{"id":37562865,"url":"https://github.com/kuzn-ilya/react-async-call","last_synced_at":"2026-01-16T09:08:02.721Z","repository":{"id":57342786,"uuid":"124758643","full_name":"kuzn-ilya/react-async-call","owner":"kuzn-ilya","description":"Declarative promise handling in React","archived":false,"fork":false,"pushed_at":"2018-11-03T12:38:15.000Z","size":628,"stargazers_count":10,"open_issues_count":2,"forks_count":2,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-10-11T12:14:02.292Z","etag":null,"topics":["async","declarative","fetch","promise","props","react","render","render-props"],"latest_commit_sha":null,"homepage":null,"language":"JavaScript","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/kuzn-ilya.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-03-11T13:21:32.000Z","updated_at":"2019-10-25T06:04:57.000Z","dependencies_parsed_at":"2022-09-16T02:50:28.646Z","dependency_job_id":null,"html_url":"https://github.com/kuzn-ilya/react-async-call","commit_stats":null,"previous_names":["kuzn-ilya/react-promise-renderer"],"tags_count":45,"template":false,"template_full_name":null,"purl":"pkg:github/kuzn-ilya/react-async-call","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzn-ilya%2Freact-async-call","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzn-ilya%2Freact-async-call/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzn-ilya%2Freact-async-call/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzn-ilya%2Freact-async-call/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kuzn-ilya","download_url":"https://codeload.github.com/kuzn-ilya/react-async-call/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kuzn-ilya%2Freact-async-call/sbom","scorecard":{"id":574383,"data":{"date":"2025-08-11","repo":{"name":"github.com/kuzn-ilya/react-async-call","commit":"25b79cdbfd41b9285b89c06de2d76b6e3db24cde"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":1.7,"checks":[{"name":"Code-Review","score":0,"reason":"Found 0/10 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Dangerous-Workflow","score":-1,"reason":"no workflows found","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Token-Permissions","score":-1,"reason":"No tokens found","details":null,"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Pinned-Dependencies","score":-1,"reason":"no dependencies found","details":null,"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 24 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":0,"reason":"115 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-67hx-6x53-jw92","Warn: Project is vulnerable to: GHSA-6chw-6frg-f759","Warn: Project is vulnerable to: GHSA-v88g-cgmw-v5xw","Warn: Project is vulnerable to: GHSA-93q8-gq69-wqmw","Warn: Project is vulnerable to: GHSA-fwr7-v2mv-hh25","Warn: Project is vulnerable to: GHSA-2mj8-pj3j-h362","Warn: Project is vulnerable to: GHSA-gqf6-75v8-vr26","Warn: Project is vulnerable to: GHSA-v45m-2wcp-gg98","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-cwfw-4gq5-mrqx","Warn: Project is vulnerable to: GHSA-g95f-p29q-9xw4","Warn: Project is vulnerable to: GHSA-grv7-fg5c-xmjg","Warn: Project is vulnerable to: GHSA-c6rq-rjc2-86v2","Warn: Project is vulnerable to: GHSA-mh2h-6j8q-x246","Warn: Project is vulnerable to: GHSA-5q88-cjfq-g2mh","Warn: Project is vulnerable to: GHSA-xp63-6vf5-xf3v","Warn: Project is vulnerable to: GHSA-3xgq-45jj-v275","Warn: Project is vulnerable to: GHSA-p28h-cc7q-c4fg","Warn: Project is vulnerable to: GHSA-gxpj-cx7g-858c","Warn: Project is vulnerable to: GHSA-w573-4hg7-7wgq","Warn: Project is vulnerable to: GHSA-ff7x-qrg7-qggm","Warn: Project is vulnerable to: GHSA-fjxv-7rqg-78g4","Warn: Project is vulnerable to: GHSA-8r6j-v8pm-fqw3","Warn: Project is vulnerable to: MAL-2023-462","Warn: Project is vulnerable to: GHSA-xf7w-r453-m56c","Warn: Project is vulnerable to: GHSA-pfrx-2q88-qq97","Warn: Project is vulnerable to: GHSA-q42p-pg8m-cqh6","Warn: Project is vulnerable to: GHSA-w457-6q6x-cgp9","Warn: Project is vulnerable to: GHSA-62gr-4qp9-h98f","Warn: Project is vulnerable to: GHSA-f52g-6jhx-586p","Warn: Project is vulnerable to: GHSA-2cf5-4w76-r9qv","Warn: Project is vulnerable to: GHSA-3cqr-58rm-57f8","Warn: Project is vulnerable to: GHSA-g9r4-xpmj-mj65","Warn: Project is vulnerable to: GHSA-q2c6-c6pm-g3gh","Warn: Project is vulnerable to: GHSA-765h-qjxv-5f44","Warn: Project is vulnerable to: GHSA-f2jv-r9rf-7988","Warn: Project is vulnerable to: GHSA-43f8-2h32-f4cj","Warn: Project is vulnerable to: GHSA-rc47-6667-2j5j","Warn: Project is vulnerable to: GHSA-pc5p-h8pf-mvwp","Warn: Project is vulnerable to: GHSA-qqgx-2p2h-9c37","Warn: Project is vulnerable to: GHSA-78xj-cgh5-2h22","Warn: Project is vulnerable to: GHSA-2p57-rm9w-gvfp","Warn: Project is vulnerable to: GHSA-2pr6-76vf-7546","Warn: Project is vulnerable to: GHSA-8j8c-7jfh-h6hx","Warn: Project is vulnerable to: GHSA-896r-f27r-55mw","Warn: Project is vulnerable to: GHSA-9c47-m6qq-7p4h","Warn: Project is vulnerable to: GHSA-6c8f-qphg-qjgp","Warn: Project is vulnerable to: GHSA-jf85-cpcp-j695","Warn: Project is vulnerable to: GHSA-p6mc-m468-83gw","Warn: Project is vulnerable to: GHSA-29mw-wpgm-hmr9","Warn: Project is vulnerable to: GHSA-35jh-r3h4-6jhm","Warn: Project is vulnerable to: GHSA-xf5p-87ch-gxw2","Warn: Project is vulnerable to: GHSA-5v2h-r2cx-5xgj","Warn: Project is vulnerable to: GHSA-rrrm-qjm4-v8hf","Warn: Project is vulnerable to: GHSA-ch52-vgq2-943f","Warn: Project is vulnerable to: GHSA-4xcv-9jjx-gfj3","Warn: Project is vulnerable to: GHSA-f9cm-qmx5-m98h","Warn: Project is vulnerable to: GHSA-7wpw-2hjm-89gp","Warn: Project is vulnerable to: GHSA-952p-6rrq-rcjv","Warn: Project is vulnerable to: GHSA-f8q6-p94x-37v3","Warn: Project is vulnerable to: GHSA-vh95-rmgr-6w4m","Warn: Project is vulnerable to: GHSA-xvch-5gv4-984h","Warn: Project is vulnerable to: GHSA-fhjf-83wg-r2j9","Warn: Project is vulnerable to: GHSA-r683-j2x4-v87g","Warn: Project is vulnerable to: GHSA-w7rc-rwvf-8q5r","Warn: Project is vulnerable to: GHSA-5fw9-fq32-wv5p","Warn: Project is vulnerable to: GHSA-m6cx-g6qm-p2cx","Warn: Project is vulnerable to: GHSA-x8qc-rrcw-4r46","Warn: Project is vulnerable to: GHSA-4328-8hgf-7wjr","Warn: Project is vulnerable to: GHSA-93f3-23rq-pjfp","Warn: Project is vulnerable to: GHSA-jmqm-f2gx-4fjv","Warn: Project is vulnerable to: GHSA-pw54-mh39-w3hc","Warn: Project is vulnerable to: GHSA-xgh6-85xh-479p","Warn: Project is vulnerable to: GHSA-rp65-9cf3-cjxr","Warn: Project is vulnerable to: GHSA-4p35-cfcx-8653","Warn: Project is vulnerable to: GHSA-7f3x-x4pr-wqhj","Warn: Project is vulnerable to: GHSA-jpp7-7chh-cf67","Warn: Project is vulnerable to: GHSA-q6wq-5p59-983w","Warn: Project is vulnerable to: GHSA-j9fq-vwqv-2fm2","Warn: Project is vulnerable to: GHSA-pqw5-jmp5-px4v","Warn: Project is vulnerable to: GHSA-hj48-42vr-x3v9","Warn: Project is vulnerable to: GHSA-hrpp-h998-j3pp","Warn: Project is vulnerable to: GHSA-p8p7-x288-28g6","Warn: Project is vulnerable to: GHSA-gcx4-mw62-g8wm","Warn: Project is vulnerable to: GHSA-r2j6-p67h-q639","Warn: Project is vulnerable to: GHSA-c2qf-rxjj-qqgw","Warn: Project is vulnerable to: GHSA-44c6-4v22-4mhx","Warn: Project is vulnerable to: GHSA-4x5v-gmq8-25ch","Warn: Project is vulnerable to: GHSA-h9rv-jmmf-4pgx","Warn: Project is vulnerable to: GHSA-hxcc-f52p-wc94","Warn: Project is vulnerable to: GHSA-4g88-fppr-53pp","Warn: Project is vulnerable to: GHSA-4jqc-8m5r-9rpr","Warn: Project is vulnerable to: GHSA-vx3p-948g-6vhq","Warn: Project is vulnerable to: GHSA-mxhp-79qh-mcx6","Warn: Project is vulnerable to: GHSA-j44m-qm6p-hp7m","Warn: Project is vulnerable to: GHSA-3jfq-g458-7qm9","Warn: Project is vulnerable to: GHSA-5955-9wpr-37jh","Warn: Project is vulnerable to: GHSA-f5x3-32g6-xq36","Warn: Project is vulnerable to: GHSA-r628-mhmh-qjhw","Warn: Project is vulnerable to: GHSA-9r2w-394v-53qc","Warn: Project is vulnerable to: GHSA-qq89-hq3f-393p","Warn: Project is vulnerable to: GHSA-52f5-9888-hmc6","Warn: Project is vulnerable to: GHSA-jgrx-mgxx-jf9v","Warn: Project is vulnerable to: GHSA-72xf-g2v4-qvf3","Warn: Project is vulnerable to: GHSA-7p7h-4mm5-852v","Warn: Project is vulnerable to: GHSA-38fc-wpqx-33j7","Warn: Project is vulnerable to: GHSA-662x-fhqg-9p8v","Warn: Project is vulnerable to: GHSA-394c-5j6w-4xmx","Warn: Project is vulnerable to: GHSA-78cj-fxph-m83p","Warn: Project is vulnerable to: GHSA-fhg7-m89q-25r3","Warn: Project is vulnerable to: GHSA-cf4h-3jhx-xvhq","Warn: Project is vulnerable to: GHSA-6fc8-4gx4-v693","Warn: Project is vulnerable to: GHSA-3h5v-q93c-6h6q","Warn: Project is vulnerable to: GHSA-c4w7-xm78-47vh","Warn: Project is vulnerable to: GHSA-p9pc-299p-vxgp"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-20T17:15:29.739Z","repository_id":57342786,"created_at":"2025-08-20T17:15:29.739Z","updated_at":"2025-08-20T17:15:29.739Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28478049,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-16T06:30:42.265Z","status":"ssl_error","status_checked_at":"2026-01-16T06:30:16.248Z","response_time":107,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"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":["async","declarative","fetch","promise","props","react","render","render-props"],"created_at":"2026-01-16T09:08:02.629Z","updated_at":"2026-01-16T09:08:02.709Z","avatar_url":"https://github.com/kuzn-ilya.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# React Async Call\n\n[![npm version][npm-badge]][npm]\n[![Build Status][build-badge]][build]\n[![Code Coverage][coverage-badge]][coverage]\n[![MIT License][license-badge]][license]\n[![size][size-badge]][unpkg-dist]\n[![gzip size][gzip-badge]][unpkg-dist]\n[![module formats: umd, cjs, and es][module-formats-badge]][unpkg-dist]\n\nDeclarative promise handling in React.\n\n## Table of Content\n  * [Motivation](#motivation)\n  * [Install](#install)\n  * [Usage](#usage)\n    * [Basic Usage](#basic-usage)\n    * [Data Fetching](#data-fetching)\n    * [Incremental Data Fetching](#incremental-data-fetching)\n  * [API Reference](#api-reference)\n  * [Change Log](#change-log)\n  * [Credits](#credits)\n\n## Motivation\n\nHandling promise-returning functions (for example, [`fetch`][fetch-api]) is not hard to do in React application. There are several packages like [holen][holen] or [React Request][react-request] for simplifying such kind of tasks but theirs authors try to impose their own vision on various aspects of data fetching. For instance, [React Request][react-request] has a cache for HTTP requests but what will happen if you decide to change caching strategy? React Async Call tries to sharpen the edges. This is minimalistic package that can be used not only for data fetching but also for handling any promise-returning functions.\n\n## Install\n\n### Using npm\n\n`npm i react-async-call --save`\n\nThen, use it as usual:\n\n```JS\n// using ES6 modules\nimport createAsyncCallComponent from 'react-async-call'\n\n// using CommonJS modules\nvar createAsyncCallComponent = require('react-async-call').createAsyncCallComponent\n```\n\n### UMD build\n\nThe UMD build is also available on [unpkg][unpkg]:\n\n```HTML\n\u003cscript src=\"https://unpkg.com/react-async-call\"\u003e\u003c/script\u003e\n```\n\nThe package is avalable on `window.ReactAsyncCall`\n\n## Usage\n\n### Basic Usage\n\n* [JavaScript Example](https://codesandbox.io/s/y7349vl4oj)\n* [TypeScript Example](https://codesandbox.io/s/w76rq8jjx8)\n\n```jsx\nimport createAsyncCallComponent from 'react-async-call'\n\nconst AsyncCall = createAsyncCallComponent(value =\u003e Promise.resolve(42))\n\nconst Example = () =\u003e (\n  \u003cAsyncCall\u003e\n    \u003cAsyncCall.Running\u003e\n      \u003cdiv\u003eLoading...\u003c/div\u003e\n    \u003c/AsyncCall.Running\u003e\n    \u003cAsyncCall.Resolved\u003e{({ result }) =\u003e \u003cdiv\u003eThe result of function call is {result}\u003c/div\u003e}\u003c/AsyncCall.Resolved\u003e\n    \u003cAsyncCall.Rejected\u003e{({ rejectReason }) =\u003e \u003cdiv\u003eError: {rejectReason}\u003c/div\u003e}\u003c/AsyncCall.Rejected\u003e\n  \u003c/AsyncCall\u003e\n)\n```\n\n### Data Fetching\n\n* [JavaScript Example](https://codesandbox.io/s/vn8qmr43yy)\n* [TypeScript Example](https://codesandbox.io/s/ryxwnkl34)\n\n### Incremental Data Fetching\n\n* [JavaScript Example](https://codesandbox.io/s/mzzvlmj65y)\n* [TypeScript Example](https://codesandbox.io/s/5y3m6mrx9p)\n\n# API Reference\n\n## Exported Members\n\n\u003ca name=\"createAsyncCallComponent\"\u003e\u003c/a\u003e\n\n### `createAsyncCallComponent(fn, [displayName])` ⇒ [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)\nA factory function that creates React component class and binds async operation to it:\n```jsx\nconst Fetcher = createAsyncCallComponent(() =\u003e fetch('https://api.github.com/repositories').then(data =\u003e data.json()))\n```\n\nAfter calling of this function you can use returned component and its static sub-components to hook async operation lifecycle:\n\n```jsx\n// Start executing async operation on Fetcher mount\n\u003cFetcher\u003e\n  \u003cFetcher.Running\u003e\n    Renders only if async operation is executing\n  \u003c/Fetcher.Running\u003e\n\n  \u003cFetcher.Resolved\u003e\n    {({ result }) =\u003e (\n      \u003cdiv\u003e\n        Renders if async operation has been executed successfully\n        \u003cpre\u003e{JSON.stringify(result)}\u003e\u003c/pre\u003e\n      \u003c/div\u003e\n    )}}\n  \u003c/Fetcher.Resolved\u003e\n\n  \u003cFetcher.Rejected\u003e\n    Renders only if async operation failed\n  \u003c/Fetcher.Rejected\u003e\n\u003c/Fetcher\u003e\n```\n\n`createAsyncCallComponent` is the only member exported by react-async-call package.\n\n**Kind**: global function  \n**Params**\n\n\n| Param | Type | Default | Description |\n| --- | --- | --- | --- |\n| fn | [\u003ccode\u003eAsyncFunction\u003c/code\u003e](#AsyncFunction) |  | See [`AsyncFunction` signature](#AsyncFunction) for details. |\n| [displayName] | \u003ccode\u003eString\u003c/code\u003e | \u003ccode\u003e\u0026quot;AsyncCall\u0026quot;\u003c/code\u003e | Component name (visible, for example, in React extension of Chrome Dev Tools). |\n\n**Returns**: [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall) - Returns React [component class `AsyncCall`](#AsyncCall) for the further usage.\nThis class contains extra component classes [`Running`](#AsyncCall.Running),\n[`Rejected`](#AsyncCall.Rejected), [`Resolved`](#AsyncCall.Resolved),\n[`Completed`](#AsyncCall.Completed), [`ResultStore`](#AsyncCall.ResultStore),\n[`Executor`](#AsyncCall.Executor) and [`State`](#AsyncCall.State) which can be used as children\n(direct or indirect) of `AsyncCall`.  \n\n* * *\n\n## React Components\n\n\u003ca name=\"AsyncCall\"\u003e\u003c/a\u003e\n\n### AsyncCall ⇐ \u003ccode\u003eReact.Component\u003c/code\u003e\nReact Component. This class is returned by call of [createAsyncCallComponent](#createAsyncCallComponent) and this is the only way to get it.\n\n**Kind**: global class  \n**Extends**: \u003ccode\u003eReact.Component\u003c/code\u003e  \n**Properties**\n\n| Name | Type | Default | Description |\n| --- | --- | --- | --- |\n| children | \u003ccode\u003eReactNode\u003c/code\u003e \\| [\u003ccode\u003eAsyncCallChildrenFunction\u003c/code\u003e](#AsyncCallChildrenFunction) |  | Property `children` can be either a ReactNode or a function that receives an object as its only argument and return ReactNode. `AsyncCall` component **always** renders its children. We recommend to use [the first form of using `children` property](https://github.com/kuzn-ilya/react-async-call/blob/master/README.md#basic-usage) and respond to async operation execution results using *static sub-components* (like [`Running`](#AsyncCall.Running), [`Rejected`](#AsyncCall.Rejected), [`Resolved`](#AsyncCall.Resolved), [`Completed`](#AsyncCall.Completed), [`ResultStore`](#AsyncCall.ResultStore), [`Executor`](#AsyncCall.Executor) and [`State`](#AsyncCall.State)). |\n| params | \u003ccode\u003eany\u003c/code\u003e |  | A value that will be passed as a single argument into async function. Every time when change of this property occurs, asyncronous operation restarts. |\n| [lazy] | \u003ccode\u003eBoolean\u003c/code\u003e | \u003ccode\u003efalse\u003c/code\u003e | If `true`, component will not start execution of asynchronous operation during component mount phase and on `params` property change. You should start async operation manualy by calling [`execute` method](#AsyncCall+execute) or via [`Executor`](#AsyncCall.Executor). |\n\n\n* [AsyncCall](#AsyncCall) ⇐ \u003ccode\u003eReact.Component\u003c/code\u003e\n    * _instance_\n        * [`.execute()`](#AsyncCall+execute)\n    * _static_\n        * [.ResultStore](#AsyncCall.ResultStore) ⇐ \u003ccode\u003eReact.Component\u003c/code\u003e\n            * _instance_\n                * [`.reset([execute])`](#AsyncCall.ResultStore+reset)\n            * _static_\n                * [.HasResult](#AsyncCall.ResultStore.HasResult) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n                * [.Resetter](#AsyncCall.ResultStore.Resetter) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n        * [.Running](#AsyncCall.Running) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n        * [.Resolved](#AsyncCall.Resolved) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n        * [.Rejected](#AsyncCall.Rejected) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n        * [.Executor](#AsyncCall.Executor) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n        * [.State](#AsyncCall.State) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n        * [.Completed](#AsyncCall.Completed) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n\n\n* * *\n\n\u003ca name=\"AsyncCall+execute\"\u003e\u003c/a\u003e\n\n#### `asyncCall.execute()`\nMethod for executing async operation manually.\nIt is recommended to use [`\u003cExecutor\u003e` component](#AsyncCall.Executor) instead.\n\n**Kind**: instance method of [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)  \n\n* * *\n\n\u003ca name=\"AsyncCall.ResultStore\"\u003e\u003c/a\u003e\n\n#### AsyncCall.ResultStore ⇐ \u003ccode\u003eReact.Component\u003c/code\u003e\nReact Component. Implements store of results of sequential async calls.\nUseful when you need to accumulate results of async calls (e.g., to glue together sequential calls of server API).\n\n**Kind**: static class of [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)  \n**Extends**: \u003ccode\u003eReact.Component\u003c/code\u003e  \n**Properties**\n\n| Name | Type | Default | Description |\n| --- | --- | --- | --- |\n| children | [\u003ccode\u003eResultStoreChildrenFunction\u003c/code\u003e](#ResultStoreChildrenFunction) \\| \u003ccode\u003eReactNode\u003c/code\u003e |  | React children or function that returns rendered result depending on `hasResult` flag and `result`. |\n| reduce | [\u003ccode\u003eReduceFunction\u003c/code\u003e](#ReduceFunction) |  | Function from previousResult and currentResult to a new result. Useful, for example, when you need to accumulate sequential async calls (e.g. for fetching data for infinte page scroll). |\n| [initialValue] | \u003ccode\u003eany\u003c/code\u003e |  | Optional initial value for the result store. If value is provided, result store will have result always. |\n| [reset] | \u003ccode\u003eboolean\u003c/code\u003e | \u003ccode\u003efalse\u003c/code\u003e | @deprecated If `true`, clears the store (**Deprecated, will be removed in version 1.0.0. Use [Resetter](#AsyncCall.ResultStore.Resetter) instead**). |\n\n\n* [.ResultStore](#AsyncCall.ResultStore) ⇐ \u003ccode\u003eReact.Component\u003c/code\u003e\n    * _instance_\n        * [`.reset([execute])`](#AsyncCall.ResultStore+reset)\n    * _static_\n        * [.HasResult](#AsyncCall.ResultStore.HasResult) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n        * [.Resetter](#AsyncCall.ResultStore.Resetter) ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\n\n\n* * *\n\n\u003ca name=\"AsyncCall.ResultStore+reset\"\u003e\u003c/a\u003e\n\n##### `resultStore.reset([execute])`\nResets result store to its initial state.\n\n**Kind**: instance method of [\u003ccode\u003eResultStore\u003c/code\u003e](#AsyncCall.ResultStore)  \n**Params**\n\n\n| Param | Type | Default | Description |\n| --- | --- | --- | --- |\n| [execute] | \u003ccode\u003ebool\u003c/code\u003e | \u003ccode\u003etrue\u003c/code\u003e | Wether execute promise-returning function after resetting or not. |\n\n\n* * *\n\n\u003ca name=\"AsyncCall.ResultStore.HasResult\"\u003e\u003c/a\u003e\n\n##### ResultStore.HasResult ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\nReact Component. Renders its children whenever result store is not empty (has result).\nProperty `children` must be a function with the only argument receiving object with the only field `result`.\n\n**Kind**: static class of [\u003ccode\u003eResultStore\u003c/code\u003e](#AsyncCall.ResultStore)  \n**Extends**: \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e  \n**Properties**\n\n| Name | Type |\n| --- | --- |\n| children | [\u003ccode\u003eHasResultChildrenFunction\u003c/code\u003e](#HasResultChildrenFunction) | \n\n\n* * *\n\n\u003ca name=\"AsyncCall.ResultStore.Resetter\"\u003e\u003c/a\u003e\n\n##### ResultStore.Resetter ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\nReact Component. Renders its children always. Property `children` must be a function with the only argument receiving an object\nwith a function for manual reset of [ResultStore](#AsyncCall.ResultStore).\n\n**Kind**: static class of [\u003ccode\u003eResultStore\u003c/code\u003e](#AsyncCall.ResultStore)  \n**Extends**: \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e  \n**Properties**\n\n| Name | Type |\n| --- | --- |\n| children | [\u003ccode\u003eResetterChildrenFunction\u003c/code\u003e](#ResetterChildrenFunction) | \n\n\n* * *\n\n\u003ca name=\"AsyncCall.Running\"\u003e\u003c/a\u003e\n\n#### AsyncCall.Running ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\nReact Component. Renders its children whenever async operation was started but is still executing. Otherwise renders nothing.\n\n**Kind**: static class of [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)  \n**Extends**: \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e  \n**Properties**\n\n| Name | Type |\n| --- | --- |\n| children | \u003ccode\u003eReactNode\u003c/code\u003e | \n\n\n* * *\n\n\u003ca name=\"AsyncCall.Resolved\"\u003e\u003c/a\u003e\n\n#### AsyncCall.Resolved ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\nReact Component. Renders its children whenever async operation has been completed successfully (promise was resolved),\nbut is still not started again. Otherwise renders nothing.\nProperty `children` can be either React node(s) or children function with the only argument receiving object with the only field `result`.\n\n**Kind**: static class of [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)  \n**Extends**: \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e  \n**Properties**\n\n| Name | Type |\n| --- | --- |\n| children | \u003ccode\u003eReactNode\u003c/code\u003e \\| [\u003ccode\u003eResolvedChildrenFunction\u003c/code\u003e](#ResolvedChildrenFunction) | \n\n\n* * *\n\n\u003ca name=\"AsyncCall.Rejected\"\u003e\u003c/a\u003e\n\n#### AsyncCall.Rejected ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\nReact Component. Renders its children whenever async operation has been completed with failure (promise was rejected),\nbut is still not started again. Otherwise renders nothing.\nProperty `children` can be either React node(s) or children function with the only argument receiving object with the only field `rejectReason`\n(promise reject reason).\n\n**Kind**: static class of [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)  \n**Extends**: \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e  \n**Properties**\n\n| Name | Type |\n| --- | --- |\n| children | \u003ccode\u003eReactNode\u003c/code\u003e \\| [\u003ccode\u003eRejectedChildrenFunction\u003c/code\u003e](#RejectedChildrenFunction) | \n\n\n* * *\n\n\u003ca name=\"AsyncCall.Executor\"\u003e\u003c/a\u003e\n\n#### AsyncCall.Executor ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\nReact Component. Renders its children always. Property `children` must be a function with the only argument receiving an object\nwith a function for manual execution of async operation.\n\n**Kind**: static class of [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)  \n**Extends**: \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e  \n**Properties**\n\n| Name | Type |\n| --- | --- |\n| children | [\u003ccode\u003eExecutorChildrenFunction\u003c/code\u003e](#ExecutorChildrenFunction) | \n\n\n* * *\n\n\u003ca name=\"AsyncCall.State\"\u003e\u003c/a\u003e\n\n#### AsyncCall.State ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\nReact Component. Renders its children always. Property `children` must be a function\nwith the only argument receiving an object ([see description of `StateChildrenFunction`](#StateChildrenFunction))\nwith the state of async operation. `State` component is handy for complicated UI cases when none of static components of [AsyncCall](#AsyncCall) suits you.\n\n**Kind**: static class of [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)  \n**Extends**: \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e  \n**Properties**\n\n| Name | Type |\n| --- | --- |\n| children | [\u003ccode\u003eStateChildrenFunction\u003c/code\u003e](#StateChildrenFunction) | \n\n\n* * *\n\n\u003ca name=\"AsyncCall.Completed\"\u003e\u003c/a\u003e\n\n#### AsyncCall.Completed ⇐ \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e\nReact Component. Renders its children whenever async operation has been completed (successfully or not),\nbut is still not started again. Otherwise renders nothing.\n\n```jsx\n\u003cAsyncCall.Completed\u003e\n  Async operation completed\n\u003c/AsyncCall.Completed\u003e\n```\n\n**Kind**: static class of [\u003ccode\u003eAsyncCall\u003c/code\u003e](#AsyncCall)  \n**Extends**: \u003ccode\u003eReact.StatelessComponent\u003c/code\u003e  \n**Properties**\n\n| Name | Type | Description |\n| --- | --- | --- |\n| [children] | \u003ccode\u003eReactNode\u003c/code\u003e | React children to be rendered whenever async operation is completed. |\n\n\n* * *\n\n## Function Signatures\n\n\u003ca name=\"ResultStoreChildrenFunction\"\u003e\u003c/a\u003e\n\n### `ResultStoreChildrenFunction(params)` ⇒ \u003ccode\u003eReactNode\u003c/code\u003e\nType of `children` function of a [ResultStore](#AsyncCall.ResultStore) component.\n\n**Params**\n\n\n| Param | Type | Description |\n| --- | --- | --- |\n| params | \u003ccode\u003eobject\u003c/code\u003e |  |\n| params.hasResult | \u003ccode\u003eboolean\u003c/code\u003e |  |\n| [params.result] | \u003ccode\u003eany\u003c/code\u003e |  |\n| params.reset | [\u003ccode\u003eResetFunction\u003c/code\u003e](#ResetFunction) | Function for manual store cleaning. |\n\n**Returns**: \u003ccode\u003eReactNode\u003c/code\u003e - Should return rendered React component(s) depending on supplied params.  \n\n* * *\n\n\u003ca name=\"ReduceFunction\"\u003e\u003c/a\u003e\n\n### `ReduceFunction(previousResult, currentResult)` ⇒ \u003ccode\u003eany\u003c/code\u003e\nType of `reduce` property of a [ResultStore](#AsyncCall.ResultStore) component.\n\n**Params**\n\n\n| Param | Type |\n| --- | --- |\n| previousResult | \u003ccode\u003eany\u003c/code\u003e | \n| currentResult | \u003ccode\u003eany\u003c/code\u003e | \n\n\n* * *\n\n\u003ca name=\"HasResultChildrenFunction\"\u003e\u003c/a\u003e\n\n### `HasResultChildrenFunction(params)` ⇒ \u003ccode\u003eReactNode\u003c/code\u003e\nType of children function for [HasResult](#AsyncCall.ResultStore.HasResult)\n\n**Params**\n\n\n| Param | Type |\n| --- | --- |\n| params | \u003ccode\u003eobject\u003c/code\u003e | \n| params.result | \u003ccode\u003eany\u003c/code\u003e | \n\n**Returns**: \u003ccode\u003eReactNode\u003c/code\u003e - Should return rendered React component(s) depending on supplied params.  \n\n* * *\n\n\u003ca name=\"ResetFunction\"\u003e\u003c/a\u003e\n\n### `ResetFunction([execute])`\nReset function\n\n**Params**\n\n\n| Param | Type | Default | Description |\n| --- | --- | --- | --- |\n| [execute] | \u003ccode\u003ebool\u003c/code\u003e | \u003ccode\u003efalse\u003c/code\u003e | Wether execute promise-returning function after resetting or not. |\n\n\n* * *\n\n\u003ca name=\"ResetterChildrenFunction\"\u003e\u003c/a\u003e\n\n### `ResetterChildrenFunction(params)` ⇒ \u003ccode\u003eReactNode\u003c/code\u003e\nType of children function for [Resetter](#AsyncCall.ResultStore.Resetter)\n\n**Params**\n\n\n| Param | Type | Description |\n| --- | --- | --- |\n| params | \u003ccode\u003eobject\u003c/code\u003e |  |\n| params.reset | [\u003ccode\u003eResetFunction\u003c/code\u003e](#ResetFunction) | Function for manual clearing of [ResultStore](#AsyncCall.ResultStore). |\n\n**Returns**: \u003ccode\u003eReactNode\u003c/code\u003e - Should return rendered React component(s) depending on supplied params.  \n\n* * *\n\n\u003ca name=\"AsyncFunction\"\u003e\u003c/a\u003e\n\n### `AsyncFunction(params)` ⇒ \u003ccode\u003ePromise\u003c/code\u003e\nAsynchronous function (aka asynchronous operation or promise-returning function)\nwhich returns promise based on supplied parameter.\n\n**Params**\n\n\n| Param | Type | Description |\n| --- | --- | --- |\n| params | \u003ccode\u003eany\u003c/code\u003e | Parameters, based on which function should return promise. |\n\n**Returns**: \u003ccode\u003ePromise\u003c/code\u003e - Promise object that represents asynchronous operation result.  \n**Example**  \nThe function below returns result (`Promise` object) of getting user data from GitHub API by his/her GitHub login:\n```\nconst getGitHubUserData = userName =\u003e fetch(`https://api.github.com/users/${userName}`).then(data =\u003e data.json())\n```\n\n* * *\n\n\u003ca name=\"ExecuteFunction\"\u003e\u003c/a\u003e\n\n### `ExecuteFunction()` ⇒ \u003ccode\u003evoid\u003c/code\u003e\nExecute function\n\n\n* * *\n\n\u003ca name=\"AsyncCallChildrenFunction\"\u003e\u003c/a\u003e\n\n### `AsyncCallChildrenFunction(params)` ⇒ \u003ccode\u003eReactNode\u003c/code\u003e\nType of children function for [AsyncCall](#AsyncCall)\n\n**Params**\n\n\n| Param | Type | Description |\n| --- | --- | --- |\n| params | \u003ccode\u003eobject\u003c/code\u003e | Represents current status of asynchronous operation. |\n| params.running | \u003ccode\u003eboolean\u003c/code\u003e | Indicates whether asynchronous operation is executing or not. |\n| params.rejected | \u003ccode\u003eboolean\u003c/code\u003e | Indicates whether asynchronous operation was failed when it was called last time. If `true`, result of promise rejection (error) can be found in the `params.rejectReason`. |\n| params.resolved | \u003ccode\u003eboolean\u003c/code\u003e | Indicates whether asynchronous operation was succeeded when it was called last time. If `true`, result of promise resolving can be found in the `params.result`. |\n| [params.result] | \u003ccode\u003eany\u003c/code\u003e | Contains result of promise (returned by async function) resolving if function call was successful. `undefined` if asynchronous operation is running or promise was rejected. |\n| [params.rejectReason] | \u003ccode\u003eany\u003c/code\u003e | Contains result of promise (returned by async function) rejection if function call was unsuccessful. `undefined` if asynchronous operation is running or promise was resolved. |\n| params.execute | [\u003ccode\u003eExecuteFunction\u003c/code\u003e](#ExecuteFunction) | Function for manual execution of asynchronous operation. |\n\n**Returns**: \u003ccode\u003eReactNode\u003c/code\u003e - Should return rendered React component(s) depending on supplied params.  \n\n* * *\n\n\u003ca name=\"ResolvedChildrenFunction\"\u003e\u003c/a\u003e\n\n### `ResolvedChildrenFunction()` ⇒ \u003ccode\u003eReactNode\u003c/code\u003e\nType of children function for [Resolved](#AsyncCall.Resolved)\n\n**Params**\n\n\n| Param | Type |\n| --- | --- |\n|  | \u003ccode\u003eobject\u003c/code\u003e | \n| params.result | \u003ccode\u003eany\u003c/code\u003e | \n\n**Returns**: \u003ccode\u003eReactNode\u003c/code\u003e - Should return rendered React component(s) depending on supplied params.  \n\n* * *\n\n\u003ca name=\"RejectedChildrenFunction\"\u003e\u003c/a\u003e\n\n### `RejectedChildrenFunction(params)` ⇒ \u003ccode\u003eReactNode\u003c/code\u003e\nType of children function for [Rejected](#AsyncCall.Rejected)\n\n**Params**\n\n\n| Param | Type |\n| --- | --- |\n| params | \u003ccode\u003eobject\u003c/code\u003e | \n| params.rejectReason | \u003ccode\u003eany\u003c/code\u003e | \n\n**Returns**: \u003ccode\u003eReactNode\u003c/code\u003e - Should return rendered React component(s) depending on supplied params.  \n\n* * *\n\n\u003ca name=\"ExecutorChildrenFunction\"\u003e\u003c/a\u003e\n\n### `ExecutorChildrenFunction(params)` ⇒ \u003ccode\u003eReactNode\u003c/code\u003e\nType of children function for [Executor](#AsyncCall.Executor)\n\n**Params**\n\n\n| Param | Type | Description |\n| --- | --- | --- |\n| params | \u003ccode\u003eobject\u003c/code\u003e |  |\n| params.execute | [\u003ccode\u003eExecuteFunction\u003c/code\u003e](#ExecuteFunction) | Function for manual execution of asynchronous operation. |\n\n**Returns**: \u003ccode\u003eReactNode\u003c/code\u003e - Should return rendered React component(s) depending on supplied params.  \n\n* * *\n\n\u003ca name=\"StateChildrenFunction\"\u003e\u003c/a\u003e\n\n### `StateChildrenFunction(params)` ⇒ \u003ccode\u003eReactNode\u003c/code\u003e\nType of children function for [State](#AsyncCall.State)\n\n**Params**\n\n\n| Param | Type | Description |\n| --- | --- | --- |\n| params | \u003ccode\u003eobject\u003c/code\u003e |  |\n| params.running | \u003ccode\u003eboolean\u003c/code\u003e | Whether async opertation is executing or not. If you only need to process `running`, use either [Running](#AsyncCall.Running) or [Completed](#AsyncCall.Completed) component instead. |\n| params.resolved | \u003ccode\u003eboolean\u003c/code\u003e | Whether async opertation was completed successfully last time or not. If you only need to process `resolved` and `result`, [Resolved](#AsyncCall.Resolved) component instead. |\n| params.rejected | \u003ccode\u003eboolean\u003c/code\u003e | Whether async opertation failed last time or not. If you only need to process `rejected` and `rejectedStatus`, use [Rejected](#AsyncCall.Rejected) component instead. |\n| [params.rejectReason] | \u003ccode\u003eany\u003c/code\u003e | Contains reject reason if async opertation failed last time. If you only need to process `rejected` and `rejectedReason`, use [Rejected](#AsyncCall.Rejected) component instead. |\n| [params.result] | \u003ccode\u003eany\u003c/code\u003e | Contains result of last successful async operation call. If you only need to process `resolved` and `result`, use [Resolved](#AsyncCall.Resolved) component instead. If you need to accumulate result, consider [ResultStore](#AsyncCall.ResultStore) usage. |\n| params.execute | [\u003ccode\u003eExecuteFunction\u003c/code\u003e](#ExecuteFunction) | Callback for manual execution of async operation. If you only need to execute async operation manualy, use [Executor](#AsyncCall.Executor) component instead.                               | |\n\n**Returns**: \u003ccode\u003eReactNode\u003c/code\u003e - Should return rendered React component(s) depending on supplied params.  \n\n* * *\n\n## Change Log\n\n[You can find change log here][changelog]\n\n## Credits\n\nGreat thanks to [@kitos](https://github.com/kitos) and [@ventrz](https://github.com/ventrz) for their invaluable help, support and bright ideas!\n\n[npm-badge]: https://badge.fury.io/js/react-async-call.svg\n[npm]: https://www.npmjs.com/package/react-async-call\n[build-badge]: https://travis-ci.org/kuzn-ilya/react-async-call.svg?branch=master\n[build]: https://travis-ci.org/kuzn-ilya/react-async-call\n[coverage-badge]: https://codecov.io/gh/kuzn-ilya/react-async-call/branch/master/graph/badge.svg\n[coverage]: https://codecov.io/gh/kuzn-ilya/react-async-call\n[license-badge]: https://img.shields.io/npm/l/react-async-call.svg\n[license]: https://github.com/kuzn-ilya/react-async-call/blob/master/LICENSE\n[size-badge]: http://img.badgesize.io/https://unpkg.com/react-async-call/umd/react-async-call.production.min.js?label=size\n[gzip-badge]: http://img.badgesize.io/https://unpkg.com/react-async-call/umd/react-async-call.production.min.js?compression=gzip\u0026label=gzip%20size\n[module-formats-badge]: https://img.shields.io/badge/module%20formats-umd%2C%20cjs-green.svg\n[unpkg-dist]: https://unpkg.com/react-async-call/\n[unpkg]: https:/unpkg.com\n[changelog]: https://github.com/kuzn-ilya/react-async-call/blob/master/docs/CHANGELOG.md\n[fetch-api]: https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API\n[holen]: https://github.com/tkh44/holen\n[react-request]: https://github.com/jamesplease/react-request","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkuzn-ilya%2Freact-async-call","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkuzn-ilya%2Freact-async-call","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkuzn-ilya%2Freact-async-call/lists"}