CINXE.COM
riverpod | Dart package
<!DOCTYPE html> <html lang="en-us"><head><script src="https://www.googletagmanager.com/gtm.js?id=GTM-MX6DBN9" async="async"></script><script src="/static/hash-9a8gn2mf/js/gtm.js" async="async"></script><meta charset="utf-8"/><meta http-equiv="x-ua-compatible" content="ie=edge"/><meta name="viewport" content="width=device-width, initial-scale=1"/><meta name="twitter:card" content="summary"/><meta name="twitter:site" content="@dart_lang"/><meta name="twitter:description" content="A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze. "/><meta name="twitter:image" content="https://pub.dev/static/hash-9a8gn2mf/img/pub-dev-icon-cover-image.png"/><meta property="og:type" content="website"/><meta property="og:site_name" content="Dart packages"/><meta property="og:title" content="riverpod | Dart package"/><meta property="og:description" content="A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze. "/><meta property="og:image" content="https://pub.dev/static/hash-9a8gn2mf/img/pub-dev-icon-cover-image.png"/><meta property="og:url" content="https://pub.dev/packages/riverpod"/><title>riverpod | Dart package</title><link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Google+Sans:wght@400;500;700&family=Google+Sans+Display:wght@400&family=Google+Sans+Text:wght@400;500;700&family=Google+Sans+Mono:wght@400;700&display=swap"/><link rel="shortcut icon" href="/favicon.ico?hash=nk4nss8c7444fg0chird9erqef2vkhb8"/><link rel="stylesheet" href="https://www.gstatic.com/glue/v25_0/ccb.min.css"/><link rel="search" type="application/opensearchdescription+xml" title="Dart packages" href="/osd.xml"/><link rel="canonical" href="https://pub.dev/packages/riverpod"/><meta name="description" content="A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze. "/><link rel="alternate" type="application/atom+xml" title="Updated Packages Feed for Pub" href="/feed.atom"/><link rel="stylesheet" type="text/css" href="/static/hash-9a8gn2mf/material/bundle/styles.css"/><link rel="stylesheet" type="text/css" href="/static/hash-9a8gn2mf/css/style.css"/><script src="/static/hash-9a8gn2mf/material/bundle/script.min.js" defer="defer"></script><script src="/static/hash-9a8gn2mf/js/script.dart.js" defer="defer"></script><script src="https://www.gstatic.com/brandstudio/kato/cookie_choice_component/cookie_consent_bar.v3.js" defer="defer" data-autoload-cookie-consent-bar="true"></script><meta name="pub-page-data" content="eyJwa2dEYXRhIjp7InBhY2thZ2UiOiJyaXZlcnBvZCIsInZlcnNpb24iOiIyLjYuMSIsImxpa2VzIjozNDU4LCJwdWJsaXNoZXJJZCI6ImRhc2gtb3ZlcmZsb3cubmV0IiwiaXNEaXNjb250aW51ZWQiOmZhbHNlLCJpc0xhdGVzdCI6dHJ1ZX0sInNlc3Npb25Bd2FyZSI6ZmFsc2V9"/><link rel="preload" href="/static/hash-9a8gn2mf/highlight/highlight-with-init.js" as="script"/></head><body class="light-theme"><script src="/static/hash-9a8gn2mf/js/dark-init.js"></script><noscript><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-MX6DBN9" height="0" width="0" style="display:none;visibility:hidden"></iframe></noscript><div class="site-header"><button class="hamburger" aria-label="menu toggle"></button><a class="logo" href="/"><img class="site-logo" src="/static/hash-9a8gn2mf/img/pub-dev-logo.svg" alt="" width="140" height="30" role="presentation"/></a><div class="site-header-space"></div><div class="site-header-mask"></div><div class="site-header-search"><form action="/packages" method="GET"><input class="site-header-search-input" name="q" placeholder="New search..." autocomplete="on" title="Search"/></form></div><nav class="site-header-nav scroll-container"><div class="nav-login-container"><button id="-account-login" class="nav-main-button link">Sign in</button></div><div class="nav-container nav-help-container hoverable"><button class="nav-main-button">Help</button><div class="nav-hover-popup"><div class="nav-table-columns"><div class="nav-table-column"><h3>Pub.dev</h3><a class="nav-link" href="/help/search" rel="noopener" target="_blank">Searching for packages</a><a class="nav-link" href="/help/scoring" rel="noopener" target="_blank">Package scoring and pub points</a></div><div class="nav-table-column"><h3>Flutter</h3><a class="nav-link" href="https://flutter.dev/using-packages/" rel="noopener" target="_blank">Using packages</a><a class="nav-link" href="https://flutter.dev/developing-packages/" rel="noopener" target="_blank">Developing packages and plugins</a><a class="nav-link" href="https://dart.dev/tools/pub/publishing" rel="noopener" target="_blank">Publishing a package</a></div><div class="nav-table-column"><h3>Dart</h3><a class="nav-link" href="https://dart.dev/guides/packages" rel="noopener" target="_blank">Using packages</a><a class="nav-link" href="https://dart.dev/tools/pub/publishing" rel="noopener" target="_blank">Publishing a package</a></div></div></div></div><div class="nav-container nav-help-container-mobile foldable"><h3 class="foldable-button">Pub.dev <img class="foldable-icon" src="/static/hash-9a8gn2mf/img/nav-mobile-foldable-icon.svg" alt="toggle folding of the section" width="13" height="6"/></h3><div class="foldable-content"><a class="nav-link" href="/help/search" rel="noopener" target="_blank">Searching for packages</a><a class="nav-link" href="/help/scoring" rel="noopener" target="_blank">Package scoring and pub points</a></div></div><div class="nav-container nav-help-container-mobile foldable"><h3 class="foldable-button">Flutter <img class="foldable-icon" src="/static/hash-9a8gn2mf/img/nav-mobile-foldable-icon.svg" alt="toggle folding of the section" width="13" height="6"/></h3><div class="foldable-content"><a class="nav-link" href="https://flutter.dev/using-packages/" rel="noopener" target="_blank">Using packages</a><a class="nav-link" href="https://flutter.dev/developing-packages/" rel="noopener" target="_blank">Developing packages and plugins</a><a class="nav-link" href="https://dart.dev/tools/pub/publishing" rel="noopener" target="_blank">Publishing a package</a></div></div><div class="nav-container nav-help-container-mobile foldable"><h3 class="foldable-button">Dart <img class="foldable-icon" src="/static/hash-9a8gn2mf/img/nav-mobile-foldable-icon.svg" alt="toggle folding of the section" width="13" height="6"/></h3><div class="foldable-content"><a class="nav-link" href="https://dart.dev/guides/packages" rel="noopener" target="_blank">Using packages</a><a class="nav-link" href="https://dart.dev/tools/pub/publishing" rel="noopener" target="_blank">Publishing a package</a></div></div></nav></div><div id="banner-container"></div><main class="container"><div class="detail-wrapper -active -has-info-box"><div class="detail-banners"><a href="https://flutter.dev/docs/development/packages-and-plugins/favorites" rel="noopener" target="_blank"><img class="ff-banner ff-banner-desktop displayed-in-light-theme" src="/static/hash-9a8gn2mf/img/ff-banner-desktop-2x.png" alt="" width="150" height="218" title="Package is a Flutter Favorite" role="presentation"/><img class="ff-banner ff-banner-desktop displayed-in-dark-theme" src="/static/hash-9a8gn2mf/img/ff-banner-desktop-dark-2x.png" alt="" width="150" height="218" title="Package is a Flutter Favorite" role="presentation"/><img class="ff-banner ff-banner-mobile displayed-in-light-theme" src="/static/hash-9a8gn2mf/img/ff-banner-mobile-2x.png" alt="" width="94" height="116" title="Package is a Flutter Favorite" role="presentation"/><img class="ff-banner ff-banner-mobile displayed-in-dark-theme" src="/static/hash-9a8gn2mf/img/ff-banner-mobile-dark-2x.png" alt="" width="94" height="116" title="Package is a Flutter Favorite" role="presentation"/></a></div><div class="detail-header -is-loose"><div class="detail-container"><div class="detail-header-outer-block"><div class="detail-header-content-block"><h1 class="title">riverpod 2.6.1 <span class="pkg-page-title-copy"><img class="pkg-page-title-copy-icon filter-invert-on-dark" src="/static/hash-9a8gn2mf/img/content-copy-icon.svg" alt="copy "riverpod: ^2.6.1" to clipboard" width="18" height="18" title="Copy "riverpod: ^2.6.1" to clipboard" data-copy-content="riverpod: ^2.6.1" data-ga-click-event="copy-package-version"/><div class="pkg-page-title-copy-feedback"><span class="code">riverpod: ^2.6.1</span> copied to clipboard</div></span></h1><div class="metadata">Published <span><a class="-x-ago" href="" title="Oct 22, 2024" aria-label="49 days ago" aria-role="button" role="button" data-timestamp="1729602083743">49 days ago</a></span> • <a class="-pub-publisher" href="/publishers/dash-overflow.net"><img class="-pub-publisher-shield filter-invert-on-dark" src="/static/hash-9a8gn2mf/img/material-icon-verified.svg" alt="verified publisher" width="14" height="14" title="Published by a pub.dev verified publisher"/>dash-overflow.net</a><span class="package-badge" title="Package is compatible with Dart 3.">Dart 3 compatible</span>• Latest: <span><a href="/packages/riverpod" title="View the latest version of riverpod">2.6.1</a></span> / <span>Prerelease: <a href="/packages/riverpod/versions/3.0.0-dev.3" title="Visit riverpod 3.0.0-dev.3 page">3.0.0-dev.3</a></span></div><div class="detail-tags-and-like"><div class="detail-tags"><div class="-pub-tag-badge"><span class="tag-badge-main">SDK</span><a class="tag-badge-sub" href="/packages?q=sdk%3Adart" rel="nofollow" title="Packages compatible with Dart SDK">Dart</a><a class="tag-badge-sub" href="/packages?q=sdk%3Aflutter" rel="nofollow" title="Packages compatible with Flutter SDK">Flutter</a></div><div class="-pub-tag-badge"><span class="tag-badge-main">Platform</span><a class="tag-badge-sub" href="/packages?q=platform%3Aandroid" rel="nofollow" title="Packages compatible with Android platform">Android</a><a class="tag-badge-sub" href="/packages?q=platform%3Aios" rel="nofollow" title="Packages compatible with iOS platform">iOS</a><a class="tag-badge-sub" href="/packages?q=platform%3Alinux" rel="nofollow" title="Packages compatible with Linux platform">Linux</a><a class="tag-badge-sub" href="/packages?q=platform%3Amacos" rel="nofollow" title="Packages compatible with macOS platform">macOS</a><a class="tag-badge-sub" href="/packages?q=platform%3Aweb" rel="nofollow" title="Packages compatible with Web platform">web</a><a class="tag-badge-sub" href="/packages?q=platform%3Awindows" rel="nofollow" title="Packages compatible with Windows platform">Windows</a></div></div><div class="detail-like"><button id="-pub-like-icon-button" class="mdc-icon-button" data-ga-click-event="toggle-like" aria-pressed="false" title="Like this package"><img class="mdc-icon-button__icon" src="/static/hash-9a8gn2mf/img/like-inactive.svg" alt="liked status: inactive" width="18" height="18"/><img class="mdc-icon-button__icon mdc-icon-button__icon--on" src="/static/hash-9a8gn2mf/img/like-active.svg" alt="liked status: active" width="18" height="18"/></button><span class="likes-count"><span id="likes-count">3.4k</span></span></div></div></div></div></div></div><div class="detail-container"><div class="detail-lead"><div class="detail-metadata-toggle"><div class="detail-metadata-toggle-icon">→</div><h3 class="detail-lead-title">Metadata</h3></div><p class="detail-lead-text">A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze. </p><p class="detail-lead-more"><a class="detail-metadata-toggle">More...</a></p></div></div><div class="detail-body"><div class="detail-tabs"><div class="detail-tabs-wide-header"><div class="detail-container"><ul class="detail-tabs-header"><li class="detail-tab tab-button detail-tab-readme-title -active">Readme</li><li class="detail-tab tab-link detail-tab-changelog-title"><a href="/packages/riverpod/changelog" role="button">Changelog</a></li><li class="detail-tab tab-link detail-tab-example-title"><a href="/packages/riverpod/example" role="button">Example</a></li><li class="detail-tab tab-link detail-tab-installing-title"><a href="/packages/riverpod/install" role="button">Installing</a></li><li class="detail-tab tab-link detail-tab-versions-title"><a href="/packages/riverpod/versions" role="button">Versions</a></li><li class="detail-tab tab-link detail-tab-analysis-title"><a href="/packages/riverpod/score" role="button">Scores</a></li></ul></div></div><div class="detail-container detail-body-main"><div class="detail-tabs-content"><section class="tab-content detail-tab-readme-content -active markdown-body"><p> <a href="https://flutter.dev/docs/development/packages-and-plugins/favorites"> <img src="https://raw.githubusercontent.com/rrousselGit/riverpod/master/resources/flutter_favorite.png" width="100" align="left"> </a> <a href="https://github.com/rrousselGit/riverpod/actions" rel="ugc"><img src="https://github.com/rrousselGit/riverpod/workflows/Build/badge.svg" alt="Build Status"></a> <a href="https://codecov.io/gh/rrousselgit/riverpod" rel="ugc"><img src="https://codecov.io/gh/rrousselgit/riverpod/branch/master/graph/badge.svg" alt="codecov"></a> <a href="https://github.com/rrousselgit/riverpod" rel="ugc"><img src="https://img.shields.io/github/stars/rrousselgit/riverpod.svg?style=flat&logo=github&colorB=deeppink&label=stars" alt="Star on Github"></a> <a href="https://opensource.org/licenses/MIT" rel="ugc"><img src="https://img.shields.io/badge/license-MIT-purple.svg" alt="License: MIT"></a> <a href="https://discord.gg/Bbumvej" rel="ugc"><img src="https://img.shields.io/discord/765557403865186374.svg?logo=discord&color=blue" alt="Discord"></a> </p><p> <a href="https://www.netlify.com" rel="ugc"> <img src="https://www.netlify.com/img/global/badges/netlify-color-accent.svg" alt="Deploys by Netlify"> </a> </p> <p></p> <p align="center"> <img src="https://github.com/rrousselGit/riverpod/blob/master/resources/icon/Facebook%20Cover%20A.png?raw=true" width="100%" alt="Riverpod"> </p> <hr> <p>A reactive caching and data-binding framework. <a href="https://riverpod.dev" rel="ugc">https://riverpod.dev</a> Riverpod makes working with asynchronous code a breeze by:</p> <ul> <li>handling errors/loading states by default. No need to manually catch errors</li> <li>natively supporting advanced scenarios, such as pull-to-refresh</li> <li>separating the logic from your UI</li> <li>ensuring your code is testable, scalable and reusable</li> </ul> <table> <thead> <tr> <th>riverpod</th> <th><a href="https://pub.dartlang.org/packages/riverpod" rel="ugc"><img src="https://img.shields.io/pub/v/riverpod.svg?label=riverpod&color=blue" alt="pub package"></a></th> </tr> </thead> <tbody> <tr> <td>flutter_riverpod</td> <td><a href="https://pub.dartlang.org/packages/flutter_riverpod" rel="ugc"><img src="https://img.shields.io/pub/v/riverpod.svg?label=flutter_riverpod&color=blue" alt="pub package"></a></td> </tr> <tr> <td>hooks_riverpod</td> <td><a href="https://pub.dartlang.org/packages/hooks_riverpod" rel="ugc"><img src="https://img.shields.io/pub/v/riverpod.svg?label=hooks_riverpod&color=blue" alt="pub package"></a></td> </tr> </tbody> </table> <p>Welcome to <a href="https://github.com/rrousselGit/riverpod" rel="ugc">Riverpod</a> (anagram of <a href="https://github.com/rrousselGit/provider" rel="ugc">Provider</a>)!</p> <p>For learning how to use <a href="https://github.com/rrousselGit/riverpod" rel="ugc">Riverpod</a>, see its documentation: >>> <a href="https://riverpod.dev" rel="ugc">https://riverpod.dev</a> <<<</p> <p>Long story short:</p> <ul> <li> <p>Define network requests by writing a function annotated with <code>@riverpod</code>:</p> <pre><code class="language-dart">@riverpod Future<String> boredSuggestion(Ref ref) async { final response = await http.get( Uri.https('boredapi.com', '/api/activity'), ); final json = jsonDecode(response.body); return json['activity']! as String; } </code></pre> </li> <li> <p>Listen to the network request in your UI and gracefully handle loading/error states.</p> <pre><code class="language-dart">class Home extends ConsumerWidget { @override Widget build(BuildContext context, WidgetRef ref) { final boredSuggestion = ref.watch(boredSuggestionProvider); // Perform a switch-case on the result to handle loading/error states return switch (boredSuggestion) { AsyncData(:final value) => Text('data: $value'), AsyncError(:final error) => Text('error: $error'), _ => const Text('loading'), }; } } </code></pre> </li> </ul> <h2 class="hash-header" id="contributing">Contributing <a href="#contributing" class="hash-link">#</a></h2> <p>Contributions are welcome!</p> <p>Here is a curated list of how you can help:</p> <ul> <li>Report bugs and scenarios that are difficult to implement</li> <li>Report parts of the documentation that are unclear</li> <li>Fix typos/grammar mistakes</li> <li>Update the documentation or add examples</li> <li>Implement new features by making a pull-request</li> </ul> <h2 class="hash-header" id="sponsors">Sponsors <a href="#sponsors" class="hash-link">#</a></h2> <p align="center"> <a href="https://raw.githubusercontent.com/rrousselGit/freezed/master/sponsorkit/sponsors.svg" rel="ugc"> <img src="https://raw.githubusercontent.com/rrousselGit/freezed/master/sponsorkit/sponsors.svg"> </a> </p> </section></div></div></div><aside class="detail-info-box"><a class="packages-scores" href="/packages/riverpod/score"><div class="packages-score packages-score-like"><div class="packages-score-value -has-value"><span class="packages-score-value-number">3.46k</span><span class="packages-score-value-sign"></span></div><div class="packages-score-label">likes</div></div><div class="packages-score packages-score-health"><div class="packages-score-value -has-value"><span class="packages-score-value-number">160</span><span class="packages-score-value-sign"></span></div><div class="packages-score-label">pub points</div></div><div class="packages-score packages-score-popularity"><div class="packages-score-value -has-value"><span class="packages-score-value-number">97</span><span class="packages-score-value-sign">%</span></div><div class="packages-score-label">popularity</div></div></a><h3 class="title">Publisher</h3><p><a href="/publishers/dash-overflow.net"><img class="-pub-publisher-shield filter-invert-on-dark" src="/static/hash-9a8gn2mf/img/material-icon-verified.svg" alt="verified publisher" width="14" height="14" title="Published by a pub.dev verified publisher"/>dash-overflow.net</a></p><h3 class="title pkg-infobox-metadata">Metadata</h3><p>A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze. </p><p><a class="link" href="https://riverpod.dev" rel="ugc">Homepage</a><br/><a class="link" href="https://github.com/rrousselGit/riverpod" rel="ugc">Repository (GitHub)</a><br/><a class="link" href="https://github.com/rrousselGit/riverpod/issues" rel="ugc">View/report issues</a><br/><a class="link" href="https://github.com/rrousselGit/riverpod/blob/master/CONTRIBUTING.md" rel="ugc">Contributing</a><br/></p><h3 class="title">Documentation</h3><p><a class="link" href="/documentation/riverpod/latest/">API reference</a><br/></p><h3 class="title">Funding</h3><p>Consider supporting this project:<br/><br/><a class="link" href="https://github.com/sponsors/rrousselGit/" rel="ugc">github.com</a><br/></p><h3 class="title">License</h3><p><img class="inline-icon-img filter-invert-on-dark" src="/static/hash-9a8gn2mf/img/material-icon-balance.svg" alt="" width="14" height="14" role="presentation"/>MIT (<a href="/packages/riverpod/license">license</a>)</p><h3 class="title">Dependencies</h3><p><a href="/packages/collection" title="^1.18.0">collection</a>, <a href="/packages/meta" title="^1.9.0">meta</a>, <a href="/packages/stack_trace" title="^1.10.0">stack_trace</a>, <a href="/packages/state_notifier" title=">=0.7.2 <2.0.0">state_notifier</a></p><h3 class="title">More</h3><p><a href="/packages?q=dependency%3Ariverpod" rel="nofollow">Packages that depend on riverpod</a></p></aside></div><script type="application/ld+json">{"@context":"http\u003a\u002f\u002fschema.org","@type":"SoftwareSourceCode","name":"riverpod","version":"2.6.1","description":"riverpod - A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze.\u000a","url":"https\u003a\u002f\u002fpub.dev\u002fpackages\u002friverpod","dateCreated":"2020-05-16T06\u003a11\u003a31.557437Z","dateModified":"2024-10-22T13\u003a01\u003a23.743599Z","programmingLanguage":"Dart","image":"https\u003a\u002f\u002fpub.dev\u002fstatic\u002fimg\u002fpub-dev-icon-cover-image.png","license":"https\u003a\u002f\u002fpub.dev\u002fpackages\u002friverpod\u002flicense"}</script></div><div class="detail-metadata"><h3 class="detail-metadata-title"><span class="detail-metadata-toggle">←</span> Metadata</h3><div class="detail-info-box"><a class="packages-scores" href="/packages/riverpod/score"><div class="packages-score packages-score-like"><div class="packages-score-value -has-value"><span class="packages-score-value-number">3.46k</span><span class="packages-score-value-sign"></span></div><div class="packages-score-label">likes</div></div><div class="packages-score packages-score-health"><div class="packages-score-value -has-value"><span class="packages-score-value-number">160</span><span class="packages-score-value-sign"></span></div><div class="packages-score-label">pub points</div></div><div class="packages-score packages-score-popularity"><div class="packages-score-value -has-value"><span class="packages-score-value-number">97</span><span class="packages-score-value-sign">%</span></div><div class="packages-score-label">popularity</div></div></a><h3 class="title">Publisher</h3><p><a href="/publishers/dash-overflow.net"><img class="-pub-publisher-shield filter-invert-on-dark" src="/static/hash-9a8gn2mf/img/material-icon-verified.svg" alt="verified publisher" width="14" height="14" title="Published by a pub.dev verified publisher"/>dash-overflow.net</a></p><h3 class="title pkg-infobox-metadata">Metadata</h3><p>A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze. </p><p><a class="link" href="https://riverpod.dev" rel="ugc">Homepage</a><br/><a class="link" href="https://github.com/rrousselGit/riverpod" rel="ugc">Repository (GitHub)</a><br/><a class="link" href="https://github.com/rrousselGit/riverpod/issues" rel="ugc">View/report issues</a><br/><a class="link" href="https://github.com/rrousselGit/riverpod/blob/master/CONTRIBUTING.md" rel="ugc">Contributing</a><br/></p><h3 class="title">Documentation</h3><p><a class="link" href="/documentation/riverpod/latest/">API reference</a><br/></p><h3 class="title">Funding</h3><p>Consider supporting this project:<br/><br/><a class="link" href="https://github.com/sponsors/rrousselGit/" rel="ugc">github.com</a><br/></p><h3 class="title">License</h3><p><img class="inline-icon-img filter-invert-on-dark" src="/static/hash-9a8gn2mf/img/material-icon-balance.svg" alt="" width="14" height="14" role="presentation"/>MIT (<a href="/packages/riverpod/license">license</a>)</p><h3 class="title">Dependencies</h3><p><a href="/packages/collection" title="^1.18.0">collection</a>, <a href="/packages/meta" title="^1.9.0">meta</a>, <a href="/packages/stack_trace" title="^1.10.0">stack_trace</a>, <a href="/packages/state_notifier" title=">=0.7.2 <2.0.0">state_notifier</a></p><h3 class="title">More</h3><p><a href="/packages?q=dependency%3Ariverpod" rel="nofollow">Packages that depend on riverpod</a></p></div><p class="detail-lead-back"><a class="detail-metadata-toggle">Back</a></p></div><div id="-screenshot-carousel" class="carousel"><fab id="-carousel-prev" class="mdc-fab carousel-prev carousel-nav" data-mdc-auto-init="MDCRipple" title="Previous" data-ga-click-event="screenshot-carousel-prev-click" tabindex="0"><div class="mdc-fab__ripple"></div><img class="mdc-fab__icon" src="/static/hash-9a8gn2mf/img/keyboard_arrow_left.svg" alt="previous" width="24" height="24" aria-hidden="true"/></fab><div id="-image-container" class="image-container"></div><fab id="-carousel-next" class="mdc-fab carousel-next carousel-nav" data-mdc-auto-init="MDCRipple" title="Next" data-ga-click-event="screenshot-carousel-next-click" tabindex="0"><div class="mdc-fab__ripple"></div><img class="mdc-fab__icon" src="/static/hash-9a8gn2mf/img/keyboard_arrow_right.svg" alt="next" width="24" height="24" aria-hidden="true"/></fab><p id="-screenshot-description" class="screenshot-description"></p></div></main><footer class="site-footer"><a class="link" href="https://dart.dev/">Dart language</a><a class="link sep" href="/report?subject=package%3Ariverpod&url=https%3A%2F%2Fpub.dev%2Fpackages%2Friverpod">Report package</a><a class="link sep" href="/policy">Policy</a><a class="link sep" href="https://www.google.com/intl/en/policies/terms/">Terms</a><a class="link sep" href="https://developers.google.com/terms/">API Terms</a><a class="link sep" href="/security">Security</a><a class="link sep" href="https://www.google.com/intl/en/policies/privacy/">Privacy</a><a class="link sep" href="/help">Help</a><a class="link icon sep" href="/feed.atom"><img class="inline-icon" src="/static/hash-9a8gn2mf/img/rss-feed-icon.svg" alt="RSS" width="20" height="20" title="RSS/atom feed"/></a><a class="link icon github_issue" href="https://github.com/dart-lang/pub-dev/issues/new"><img class="inline-icon" src="/static/hash-9a8gn2mf/img/bug-report-white-96px.png" alt="bug report" width="20" height="20" title="Report an issue with this site"/></a></footer><script src="/static/hash-9a8gn2mf/highlight/highlight-with-init.js" defer="defer"></script></body></html>