<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Hany Sameh</title>
    <description>The latest articles on Forem by Hany Sameh (@hanysameh).</description>
    <link>https://forem.com/hanysameh</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1022161%2F1f95c73d-b02d-4f25-ab87-2163ca41addc.jpeg</url>
      <title>Forem: Hany Sameh</title>
      <link>https://forem.com/hanysameh</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/hanysameh"/>
    <language>en</language>
    <item>
      <title>Flutter Bloc</title>
      <dc:creator>Hany Sameh</dc:creator>
      <pubDate>Fri, 03 Mar 2023 13:09:19 +0000</pubDate>
      <link>https://forem.com/hanysameh/flutter-bloc-2abc</link>
      <guid>https://forem.com/hanysameh/flutter-bloc-2abc</guid>
      <description>&lt;h2&gt;
  
  
  &lt;strong&gt;&lt;em&gt;What is flutter bloc?&lt;/em&gt;&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;Flutter bloc is one of the state management for Flutter applications. You can use it to handle all the possible states of your application in an easy way.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--ANBGc0Dn--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://user-images.githubusercontent.com/38296077/126981491-e13d63ec-932d-4640-a9c2-927259ce48a7.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--ANBGc0Dn--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://user-images.githubusercontent.com/38296077/126981491-e13d63ec-932d-4640-a9c2-927259ce48a7.jpg" alt="https://user-images.githubusercontent.com/38296077/126981491-e13d63ec-932d-4640-a9c2-927259ce48a7.jpg" width="880" height="495"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Why Bloc?
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Bloc makes it easy to separate presentation from business logic, making your code &lt;em&gt;fast&lt;/em&gt;, &lt;em&gt;easy to test&lt;/em&gt;, and &lt;em&gt;reusable&lt;/em&gt;.&lt;/strong&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Advantages
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;Understand easily what’s happening inside your app.&lt;/li&gt;
&lt;li&gt;More structured code, Easily to maintain an test.&lt;/li&gt;
&lt;li&gt;Know and understand every state of your app.&lt;/li&gt;
&lt;li&gt;Work on a single, stable, popular and effective bloc codebase.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  &lt;strong&gt;&lt;em&gt;How does it work?&lt;/em&gt;&lt;/strong&gt;
&lt;/h2&gt;

&lt;p&gt;When you use flutter bloc you are going to create events to trigger the interactions with the app and then the bloc in charge is going to emit the requested data with a state&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--6DncXvSf--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://miro.medium.com/max/720/0%2AEG9GW70kfdesSPRZ.webp" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--6DncXvSf--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://miro.medium.com/max/720/0%2AEG9GW70kfdesSPRZ.webp" alt="https://miro.medium.com/max/720/0*EG9GW70kfdesSPRZ.webp" width="720" height="180"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Core Concepts of Bloc
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Streams&lt;/strong&gt;&lt;/p&gt;


💡 **A stream is a sequence of asynchronous data.**



&lt;p&gt;In order to use the bloc library, it is critical to have a basic understanding of &lt;strong&gt;&lt;code&gt;Streams&lt;/code&gt;&lt;/strong&gt;and how they work.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;If you're unfamiliar with &lt;code&gt;Streams&lt;/code&gt; just think of a pipe with water flowing through it. The pipe is the &lt;code&gt;Stream&lt;/code&gt; and the water is the asynchronous data.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;We can create a  &lt;strong&gt;&lt;code&gt;Stream&lt;/code&gt;&lt;/strong&gt;  in Dart by writing an &lt;strong&gt;&lt;code&gt;async*&lt;/code&gt;&lt;/strong&gt; (async generator) function.&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;Stream&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;countStream&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;max&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="kd"&gt;async&lt;/span&gt;&lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;i&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt; &lt;span class="n"&gt;i&lt;/span&gt; &lt;span class="p"&gt;&amp;lt;&lt;/span&gt; &lt;span class="n"&gt;max&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt; &lt;span class="n"&gt;i&lt;/span&gt;&lt;span class="o"&gt;++&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
        &lt;span class="k"&gt;yield&lt;/span&gt; &lt;span class="n"&gt;i&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;By marking a function as &lt;strong&gt;&lt;code&gt;async*&lt;/code&gt;&lt;/strong&gt; we are able to use the &lt;strong&gt;&lt;code&gt;yield&lt;/code&gt;&lt;/strong&gt; keyword and return a &lt;strong&gt;&lt;code&gt;Stream&lt;/code&gt;&lt;/strong&gt; of data. In the above example, we are returning a  &lt;strong&gt;&lt;code&gt;Stream&lt;/code&gt;&lt;/strong&gt; of integers up to the &lt;strong&gt;&lt;code&gt;max&lt;/code&gt;&lt;/strong&gt; integer parameter.&lt;/p&gt;

&lt;p&gt;Every time we &lt;strong&gt;&lt;code&gt;yield&lt;/code&gt;&lt;/strong&gt; in an &lt;strong&gt;&lt;code&gt;async*&lt;/code&gt;&lt;/strong&gt; function we are pushing that piece of data through the &lt;strong&gt;&lt;code&gt;Stream&lt;/code&gt;&lt;/strong&gt; .&lt;/p&gt;

&lt;p&gt;We can consume the above &lt;strong&gt;&lt;code&gt;Stream&lt;/code&gt;&lt;/strong&gt; in several ways. If we wanted to write a function to return the sum of a &lt;strong&gt;&lt;code&gt;Stream&lt;/code&gt;&lt;/strong&gt; of integers it could look something like:&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;Future&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;sumStream&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;Stream&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;stream&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="kd"&gt;async&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;sum&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;value&lt;/span&gt; &lt;span class="k"&gt;in&lt;/span&gt; &lt;span class="n"&gt;stream&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
        &lt;span class="n"&gt;sum&lt;/span&gt; &lt;span class="o"&gt;+=&lt;/span&gt; &lt;span class="n"&gt;value&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="p"&gt;}&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;sum&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;By marking the above function as &lt;strong&gt;&lt;code&gt;async&lt;/code&gt;&lt;/strong&gt; we are able to use the &lt;strong&gt;&lt;code&gt;await&lt;/code&gt;&lt;/strong&gt; keyword and return a &lt;strong&gt;&lt;code&gt;Future&lt;/code&gt;&lt;/strong&gt; of integers. In this example, we are awaiting each value in the stream and returning the sum of all integers in the stream.&lt;/p&gt;

&lt;p&gt;We can put it all together like so:&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="nf"&gt;main&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="kd"&gt;async&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="c1"&gt;/// Initialize a stream of integers 0-9&lt;/span&gt;
    &lt;span class="n"&gt;Stream&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;stream&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;countStream&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;10&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
    &lt;span class="c1"&gt;/// Compute the sum of the stream of integers&lt;/span&gt;
    &lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;sum&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="n"&gt;sumStream&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;stream&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
    &lt;span class="c1"&gt;/// Print the sum&lt;/span&gt;
    &lt;span class="n"&gt;print&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;sum&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// 45&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;Now that we have a basic understanding of how &lt;strong&gt;&lt;code&gt;Streams&lt;/code&gt;&lt;/strong&gt; work in Dart we're ready to learn about the core component of the bloc package: a &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt; .&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Cubit&lt;/strong&gt;&lt;/p&gt;


💡 **A `Cubit` is a class which extends `BlocBase` and can be extended to manage any type of state.**



&lt;p&gt;A &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt; can expose functions which can be invoked to trigger state changes.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--O72mmPCW--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://bloclibrary.dev/assets/cubit_architecture_full.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--O72mmPCW--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://bloclibrary.dev/assets/cubit_architecture_full.png" alt="https://bloclibrary.dev/assets/cubit_architecture_full.png" width="800" height="201"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;States are the output of a &lt;code&gt;Cubit&lt;/code&gt; and represent a part of your application's state. UI components can be notified of states and redraw portions of themselves based on the current state.&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Create A Cubit:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;We can create a &lt;strong&gt;&lt;code&gt;CounterCubit&lt;/code&gt;&lt;/strong&gt; like:&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterCubit&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Cubit&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;When creating a &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt;, we need to define the type of state which the &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt; will be managing. In the case of the &lt;strong&gt;&lt;code&gt;CounterCubit&lt;/code&gt;&lt;/strong&gt; above, the state can be represented via an &lt;strong&gt;&lt;code&gt;int&lt;/code&gt;&lt;/strong&gt; but in more complex cases it might be necessary to use a &lt;strong&gt;&lt;code&gt;class&lt;/code&gt;&lt;/strong&gt;instead of a primitive type.&lt;/p&gt;

&lt;p&gt;The second thing we need to do when creating a &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt; is specify the initial state. We can do this by calling &lt;strong&gt;&lt;code&gt;super&lt;/code&gt;&lt;/strong&gt; with the value of the initial state. In the snippet above, we are setting the initial state to &lt;strong&gt;&lt;code&gt;0&lt;/code&gt;&lt;/strong&gt; internally but we can also allow the &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt; to be more flexible by accepting an external value:&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterCubit&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Cubit&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;initialState&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;initialState&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;This would allow us to instantiate &lt;strong&gt;&lt;code&gt;CounterCubit&lt;/code&gt;&lt;/strong&gt;instances with different initial states like:&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kd"&gt;final&lt;/span&gt; &lt;span class="n"&gt;cubitA&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// state starts at 0&lt;/span&gt;
&lt;span class="kd"&gt;final&lt;/span&gt; &lt;span class="n"&gt;cubitB&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;10&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// state starts at 10&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;State Changes:&lt;/strong&gt;&lt;/p&gt;


💡 **Each `Cubit` has the ability to output a new state via `emit`.**




&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterCubit&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Cubit&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;increment&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;state&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;In the above snippet, the &lt;strong&gt;&lt;code&gt;CounterCubit&lt;/code&gt;&lt;/strong&gt; is exposing a public method called &lt;strong&gt;&lt;code&gt;increment&lt;/code&gt;&lt;/strong&gt;&lt;br&gt;
which can be called externally to notify the &lt;strong&gt;&lt;code&gt;CounterCubit&lt;/code&gt;&lt;/strong&gt; to increment its state. When &lt;strong&gt;&lt;code&gt;increment&lt;/code&gt;&lt;/strong&gt; is called, we can access the current state of the &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt; via the &lt;strong&gt;&lt;code&gt;state&lt;/code&gt;&lt;/strong&gt;&lt;br&gt;
getter and &lt;strong&gt;&lt;code&gt;emit&lt;/code&gt;&lt;/strong&gt; a new state by adding 1 to the current state.&lt;/p&gt;

&lt;p&gt;Note:&lt;/p&gt;

&lt;p&gt;The &lt;strong&gt;&lt;code&gt;emit&lt;/code&gt;&lt;/strong&gt; method is protected, meaning it should only be used inside of a &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt;.&lt;/p&gt;
&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;
&lt;li&gt;

&lt;p&gt;&lt;strong&gt;Bloc&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;💡 &lt;strong&gt;A &lt;code&gt;Bloc&lt;/code&gt; is a more advanced class which relies on &lt;code&gt;events&lt;/code&gt; to trigger &lt;code&gt;state&lt;/code&gt; changes rather than functions. &lt;code&gt;Bloc&lt;/code&gt; also extends &lt;code&gt;BlocBase&lt;/code&gt; which means it has a similar public API as &lt;code&gt;Cubit&lt;/code&gt;. However, rather than calling a &lt;code&gt;function&lt;/code&gt; on a &lt;code&gt;Bloc&lt;/code&gt; and directly emitting a new &lt;code&gt;state&lt;/code&gt;, &lt;code&gt;Blocs&lt;/code&gt; receive &lt;code&gt;events&lt;/code&gt; and convert the incoming &lt;code&gt;events&lt;/code&gt; into outgoing &lt;code&gt;states&lt;/code&gt;.&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;Create A Bloc:&lt;/p&gt;

&lt;p&gt;Creating a &lt;strong&gt;&lt;code&gt;Bloc&lt;/code&gt;&lt;/strong&gt; is similar to creating a &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt; except in addition to defining the state that we'll be managing, we must also define the event that the &lt;strong&gt;&lt;code&gt;Bloc&lt;/code&gt;&lt;/strong&gt; will be able to process.&lt;/p&gt;


💡 **Events are the input to a Bloc. They are commonly added in response to user interactions such as button presses or lifecycle events like page loads.**




&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kd"&gt;abstract&lt;/span&gt; &lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterEvent&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterIncrementPressed&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;CounterEvent&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterBloc&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Bloc&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterEvent&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterBloc&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;Just like when creating the &lt;strong&gt;&lt;code&gt;CounterCubit&lt;/code&gt;&lt;/strong&gt;, we must specify an initial state by passing it to the superclass via &lt;strong&gt;&lt;code&gt;super&lt;/code&gt;&lt;/strong&gt;.&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;State Changes:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;Bloc&lt;/code&gt;&lt;/strong&gt; requires us to register event handlers via the &lt;strong&gt;&lt;code&gt;on&amp;lt;Event&amp;gt;&lt;/code&gt;&lt;/strong&gt; API, as opposed to functions in &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt;. &lt;/p&gt;

&lt;p&gt;An event handler is responsible for converting any incoming events into zero or more outgoing states.&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kd"&gt;abstract&lt;/span&gt; &lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterEvent&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterIncrementPressed&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;CounterEvent&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterBloc&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Bloc&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterEvent&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterBloc&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="kd"&gt;on&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterIncrementPressed&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;((&lt;/span&gt;&lt;span class="n"&gt;event&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="c1"&gt;// handle incoming `CounterIncrementPressed` event&lt;/span&gt;
    &lt;span class="p"&gt;})&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;



💡 **Tip**: an **`EventHandler`** has access to the added event as well as an **`Emitter`** which can be used to emit zero or more states in response to the incoming event.



&lt;p&gt;We can then update the &lt;strong&gt;&lt;code&gt;EventHandler&lt;/code&gt;&lt;/strong&gt; to handle the &lt;strong&gt;&lt;code&gt;CounterIncrementPressed&lt;/code&gt;&lt;/strong&gt; event:&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kd"&gt;abstract&lt;/span&gt; &lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterEvent&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterIncrementPressed&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;CounterEvent&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterBloc&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Bloc&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterEvent&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterBloc&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="kd"&gt;on&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterIncrementPressed&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;((&lt;/span&gt;&lt;span class="n"&gt;event&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;state&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
    &lt;span class="p"&gt;});&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;In the above snippet, we have registered an &lt;strong&gt;&lt;code&gt;EventHandler&lt;/code&gt;&lt;/strong&gt; to manage all  &lt;strong&gt;&lt;code&gt;CounterIncrementPressed&lt;/code&gt;&lt;/strong&gt; events. For each incoming &lt;strong&gt;&lt;code&gt;CounterIncrementPressed&lt;/code&gt;&lt;/strong&gt; event we can access the current state of the bloc via the &lt;strong&gt;&lt;code&gt;state&lt;/code&gt;&lt;/strong&gt; getter and &lt;strong&gt;&lt;code&gt;emit(state + 1)&lt;/code&gt;&lt;/strong&gt;.&lt;/p&gt;
&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Bloc vs Cubit
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--Gu6iXdxT--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-01_at_7.39.54_PM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--Gu6iXdxT--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-01_at_7.39.54_PM.png" alt="Screen Shot 2023-02-01 at 7.39.54 PM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;Cubit&lt;/p&gt;

&lt;p&gt;Cubit is a subset of the BLoC Pattern package that does not rely on events and instead uses methods to emit new states.&lt;/p&gt;

&lt;p&gt;So, we can use Cubit for simple states, and as needed we can use the Bloc.&lt;/p&gt;

&lt;p&gt;There are many advantages of choosing Cubit over Bloc. The two main benefits are:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Cubit&lt;/strong&gt; is a subset of &lt;strong&gt;Bloc&lt;/strong&gt;; so, it reduces complexity. Cubit eliminates the event classes. Cubit uses emit rather than yield to emit state. Since emit works synchronously, you can ensure that the state is updated in the next line.&lt;/p&gt;

&lt;p&gt;note:&lt;/p&gt;

&lt;p&gt;• We don’t have streams, so no transformations.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--_767yOjn--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-01_at_7.48.48_PM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--_767yOjn--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-01_at_7.48.48_PM.png" alt="Screen Shot 2023-02-01 at 7.48.48 PM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;Bloc&lt;/p&gt;

&lt;p&gt;When we use BLoC, there’s two important things: “Events” and “States”. That means that when we send an “Event” we can receive one or more “States”, and these “States” are sent in a &lt;strong&gt;stream&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;We have two streams here: Events and States; and that means that all things that we can apply to a Stream we can do it here. Transformations.&lt;/li&gt;
&lt;li&gt;We can do long duration operations here, things like: API calls, database, compressions or some other complex things.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;notes:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;If you send a lot of events for one BLoC could be difficult to track if you are not tracking them correctly.&lt;/li&gt;
&lt;li&gt;Sometimes we want to receive this “state” synchronously, but with BLoC this is not possible.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--Eia6o5-c--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-01_at_7.54.25_PM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--Eia6o5-c--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-01_at_7.54.25_PM.png" alt="Screen Shot 2023-02-01 at 7.54.25 PM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;


&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; &lt;br&gt;
BLoC uses mapToState and gives you a stream (async*). Cubit uses normal functions and gives you the result immediately or a Future (with async).&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--L914-eGl--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-01_at_7.52.41_PM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--L914-eGl--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-01_at_7.52.41_PM.png" alt="Screen Shot 2023-02-01 at 7.52.41 PM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;
&lt;h2&gt;
  
  
  Flutter Bloc Concepts
&lt;/h2&gt;
&lt;h3&gt;
  
  
  &lt;strong&gt;BlocProvider&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--JWDHomxL--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_12.37.37_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--JWDHomxL--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_12.37.37_AM.png" alt="Screen Shot 2023-02-02 at 12.37.37 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;


💡 Is a flutter widget which creates and provides a Bloc to all of its children.



&lt;ul&gt;
&lt;li&gt;Is also known as as dependency injection.&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;code&gt;BlocProvider&lt;/code&gt; will provide a single instance of a Bloc to the subtree below it.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s---18Aag5W--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_12.43.04_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s---18Aag5W--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_12.43.04_AM.png" alt="Screen Shot 2023-02-02 at 12.43.04 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;br&gt;
&lt;/p&gt;


&lt;/li&gt;
&lt;/ul&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="c1"&gt;// you must add flutter_bloc package dependency in pubspec.yaml&lt;/span&gt;
&lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;yourWidget&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="c1"&gt;// The context in which a specific widget is built&lt;/span&gt;

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;we access it in a subtree like:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;of&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="c1"&gt;// OR&lt;/span&gt;

&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;read&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;();&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;By default, &lt;code&gt;BlocProvider&lt;/code&gt; create the Bloc lazily&lt;/p&gt;

&lt;p&gt;meaning that the create function will get executed when the Bloc is looked up for via &lt;code&gt;BlocProvider&lt;/code&gt;  of Bloc a context &lt;/p&gt;

&lt;p&gt;note:&lt;/p&gt;

&lt;p&gt;To override this behavior and force the &lt;code&gt;BlocProvider&lt;/code&gt; create function to be run immediately as soon as possible laze can be set to false inside the widget’s parameters like:&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="nl"&gt;laze:&lt;/span&gt; &lt;span class="kc"&gt;false&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;yourWidget&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
&lt;span class="p"&gt;);&lt;/span&gt; 
&lt;/code&gt;&lt;/pre&gt;

&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;code&gt;BlocProvider&lt;/code&gt; handles the closing part of Bloc automatically so that where won’t be any stream leaks all over the place&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Question&lt;/p&gt;

&lt;p&gt;When we push a new screen into the navigation routing feature of flutter is the &lt;code&gt;BlocA&lt;/code&gt; going to be available there too?&lt;/p&gt;

&lt;p&gt;No, because there is another context  created on the new rout, a context which the &lt;code&gt;BlocProvider&lt;/code&gt; doesn’t know yet.&lt;/p&gt;

&lt;p&gt;so in order to pass the only instance of the Bloc to the new rout, we will use &lt;code&gt;BlocProvider.value()&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--q7rLRgIR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_1.07.29_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--q7rLRgIR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_1.07.29_AM.png" alt="Screen Shot 2023-02-02 at 1.07.29 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;value&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;value:&lt;/span&gt; &lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;of&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;newChild&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Example:&lt;/p&gt;

&lt;p&gt;build counter app with bloc&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="c1"&gt;// in this app we use Cubit&lt;/span&gt;
&lt;span class="c1"&gt;// 1- create app states -&amp;gt; counter_states.dart&lt;/span&gt;
&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;
&lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
&lt;span class="kd"&gt;required&lt;/span&gt; &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// 2- create cubit -&amp;gt; counter_cubit.dart&lt;/span&gt;
&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterCubit&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Cubit&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nl"&gt;counterValue:&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;));&lt;/span&gt;

  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;increment&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nl"&gt;counterValue:&lt;/span&gt;&lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;));&lt;/span&gt;

  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;decrement&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nl"&gt;counterValue:&lt;/span&gt;&lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;));&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// Ui &lt;/span&gt;
&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterApp&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;StatelessWidget&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="n"&gt;CounterApp&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;&lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;key&lt;/span&gt;&lt;span class="p"&gt;});&lt;/span&gt;

  &lt;span class="nd"&gt;@override&lt;/span&gt;
  &lt;span class="n"&gt;Widget&lt;/span&gt; &lt;span class="n"&gt;build&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;_&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt; &lt;span class="c1"&gt;// -&amp;gt; create counter cubit&lt;/span&gt;
      &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;MaterialApp&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
                &lt;span class="nl"&gt;body:&lt;/span&gt;&lt;span class="n"&gt;counterScreen&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
            &lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="p"&gt;);&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;//in counter screen you access increment and decrement methods in buttons like:&lt;/span&gt;

&lt;span class="n"&gt;FloatingActionButton&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="n"&gt;Icon&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;Icons&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;add&lt;/span&gt;&lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="nl"&gt;onPressed:&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;read&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;()&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;increment&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;&lt;span class="c1"&gt;//access increment&lt;/span&gt;
  &lt;span class="p"&gt;),&lt;/span&gt;

&lt;span class="n"&gt;FloatingActionButton&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="n"&gt;Icon&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;Icons&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;remove&lt;/span&gt;&lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="nl"&gt;onPressed:&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;read&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;()&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;decrement&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;&lt;span class="c1"&gt;//access decrement&lt;/span&gt;
  &lt;span class="p"&gt;),&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;The Question now is How do we receive the new state inside the UI ?, How do we rebuild specific text widget which prints out the counter value ?&lt;/p&gt;

&lt;p&gt;It is now time to introduce the second important Flutter Bloc concept which is &lt;code&gt;BlobBuilder&lt;/code&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  &lt;strong&gt;BlocBuilder&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;💡 A widget that helps Re-Building the UI based on Bloc state changes&lt;/p&gt;

&lt;p&gt;Re-Building a large chunk of the UI required a lot of time to compute, good practice would be to wrap the exact part of the UI you want to rebuild inside &lt;code&gt;BlocBuilder&lt;/code&gt; &lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--dixhOnJt--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_3.29.29_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--dixhOnJt--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_3.29.29_AM.png" alt="Screen Shot 2023-02-02 at 3.29.29 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Ex:&lt;/p&gt;

&lt;p&gt;If you have a text widget which updates from a sequence of emitted states and that text is inside a tone of Columns, Rows and other widgets , it is a huge mistake to rebuild all of them just to update the text widget &lt;/p&gt;

&lt;p&gt;to rebuild only the text widget → wrap it inside &lt;code&gt;BlocBuilder&lt;/code&gt; &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;&lt;code&gt;BlocBuilder&lt;/code&gt; is a widget which requires a Bloc or Cubit and the builder function&lt;/p&gt;

&lt;p&gt;builder function → will potentially be called many time due to how flutter engine works behind the scenes and should be a pure function that returns a widget in response to a state.&lt;/p&gt;

&lt;p&gt;Pure Function → is a function return value depends only on the function’s arguments and no others.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--47d56pOw--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_3.40.14_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--47d56pOw--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_3.40.14_AM.png" alt="Screen Shot 2023-02-02 at 3.40.14 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;So in this case our builder function should return a widget which only depend on the context and state parameters .&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;BlocBuilder&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="n"&gt;BlocAStates&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;builder:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;){&lt;/span&gt;
        &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;widget&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;p&gt;If the Bloc or Cubit is not provided the &lt;code&gt;BlocBuilder&lt;/code&gt; will automatically perform lookup for its instance using &lt;code&gt;BlocProvider&lt;/code&gt; and the current build context.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;you can use &lt;code&gt;buildWhen&lt;/code&gt; parameter this should take in a function having the previous state and current state as parameters&lt;/p&gt;

&lt;p&gt;Ex:&lt;/p&gt;

&lt;p&gt;If text value in current state greater than the text value in previous state you can &lt;code&gt;return false&lt;/code&gt; so that the Builder function won’t trigger and won’t rebuild UI&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;BlocBuilder&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="n"&gt;BlocAStates&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;builder:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;){&lt;/span&gt;
        &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;widget&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
    &lt;span class="p"&gt;}&lt;/span&gt;
    &lt;span class="nl"&gt;buildWhen:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;previous&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;current&lt;/span&gt;&lt;span class="p"&gt;){}&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  BlocListener
&lt;/h3&gt;

&lt;p&gt;has mainly the same structure as &lt;code&gt;BlocBuilder&lt;/code&gt; but it is really deferent in many ways&lt;/p&gt;

&lt;p&gt;💡 Is a flutter widget which listens to any sate change as BlocBuilder does but instead of rebuilding a widget as BlocBuilder did with the builder function it takes a simple void function called listener which is called only once per state not including the initial state.&lt;/p&gt;

&lt;p&gt;There is also a &lt;code&gt;listenWhen&lt;/code&gt; parameter function you can pass to tell the &lt;code&gt;BlocListener&lt;/code&gt; when to call the listener function or not as build when parameter was for the &lt;code&gt;BlocBuilder&lt;/code&gt; widget.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;BlocListener&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="n"&gt;BlocAStates&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;listener:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;){&lt;/span&gt;
        &lt;span class="n"&gt;debugPrint&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;"do stuff have on BlocA's state"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
    &lt;span class="p"&gt;},&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;widget&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;🔄  In our Counter App:&lt;/p&gt;

&lt;p&gt;We need to Re-Build text widget and print increment when click add button and decrement when click remove button, Let’s do this&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="c1"&gt;// rebuild text widget &lt;/span&gt;
&lt;span class="n"&gt;BlocBuilder&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
       &lt;span class="nl"&gt;builder:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
           &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;Text&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
              &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;toString&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt; &lt;span class="c1"&gt;// initial value = 0&lt;/span&gt;
                  &lt;span class="nl"&gt;style:&lt;/span&gt; &lt;span class="n"&gt;Theme&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;of&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;textTheme&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;headlineLarge&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
      &lt;span class="p"&gt;);&lt;/span&gt;
   &lt;span class="p"&gt;},&lt;/span&gt;
&lt;span class="p"&gt;),&lt;/span&gt;

&lt;span class="c1"&gt;// to print in listener we need ro refactor CounterState and CounterCubit&lt;/span&gt;
&lt;span class="c1"&gt;// Let's do this&lt;/span&gt;
&lt;span class="c1"&gt;// refactor CounterState to add wasIncremented variable&lt;/span&gt;
&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterState&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="kt"&gt;bool&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt; &lt;span class="n"&gt;wasIncremented&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
    &lt;span class="kd"&gt;required&lt;/span&gt; &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;wasIncremented&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="p"&gt;});&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt; 

&lt;span class="c1"&gt;// refactor Cubit to change wasIncremented variable value on emit state &lt;/span&gt;
&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterCubit&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Cubit&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nl"&gt;counterValue:&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;));&lt;/span&gt;

  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;increment&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
        &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
          &lt;span class="nl"&gt;counterValue:&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
          &lt;span class="nl"&gt;wasIncremented:&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="c1"&gt;// when click add button  &lt;/span&gt;
        &lt;span class="p"&gt;),&lt;/span&gt;
      &lt;span class="p"&gt;);&lt;/span&gt;

  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;decrement&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
        &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
          &lt;span class="nl"&gt;counterValue:&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
          &lt;span class="nl"&gt;wasIncremented:&lt;/span&gt; &lt;span class="kc"&gt;false&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="c1"&gt;// when click remove button&lt;/span&gt;
        &lt;span class="p"&gt;),&lt;/span&gt;
      &lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// Now you can access this variable when listen to state change &lt;/span&gt;
    &lt;span class="n"&gt;Scaffold&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
        &lt;span class="nl"&gt;body:&lt;/span&gt; &lt;span class="n"&gt;BlocListener&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
        &lt;span class="nl"&gt;listener:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
          &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;wasIncremented&lt;/span&gt; &lt;span class="o"&gt;==&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
            &lt;span class="n"&gt;debugPrint&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'Incremented'&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
          &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;else&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
            &lt;span class="n"&gt;debugPrint&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'Decremented'&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
          &lt;span class="p"&gt;}&lt;/span&gt;
        &lt;span class="p"&gt;},&lt;/span&gt;
        &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;CounterDesign&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="c1"&gt;// Now We are done &lt;/span&gt;
&lt;span class="c1"&gt;// Now you have created your first Flutter App with Bloc&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Perhaps you are in our situation right now when you are updating UI using &lt;code&gt;BlocBuilder&lt;/code&gt; and also print something using &lt;code&gt;BlocListener&lt;/code&gt; isn’t there an easier way to do it of course there is, it is called &lt;code&gt;BlocConsumer&lt;/code&gt; &lt;/p&gt;

&lt;h3&gt;
  
  
  BlocConsumer
&lt;/h3&gt;

&lt;p&gt;💡 Is a widget which combines both &lt;code&gt;BlocListener&lt;/code&gt; and &lt;code&gt;BlocBuilder&lt;/code&gt; into a single widget&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--8NOebyUV--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_4.51.42_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--8NOebyUV--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-02_at_4.51.42_AM.png" alt="Screen Shot 2023-02-02 at 4.51.42 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  &lt;strong&gt;BlocSelector&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;💡 Is a Flutter widget which is analogous to &lt;strong&gt;&lt;code&gt;BlocBuilder&lt;/code&gt;&lt;/strong&gt; but allows developers to filter updates by selecting a new value based on the current bloc state. Unnecessary builds are prevented if the selected value does not change. The selected value must be immutable in order for &lt;strong&gt;&lt;code&gt;BlocSelector&lt;/code&gt;&lt;/strong&gt;to accurately determine whether &lt;strong&gt;&lt;code&gt;builder&lt;/code&gt;&lt;/strong&gt;should be called again.&lt;/p&gt;

&lt;p&gt;If the &lt;strong&gt;&lt;code&gt;bloc&lt;/code&gt;&lt;/strong&gt;parameter is omitted, &lt;strong&gt;&lt;code&gt;BlocSelector&lt;/code&gt;&lt;/strong&gt;will automatically perform a lookup using  &lt;strong&gt;&lt;code&gt;BlocProvider&lt;/code&gt;&lt;/strong&gt; and the current &lt;strong&gt;&lt;code&gt;BuildContext&lt;/code&gt; .&lt;/strong&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;BlocSelector&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;BlocAState&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;SelectedState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
  &lt;span class="nl"&gt;selector:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="c1"&gt;// return selected state based on the provided state.&lt;/span&gt;
  &lt;span class="p"&gt;},&lt;/span&gt;
  &lt;span class="nl"&gt;builder:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="c1"&gt;// return widget here based on the selected state.&lt;/span&gt;
  &lt;span class="p"&gt;},&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  &lt;strong&gt;MultiBlocProvider&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;💡 Is a Flutter widget that merges multiple &lt;strong&gt;&lt;code&gt;BlocProvider&lt;/code&gt;&lt;/strong&gt;widgets into one.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;MultiBlocProvider&lt;/code&gt;&lt;/strong&gt; improves the readability and eliminates the need to nest multiple  &lt;strong&gt;&lt;code&gt;BlocProviders&lt;/code&gt;&lt;/strong&gt;. &lt;/p&gt;

&lt;p&gt;Example without it:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
  &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
  &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocB&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;BlocB&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocC&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;BlocC&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
      &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;ChildA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;)&lt;/span&gt;
  &lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Example with it:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;MultiBlocProvider&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
  &lt;span class="nl"&gt;providers:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;
    &lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocB&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;BlocB&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="n"&gt;BlocProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocC&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BuildContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;BlocC&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
  &lt;span class="p"&gt;],&lt;/span&gt;
  &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;ChildA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  &lt;strong&gt;MultiBlocListener&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;💡 Is a Flutter widget that merges multiple &lt;strong&gt;&lt;code&gt;BlocListener&lt;/code&gt;&lt;/strong&gt; widgets into one&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;MultiBlocListener&lt;/code&gt;&lt;/strong&gt; improves the readability and eliminates the need to nest multiple  &lt;strong&gt;&lt;code&gt;BlocListeners&lt;/code&gt; .&lt;/strong&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="c1"&gt;// without it&lt;/span&gt;
&lt;span class="n"&gt;BlocListener&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;BlocAState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
  &lt;span class="nl"&gt;listener:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{},&lt;/span&gt;
  &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;BlocListener&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocB&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;BlocBState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;listener:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{},&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;BlocListener&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocC&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;BlocCState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;listener:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{},&lt;/span&gt;
      &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;ChildA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
  &lt;span class="p"&gt;),&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;→ with &lt;strong&gt;&lt;code&gt;MultiBlocListener&lt;/code&gt;&lt;/strong&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;MultiBlocListener&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
  &lt;span class="nl"&gt;listeners:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;
    &lt;span class="n"&gt;BlocListener&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocA&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;BlocAState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;listener:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{},&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="n"&gt;BlocListener&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocB&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;BlocBState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;listener:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{},&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="n"&gt;BlocListener&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;BlocC&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;BlocCState&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;listener:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;state&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{},&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
  &lt;span class="p"&gt;],&lt;/span&gt;
  &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;ChildA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  RepositoryProvider
&lt;/h3&gt;

&lt;p&gt;💡 Is a Flutter widget which provides a repository to its children via  &lt;strong&gt;&lt;code&gt;RepositoryProvider.of(context)&lt;/code&gt;&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;The same exact widget as a &lt;code&gt;BlocProvider&lt;/code&gt; the only difference being that it provides a single repository class instance instead of a single Bloc Instance.&lt;/p&gt;

&lt;p&gt;⇒ It is used as a dependency injection (DI) widget so that a single instance of a repository can be provided to multiple widgets within a subtree&lt;/p&gt;

&lt;p&gt;NOTE:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;BlocProvider&lt;/code&gt;&lt;/strong&gt; should be used to provide blocs whereas &lt;strong&gt;&lt;code&gt;RepositoryProvider&lt;/code&gt;&lt;/strong&gt; should only be used for repositories.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;RepositoryProvider&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
  &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;RepositoryA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
  &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;ChildA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;then from &lt;strong&gt;&lt;code&gt;ChildA&lt;/code&gt;&lt;/strong&gt; we can retrieve the &lt;strong&gt;&lt;code&gt;Repository&lt;/code&gt;&lt;/strong&gt; instance with:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="c1"&gt;// with extensions&lt;/span&gt;
&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;read&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;RepositoryA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;();&lt;/span&gt;

&lt;span class="c1"&gt;// without extensions&lt;/span&gt;
&lt;span class="n"&gt;RepositoryProvider&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;of&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;RepositoryA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  &lt;strong&gt;MultiRepositoryProvider&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;💡 is a Flutter widget that merges multiple &lt;strong&gt;&lt;code&gt;RepositoryProvider&lt;/code&gt;&lt;/strong&gt; widgets into one.&lt;/p&gt;

&lt;p&gt;⇒ &lt;strong&gt;&lt;code&gt;MultiRepositoryProvider&lt;/code&gt;&lt;/strong&gt; improves the readability and eliminates the need to nest multiple &lt;strong&gt;&lt;code&gt;RepositoryProvider&lt;/code&gt;&lt;/strong&gt; .&lt;/p&gt;

&lt;p&gt;By using &lt;strong&gt;&lt;code&gt;MultiRepositoryProvider&lt;/code&gt;&lt;/strong&gt; we can go from:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;RepositoryProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;RepositoryA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
  &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;RepositoryA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
  &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;RepositoryProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;RepositoryB&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
    &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;RepositoryB&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;RepositoryProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;RepositoryC&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;RepositoryC&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
      &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;ChildA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;)&lt;/span&gt;
  &lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;To:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;MultiRepositoryProvider&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
  &lt;span class="nl"&gt;providers:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;
    &lt;span class="n"&gt;RepositoryProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;RepositoryA&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;RepositoryA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="n"&gt;RepositoryProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;RepositoryB&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;RepositoryB&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
    &lt;span class="n"&gt;RepositoryProvider&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;RepositoryC&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;
      &lt;span class="nl"&gt;create:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;RepositoryC&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="p"&gt;),&lt;/span&gt;
  &lt;span class="p"&gt;],&lt;/span&gt;
  &lt;span class="nl"&gt;child:&lt;/span&gt; &lt;span class="n"&gt;ChildA&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  &lt;strong&gt;BlocObserver&lt;/strong&gt;
&lt;/h3&gt;

&lt;p&gt;One added bonus of using the bloc library is that we can have access to all &lt;strong&gt;&lt;code&gt;Changes&lt;/code&gt;&lt;/strong&gt; in one place. Even though in this application we only have one &lt;strong&gt;&lt;code&gt;Cubit&lt;/code&gt;&lt;/strong&gt;, it's fairly common in larger applications to have many &lt;strong&gt;&lt;code&gt;Cubits&lt;/code&gt;&lt;/strong&gt; managing different parts of the application's state.&lt;/p&gt;

&lt;p&gt;If we want to be able to do something in response to all &lt;strong&gt;&lt;code&gt;Changes&lt;/code&gt;&lt;/strong&gt; we can simply create our own &lt;strong&gt;&lt;code&gt;BlocObserver&lt;/code&gt;&lt;/strong&gt;.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;SimpleBlocObserver&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;BlocObserver&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nd"&gt;@override&lt;/span&gt;
  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;onChange&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;BlocBase&lt;/span&gt; &lt;span class="n"&gt;bloc&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;Change&lt;/span&gt; &lt;span class="n"&gt;change&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;onChange&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;bloc&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;change&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
    &lt;span class="n"&gt;print&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'&lt;/span&gt;&lt;span class="si"&gt;${bloc.runtimeType}&lt;/span&gt;&lt;span class="s"&gt; &lt;/span&gt;&lt;span class="si"&gt;$change&lt;/span&gt;&lt;span class="s"&gt;'&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;In order to use the &lt;strong&gt;&lt;code&gt;SimpleBlocObserver&lt;/code&gt;&lt;/strong&gt;, we just need to tweak the &lt;strong&gt;&lt;code&gt;main&lt;/code&gt;&lt;/strong&gt; function:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="nf"&gt;main&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;Bloc&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;observer&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;SimpleBlocObserver&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;
  &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;
    &lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;increment&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;
    &lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;close&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;  
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;The above snippet would then output:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;Change &lt;span class="o"&gt;{&lt;/span&gt; currentState: 0, nextState: 1 &lt;span class="o"&gt;}&lt;/span&gt;
CounterCubit Change &lt;span class="o"&gt;{&lt;/span&gt; currentState: 0, nextState: 1 &lt;span class="o"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;You can observe a Cubit or Bloc Like:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="c1"&gt;// ObserveACubit&lt;/span&gt;
&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterCubit&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Cubit&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;increment&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;state&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

  &lt;span class="nd"&gt;@override&lt;/span&gt;
  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;onChange&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;Change&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;change&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;onChange&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;change&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
    &lt;span class="n"&gt;print&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;change&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// ObserveABloc&lt;/span&gt;
&lt;span class="kd"&gt;abstract&lt;/span&gt; &lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterEvent&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterIncrementPressed&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;CounterEvent&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterBloc&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Bloc&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterEvent&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;CounterBloc&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;:&lt;/span&gt; &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="kd"&gt;on&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;CounterIncrementPressed&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;((&lt;/span&gt;&lt;span class="n"&gt;event&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;emit&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;state&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;));&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;

  &lt;span class="nd"&gt;@override&lt;/span&gt;
  &lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="n"&gt;onChange&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;Change&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;int&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;change&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;super&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;onChange&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;change&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
    &lt;span class="n"&gt;print&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;change&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Bloc Architecture
&lt;/h2&gt;

&lt;p&gt;First we ask the questions that are on your mind &lt;/p&gt;

&lt;p&gt;What is an Architecture?&lt;/p&gt;

&lt;p&gt;What is all about?&lt;/p&gt;

&lt;p&gt;Why we need an ArchItecture?&lt;/p&gt;

&lt;p&gt;Let’s start &lt;/p&gt;

&lt;p&gt;We as human species can’t live without a predefined and stable architecture which is mainly our skeleton, imagine having all kinds of different classes, methods, functions, variables all over the place, this is definitely going to result in a total failure.&lt;/p&gt;

&lt;p&gt;Now assimilate this to us humans, How would our life be if we only had our organs every one had to choose where to place their heart, their lungs, their kidneys as probably none of these people would have survived in this situation without organized structure and stable skeleton neither would have any of the apps built without a proper architecture, it’s as simple as that.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--S9oQYpbR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_12.57.33_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--S9oQYpbR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_12.57.33_AM.png" alt="Screen Shot 2023-02-03 at 12.57.33 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;so think of architecture as being the skeleton, the blueprint, the structure which keep all your code organized stable and easy to test and maintain.&lt;/p&gt;

&lt;p&gt;Now Bloc Architecture is simply an architecture which has Bloc as it center of gravity.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--wWfz2g_0--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.01.47_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--wWfz2g_0--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.01.47_AM.png" alt="Screen Shot 2023-02-03 at 1.01.47 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;So not only is &lt;code&gt;Bloc&lt;/code&gt; a &lt;code&gt;Design Pattern&lt;/code&gt; and &lt;code&gt;State Management library&lt;/code&gt; but it also an &lt;code&gt;Architecture Pattern&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--ryNyQ8yx--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.03.40_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--ryNyQ8yx--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.03.40_AM.png" alt="Screen Shot 2023-02-03 at 1.03.40 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;What we know for now is that for every interaction an user makes with the app through each UI there should be an event dispatched to the specialized Bloc or Cubit which will process it and will eventually emit a state that is going to rebuild the UI in a way so that the user gets a feedback of what’s going on with the app, The big unknown variable in all this equation is how Bloc processes the event and perhaps retrieves the necessary data to show to the user, Let me put it this for you almost every app now a days retrieves its data from the internet, so in order to link our Bloc based flutter app with the outer data layer, we need to add the data layer into our equation so that for example:&lt;/p&gt;

&lt;p&gt;when Bloc receives a fetching event from UI it will request some data from internet, retrieve it as a response, parse it and return the data with a new state to the user.&lt;/p&gt;

&lt;p&gt;Let’s talk about layers &lt;/p&gt;

&lt;p&gt;We can split this into three separated main layers which not surprisingly will depend one on another, so the UI is mostly seen as a &lt;code&gt;Presentation Layer&lt;/code&gt; , The Bloc/Cubit as &lt;code&gt;Business Logic Layer&lt;/code&gt;  and the last but not the least the app’s data as simply the &lt;code&gt;Data Layer&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--vATkjCtE--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.23.46_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--vATkjCtE--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.23.46_AM.png" alt="Screen Shot 2023-02-03 at 1.23.46 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;We’re going to start with &lt;code&gt;Data Layer&lt;/code&gt; which is farthest from the user interface and work our way up to the &lt;code&gt;Presentation Layer&lt;/code&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Data Layer
&lt;/h3&gt;

&lt;p&gt;💡 has Responsibility of retrieving  and also manipulating data from one or more sources whether we’re talking about network, Database, Request or other asynchronous sources.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--ROa6eVKP--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.28.37_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--ROa6eVKP--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.28.37_AM.png" alt="Screen Shot 2023-02-03 at 1.28.37 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;The Date Layer has been split up inside three important sub-layers :&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Models&lt;/li&gt;
&lt;li&gt;Data Provider&lt;/li&gt;
&lt;li&gt;Repositories&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;They will also be dependent on one another.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--SmibanuK--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.30.44_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--SmibanuK--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.30.44_AM.png" alt="Screen Shot 2023-02-03 at 1.30.44 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Suppose you want to build your own first app and you don’t know where to actually start programming the app, what is actually the first thing  you should code ?&lt;/p&gt;

&lt;p&gt;The best way to start your app of course after you visually and technically designed it is by coding your models, but what exactly is a model?&lt;/p&gt;

&lt;p&gt;⇒ Let’s start with model &lt;/p&gt;

&lt;h3&gt;
  
  
  Model
&lt;/h3&gt;

&lt;p&gt;A model is as its name is implying a blueprint to the data your application will work with.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--tcTpD1bR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.36.58_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--tcTpD1bR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.36.58_AM.png" alt="Screen Shot 2023-02-03 at 1.36.58 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;is a nothing more than a class which contains the data the application itself will be dependent on.&lt;/p&gt;

&lt;p&gt;Example → weather API&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--ec75Txpa--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.41.24_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--ec75Txpa--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.41.24_AM.png" alt="Screen Shot 2023-02-03 at 1.41.24 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;they shouldn’t be identical to the data provider, Why?&lt;/p&gt;

&lt;p&gt;think of what is going to happen if you have weather apis in your app as a source to your weather data their apis will set completely different jsons to your app perhaps on of them has the temperature inside a temp name field and the other one a temperature name field then you will need to parse them separately to your universal models, remember that inside many apps might be multiple data sources but it’s recommended to have only &lt;code&gt;one special data model&lt;/code&gt;in which they will parsed.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--hnvnF7QZ--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.44.02_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--hnvnF7QZ--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.44.02_AM.png" alt="Screen Shot 2023-02-03 at 1.44.02 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;This means that models should be independent enough to get weather data from many different weather APIs.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--t9abWdWw--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.52.31_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--t9abWdWw--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_1.52.31_AM.png" alt="Screen Shot 2023-02-03 at 1.52.31 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;So now after you hopefully understood what a model is, it is time to move over to next sub-layer the &lt;code&gt;Data Provider&lt;/code&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Data Provider
&lt;/h3&gt;

&lt;p&gt;💡 Data Provider’s responsibility is to provide raw data to its successor the repository sub-layer&lt;/p&gt;

&lt;p&gt;⏰  Let’s concentrate on the Data Provider for a moment..&lt;/p&gt;

&lt;p&gt;A Data Provider is actually an API for you own app this means that it is going to be a class which contain different methods and these methods will serve as a direct communication way with the data sources&lt;/p&gt;

&lt;p&gt;this where all the magic happens, this is where flutter asks for the required data straight from the internet, all your network requests like &lt;code&gt;http.get&lt;/code&gt; , &lt;code&gt;[http.post](http://http.post)&lt;/code&gt; , &lt;code&gt;put&lt;/code&gt; , &lt;code&gt;delete&lt;/code&gt; will go inside take in mind that the return type of these methods won’t to be the type of model you created earlier but rather of the type of row data you received from the data source which for example may be a type of json string&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--6e6Uvl9_--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.10.48_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--6e6Uvl9_--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.10.48_AM.png" alt="Screen Shot 2023-02-03 at 2.10.48 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;the component in which we’ll have our model class is instantiated as objects is repository  &lt;/p&gt;

&lt;h3&gt;
  
  
  Repository
&lt;/h3&gt;

&lt;p&gt;💡 Is mainly a wrapper around one ore more Data Providers, it’s safe to say that it’s the part of data layer&lt;/p&gt;

&lt;p&gt;Bloc communicates with similar to the other data layer sub parts &lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;Repositories are also classes which contain dependencies of their respective data providers so for example:&lt;/p&gt;

&lt;p&gt;the weather repository will have a dependency on the weather provider with help of which we’ll call the &lt;code&gt;getRawWeather&lt;/code&gt; method and retrieve the weather &lt;code&gt;RowData&lt;/code&gt; .&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--jysyH5TD--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.26.08_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--jysyH5TD--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.26.08_AM.png" alt="Screen Shot 2023-02-03 at 2.26.08 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Repository is where the model object will be instantiated with the &lt;code&gt;RowData&lt;/code&gt; from the &lt;code&gt;DataProvider&lt;/code&gt; or raw data which will be model data with &lt;code&gt;fromJson&lt;/code&gt; methods.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;The Repository is also a perfect place for &lt;code&gt;Fine-Tuning&lt;/code&gt; the data before giving it as a response to the Bloc, here you can filter it, sort it and do all kinds of last of last moment changes before it will be sent to the &lt;code&gt;Business Logic Layer&lt;/code&gt; .&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Business Logic Layer
&lt;/h3&gt;

&lt;p&gt;💡 Is where Bloc and Cubit will be created inside your flutter app, its main responsibility is to respond to user input from the Presentation layer with new emitted state.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;This layer is meant to be the mediator between the beautiful bright and colorful side of the UI and the dark dangerous and unstable side of the Data Layer&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--DtHsePQm--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.31.30_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--DtHsePQm--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.31.30_AM.png" alt="Screen Shot 2023-02-03 at 2.31.30 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;&lt;p&gt;The Business Logic Layer is the last layer that can intercept and catch any errors from with in the Data Layer and protect the application from crashing.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Now since this layer is closely related to the data layer especially the repository sub-layer it can depend on one or more repositories to retrieve the data needed to build up the app state.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--HNnXmBKK--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.38.32_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--HNnXmBKK--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.38.32_AM.png" alt="Screen Shot 2023-02-03 at 2.38.32 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;🟢  Important fact:&lt;/p&gt;

&lt;p&gt;You need to know and understand is that Bloc can communicate one with each other, Cubit can do this too, this is really important&lt;/p&gt;

&lt;p&gt;So let’s say we have our previous weather Bloc and we also have an InternetBloc which emits states based on weather there is a stable internet connection or not&lt;/p&gt;

&lt;p&gt;Supposedly your internet connection dies when you want to know the weather from your location inside the WeatherBloc, you can depend on the InternetBloc and subscribe to its stream of emitted states then react on every internet state emitted by the InternetBloc&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--mKDY5pmG--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.51.11_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--mKDY5pmG--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_2.51.11_AM.png" alt="Screen Shot 2023-02-03 at 2.51.11 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;So in this case the InternetBloc would have emitted a no internet state down the stream the weather Bloc will listen to the stream and will eventually receive the no internet state, the WeatherBloc can also emit a state in response to this internet state letting the user know that there  is no internet connection.&lt;/p&gt;

&lt;p&gt;🚫  Don’t Forget :]&lt;/p&gt;

&lt;p&gt;⇒ The subscription to the Bloc needs to be closed manually by overriding the close method, We don’t any stream leaks inside our app&lt;/p&gt;

&lt;p&gt;🎉  We have arrived at our final layer of the Bloc Architecture the &lt;code&gt;Presentation Layer&lt;/code&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Presentation Layer
&lt;/h3&gt;

&lt;p&gt;This layer sums up every thing related to the user inter face like &lt;code&gt;Widgets&lt;/code&gt;, &lt;code&gt;User Input&lt;/code&gt;, &lt;code&gt;Lifecycle events&lt;/code&gt;, &lt;code&gt;animations&lt;/code&gt; and so on  and so froth, also its responsibility in our case is to figure out how to render itself based on one or more Bloc State.&lt;/p&gt;

&lt;p&gt;⇒ Most application flows will start with perhaps an app start event which triggers the app to fetch some data from the Data Layer &lt;/p&gt;

&lt;p&gt;For Example:&lt;/p&gt;

&lt;p&gt;When the first screen of the app will be created inside this constructor there will be a WeatherBloc which adds the app started event so that some location based weather will be displayed on the screen.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--8FSV3fCZ--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_3.31.36_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--8FSV3fCZ--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_3.31.36_AM.png" alt="Screen Shot 2023-02-03 at 3.31.36 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Great, Now we are finished all app layers 🎉&lt;/p&gt;

&lt;p&gt;→ final structure of weather app&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--9OH4JXgt--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_3.41.05_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--9OH4JXgt--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-03_at_3.41.05_AM.png" alt="Screen Shot 2023-02-03 at 3.41.05 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Let’s talk about anther important topic in Bloc, which is &lt;code&gt;BlocTesting&lt;/code&gt; &lt;/p&gt;

&lt;h2&gt;
  
  
  Bloc Testing
&lt;/h2&gt;

&lt;p&gt;💡 &lt;strong&gt;Bloc was designed to be extremely easy to test.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Why do developers hate testing so much?&lt;/p&gt;

&lt;p&gt;The answer is so simple, We hate testing because the application works fine without it, it seems like a reasonable answer right and indeed it is an application can work without testing but doesn’t mean we should disconsider it so badly.&lt;/p&gt;

&lt;p&gt;Testing is in so many cases a life saver, it’s the hero nobody talks about on the news&lt;/p&gt;

&lt;p&gt;so if you hate testing much, think of it as acute little dog which will be loyal to you and your app all the time, think of it as a layer which will bark whenever something breaks inside your app&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--NZ2RJ0xc--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.01.19_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--NZ2RJ0xc--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.01.19_AM.png" alt="Screen Shot 2023-02-05 at 3.01.19 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Now let me ask you something, have you ever worked on a big project in which wanted to add anew feature and you realize that after 2 or even 3 days of work despite the fact that the feature works perfectly fine it breaks other features in a completely different place inside your app or maybe have you thought if you ever want to delete a piece of code from within your app will this action be destructive or non-destructive to the app itself, How would you check if every thing is ok ?&lt;/p&gt;

&lt;p&gt;after wards most of you will say that they will run the app and check every feature to see if every thing works well but i’m sure that some of you won’t even physically test it and live with the idea that nothing will break a conclusion which is fundamentally wrong.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--H4aN_Nvt--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.02.58_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--H4aN_Nvt--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.02.58_AM.png" alt="Screen Shot 2023-02-05 at 3.02.58 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;⇒ Keep that in mind.&lt;/p&gt;

&lt;p&gt;So what if i tell you that there is something which will run a full checkup of every feature you wrote inside your app so that whenever you refactor your code&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--bEn4Njun--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.11.07_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--bEn4Njun--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.11.07_AM.png" alt="Screen Shot 2023-02-05 at 3.11.07 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;you’ll be stress-free without having to worry about if it’s gonna crash or not, you have already guessed that, i’m talking about our body testing.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--lnmClKts--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.13.09_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--lnmClKts--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.13.09_AM.png" alt="Screen Shot 2023-02-05 at 3.13.09 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Now the difference between Pros &amp;amp; Cons → becomes a problem of&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--E46UUCyj--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.18.18_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--E46UUCyj--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.18.18_AM.png" alt="Screen Shot 2023-02-05 at 3.18.18 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;But is it worth it, I’ll let answer this question in the following minutes after we understand the structure and practice testing on our beloved Counter App&lt;/p&gt;

&lt;p&gt;How could we implement a test for a feature?&lt;/p&gt;

&lt;p&gt;Think of it logically, how would you test if something is working or not?&lt;/p&gt;

&lt;p&gt;in big words a test is defined by how you will programmatically tell flutter to double check if the output given by a feature is equal to the expected response you planned on receiving an no other&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--7f4ndi7y--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.27.58_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--7f4ndi7y--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_3.27.58_AM.png" alt="Screen Shot 2023-02-05 at 3.27.58 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Now let’s switch to the coding part where i’ll show how testing works and after wards how to write tests inside your app.&lt;/p&gt;

&lt;p&gt;👉  Let’s do it&lt;/p&gt;

&lt;p&gt;Now you need to clone this repo → &lt;a href="https://github.com/HanySameh/FlutterBloc/tree/master/counter_app"&gt;CounterApp&lt;/a&gt; and add &lt;code&gt;bloc_test&lt;/code&gt; &amp;amp; &lt;code&gt;test&lt;/code&gt; dependency&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="na"&gt;dependencies&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;bloc_test&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;^9.1.0&lt;/span&gt;
  &lt;span class="na"&gt;test&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;^1.22.0&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;in test folder we’ll have our test files, a little hint i can give you is that every feature of your app need to be tested in the first place inside the test folder should be kind of symmetrical to the features from within tour app, so all you have  to crate the folder symmetrically to the lib folder inside the test folder and add &lt;code&gt;_test&lt;/code&gt; to the name of the file.&lt;/p&gt;

&lt;p&gt;In this case we’ll have a &lt;code&gt;counter_cubit_test.dart&lt;/code&gt; in which we’ll test out the functionality of our counter feature.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--llxcd8dU--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-06_at_5.09.41_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--llxcd8dU--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-06_at_5.09.41_AM.png" alt="Screen Shot 2023-02-06 at 5.09.41 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;👉  Remember that all the counter feature does is to increment or decrement a counter value based on which button is pressed by the user.&lt;/p&gt;

&lt;p&gt;So inside the test file we need to start by create a &lt;code&gt;MainFunction&lt;/code&gt; inside this main function we’ll go right ahed and create a group with the name of &lt;code&gt;CounterCubit&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="s"&gt;'package:test/test.dart'&lt;/span&gt;&lt;span class="o"&gt;;&lt;/span&gt;

&lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="nf"&gt;main&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;group&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'CounterCubit'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;

  &lt;span class="p"&gt;});&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;group → is actually a way of organizing multiple test for a feature.&lt;/p&gt;

&lt;p&gt;For Example:&lt;/p&gt;

&lt;p&gt;inside our CounterCubit group we’ll write all the necessary test for the counter feature.&lt;/p&gt;

&lt;p&gt;In a group you can also share a common &lt;code&gt;setup&lt;/code&gt; and &lt;code&gt;teardown&lt;/code&gt; functions across all the available test&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;setUp&lt;/span&gt;&lt;span class="p"&gt;(()&lt;/span&gt; &lt;span class="p"&gt;{});&lt;/span&gt;
&lt;span class="n"&gt;tearDown&lt;/span&gt;&lt;span class="p"&gt;(()&lt;/span&gt; &lt;span class="p"&gt;{});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;What is the purpose of these functions?&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;Inside the &lt;code&gt;setup&lt;/code&gt; function you can instantiate&lt;/p&gt;

&lt;p&gt;For Example: &lt;/p&gt;

&lt;p&gt;The objects our tests will be working with, in our case, we’ll instantiate the &lt;code&gt;CounterCubit&lt;/code&gt; so that access it later on in our test&lt;/p&gt;

&lt;p&gt;so &lt;code&gt;setup&lt;/code&gt; is mainly as its name is implying a function which will be called to create and initialize the necessary data tests will work with.&lt;/p&gt;

&lt;p&gt;on the other hand &lt;code&gt;teardown&lt;/code&gt; function&lt;br&gt;
&lt;/p&gt;
&lt;/li&gt;
&lt;/ul&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kt"&gt;void&lt;/span&gt; &lt;span class="nf"&gt;main&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="n"&gt;group&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'CounterCubit'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="kd"&gt;late&lt;/span&gt; &lt;span class="n"&gt;CounterCubit&lt;/span&gt; &lt;span class="n"&gt;counterCubit&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

    &lt;span class="n"&gt;setUp&lt;/span&gt;&lt;span class="p"&gt;(()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="n"&gt;counterCubit&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;
    &lt;span class="p"&gt;});&lt;/span&gt;

    &lt;span class="n"&gt;tearDown&lt;/span&gt;&lt;span class="p"&gt;(()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="n"&gt;counterCubit&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;close&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;
    &lt;span class="p"&gt;});&lt;/span&gt;
  &lt;span class="p"&gt;});&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;&lt;code&gt;teardown&lt;/code&gt; Function&lt;/p&gt;


💡 Is a function that will get called after each test is run and if `group` it will apply of course only to the test in that `group` inside of this perhaps we can `close` the created `Cubit`

&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Now the time has finally come for us to write our first test which is going to be checking the &lt;code&gt;InitialState&lt;/code&gt; of our &lt;code&gt;CounterCubit&lt;/code&gt; to is equal to &lt;code&gt;CounterState&lt;/code&gt; with a &lt;code&gt;CounterValue&lt;/code&gt; of &lt;code&gt;Zero&lt;/code&gt; .&lt;/p&gt;

&lt;p&gt;We’re going this by creating a &lt;code&gt;test&lt;/code&gt; function and give it a description which should denote the purpose of it, in this case in going to be &lt;code&gt;“initial state of CounterCubit is CounterState(counterValue:0)”&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;group&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'CounterCubit'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="kd"&gt;late&lt;/span&gt; &lt;span class="n"&gt;CounterCubit&lt;/span&gt; &lt;span class="n"&gt;counterCubit&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

    &lt;span class="n"&gt;setUp&lt;/span&gt;&lt;span class="p"&gt;(()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="n"&gt;counterCubit&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;CounterCubit&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;
    &lt;span class="p"&gt;});&lt;/span&gt;

    &lt;span class="n"&gt;tearDown&lt;/span&gt;&lt;span class="p"&gt;(()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="n"&gt;counterCubit&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;close&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;
    &lt;span class="p"&gt;});&lt;/span&gt;
    &lt;span class="n"&gt;test&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'initial state of CounterCubit is CounterState(counterValue:0)'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;

    &lt;span class="p"&gt;});&lt;/span&gt;
  &lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;How do we check this?&lt;/p&gt;

&lt;p&gt;I told you earlier that the purpose of any test is to check that the output of the feature is actually equal to the expected output nothing else&lt;/p&gt;

&lt;p&gt;To do this, all we need is the &lt;code&gt;except&lt;/code&gt; function which will take two main important arguments ( the &lt;code&gt;actual value&lt;/code&gt; returned by our &lt;code&gt;InitialState&lt;/code&gt; and the &lt;code&gt;expected value&lt;/code&gt; which we’re expecting to be received )&lt;/p&gt;

&lt;p&gt;So our &lt;code&gt;InitialState&lt;/code&gt; returned when the &lt;code&gt;Cubit&lt;/code&gt; created will be &lt;code&gt;counterCubit.state&lt;/code&gt; and the &lt;code&gt;expected value&lt;/code&gt; should be a &lt;code&gt;CounterState&lt;/code&gt; which has the &lt;code&gt;counterValue: 0&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;test&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'initial state of CounterCubit is CounterState(counterValue:0)'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
     &lt;span class="n"&gt;expect&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;counterCubit&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;state&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nl"&gt;counterValue:&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;));&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;We can run this test by typing &lt;code&gt;dart run&lt;/code&gt; test in terminal&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;//todo
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;OR rather by clicking the run button next to the &lt;code&gt;group&lt;/code&gt; .&lt;/p&gt;

&lt;p&gt;So if we run this test we will surprisingly receive a complete failure with this Message&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;Expected: &amp;lt;Instance of &lt;span class="s1"&gt;'CounterState'&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;
  Actual: &amp;lt;Instance of &lt;span class="s1"&gt;'CounterState'&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;in which we expected a instance of &lt;code&gt;CounterState&lt;/code&gt; and we actually receive an instance of &lt;code&gt;CounterState&lt;/code&gt; , here you can actually start to understand why testing is such an amazing tool, it has already signaled us a problem with our app.&lt;/p&gt;

&lt;p&gt;👉  Remember that the application worked perfectly when we manually tested it, how come that test fails then&lt;/p&gt;

&lt;p&gt;since it tell us that both the &lt;code&gt;expected&lt;/code&gt; and &lt;code&gt;actual&lt;/code&gt; output are instance of &lt;code&gt;CounterState&lt;/code&gt; and we know that both should have a &lt;code&gt;Zero&lt;/code&gt; value inside that means that the instances are still different somehow &lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--LBpt-hD0--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_4.46.38_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--LBpt-hD0--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-05_at_4.46.38_AM.png" alt="Screen Shot 2023-02-05 at 4.46.38 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;and that’s due the fact that inside &lt;code&gt;Dart&lt;/code&gt; language two instances of the same exact class aren’t equal even though they are basically identical this is happening because these two instances are stored in a different part of the memory and &lt;code&gt;Dart&lt;/code&gt; compares their location in memory instead of their values hence making them not equal.&lt;/p&gt;

&lt;p&gt;You can override this behavior really simple by using a really popular library you may have already heard about → &lt;code&gt;Equatable&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;in the backend, &lt;code&gt;Equatable&lt;/code&gt; is just a simple tool which overrides the &lt;code&gt;equal operator&lt;/code&gt; and the &lt;code&gt;HashCode&lt;/code&gt; for every class that extends it hence tricking Dart into comparing the instances by value rather than by where they’re placed in the memory.&lt;/p&gt;

&lt;p&gt;So if you want the functionality of comparing to instances like we do in our test, &lt;code&gt;Equatable&lt;/code&gt; is the way to go. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://pub.dev/packages/equatable"&gt;equatable | Dart Package&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Ok, so all we need to do inside our app right now is to add The &lt;code&gt;Equatable&lt;/code&gt; dependency in &lt;code&gt;pubspec.yaml&lt;/code&gt; file&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="na"&gt;dependencies&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;equatable&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;^2.0.5&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;And then &lt;code&gt;extend&lt;/code&gt; the &lt;code&gt;CounterState&lt;/code&gt; class with it&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="s"&gt;'package:equatable/equatable.dart'&lt;/span&gt;&lt;span class="o"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterState&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Equatable&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;final&lt;/span&gt; &lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="kd"&gt;final&lt;/span&gt; &lt;span class="kt"&gt;bool&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt; &lt;span class="n"&gt;wasIncremented&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
    &lt;span class="kd"&gt;required&lt;/span&gt; &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;wasIncremented&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="p"&gt;});&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;NOTE:&lt;/p&gt;

&lt;p&gt;that now we’ll get a warning telling us that need to override the &lt;code&gt;props&lt;/code&gt; of the &lt;code&gt;Equatable&lt;/code&gt; class&lt;/p&gt;

&lt;p&gt;👉  props → are just a way of indicating &lt;code&gt;Equatable&lt;/code&gt; which are the fields in our class that we want to be compared while applying the equal operator&lt;/p&gt;

&lt;p&gt;so we’re gonna pass both the &lt;code&gt;counterValue&lt;/code&gt; and &lt;code&gt;wasIncremented&lt;/code&gt; attributes inside the props list&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="s"&gt;'package:equatable/equatable.dart'&lt;/span&gt;&lt;span class="o"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;CounterState&lt;/span&gt; &lt;span class="kd"&gt;extends&lt;/span&gt; &lt;span class="n"&gt;Equatable&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;final&lt;/span&gt; &lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="kd"&gt;final&lt;/span&gt; &lt;span class="kt"&gt;bool&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt; &lt;span class="n"&gt;wasIncremented&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
    &lt;span class="kd"&gt;required&lt;/span&gt; &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="k"&gt;this&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;wasIncremented&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="p"&gt;});&lt;/span&gt;

  &lt;span class="nd"&gt;@override&lt;/span&gt;
  &lt;span class="kt"&gt;List&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="kt"&gt;Object&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="kd"&gt;get&lt;/span&gt; &lt;span class="n"&gt;props&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;counterValue&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;wasIncremented&lt;/span&gt;&lt;span class="p"&gt;];&lt;/span&gt; &lt;span class="c1"&gt;// &amp;lt;-&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Now whenever we will compare two &lt;code&gt;CounterStates&lt;/code&gt; , Dart will compare them attributes by attribute in order to see whether they’re equal or not.&lt;/p&gt;

&lt;p&gt;so right now if you go back to our test file and run the test, the test should finally &lt;code&gt;pass&lt;/code&gt; since our &lt;code&gt;expected&lt;/code&gt; and &lt;code&gt;actual&lt;/code&gt; &lt;code&gt;CounterState&lt;/code&gt; had the same &lt;code&gt;counterValue&lt;/code&gt; which is &lt;code&gt;Zero&lt;/code&gt; .&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--icAp5VjB--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-06_at_7.33.22_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--icAp5VjB--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-06_at_7.33.22_AM.png" alt="Screen Shot 2023-02-06 at 7.33.22 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Now it is time for us to test out the functionality of the &lt;code&gt;Increment&lt;/code&gt; and &lt;code&gt;Decrement&lt;/code&gt; functions from inside our counter feature because these are the most important right&lt;/p&gt;

&lt;p&gt;⇒ for this we’ll use the &lt;code&gt;blocTest&lt;/code&gt; function from inside the &lt;code&gt;bloc_test&lt;/code&gt; dependency.&lt;/p&gt;

&lt;p&gt;We’ll use this because we need to test the output as a response to the &lt;code&gt;increment&lt;/code&gt; or &lt;code&gt;decrement&lt;/code&gt; functions.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;We’ll start with the test for the &lt;code&gt;increment&lt;/code&gt; functionality&lt;/p&gt;

&lt;p&gt;So firstly we need to describe it properly &lt;/p&gt;

&lt;p&gt;&lt;code&gt;“the CounterCubit should emit a CounterState(counterValue:1, wasIncremented:true) when the increment function is called”&lt;/code&gt; &lt;/p&gt;

&lt;p&gt;👉  To do this, we’ll use the trio parameters of &lt;code&gt;build&lt;/code&gt; , &lt;code&gt;act&lt;/code&gt;, &lt;code&gt;expect&lt;/code&gt; from inside &lt;code&gt;blocTest&lt;/code&gt; function.&lt;br&gt;
&lt;/p&gt;
&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;blocTest&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
      &lt;span class="s"&gt;'the CounterCubit should emit a CounterState(counterValue:1,'&lt;/span&gt;
            &lt;span class="s"&gt;'wasIncremented:true) when the increment function is called'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
   &lt;span class="nl"&gt;build:&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
   &lt;span class="nl"&gt;act:&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
   &lt;span class="nl"&gt;expect:&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;


&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;build&lt;/p&gt;


💡 Is a function that will return `current instance` of the `CounterCubit` in order to make it available to the testing process



&lt;p&gt;&lt;code&gt;build: ()⇒counterCubit,&lt;/code&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;act&lt;/p&gt;


💡 Is a function that will take the `cubit` and will return the `action` applied on it.



&lt;p&gt;in our case is the &lt;code&gt;increment&lt;/code&gt; function → &lt;code&gt;act: (cubit)⇒ cubit.increment()&lt;/code&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;expect&lt;/p&gt;


💡 Is a function that will return an `iterable list` which will verify if the order of the state and the actual emitted state correspond with the emitted ones and no other.



&lt;p&gt;the &lt;code&gt;counterCubit&lt;/code&gt; emits only a single state in this example we’ll place it inside the list accordingly&lt;/p&gt;

&lt;p&gt;&lt;code&gt;expect: ()⇒ [const CounterState(counterValue: 1, wasIncremented: true)],&lt;/code&gt;&lt;br&gt;
&lt;/p&gt;
&lt;/li&gt;
&lt;/ul&gt;

&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;blocTest&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="s"&gt;'the CounterCubit should emit a '&lt;/span&gt;
    &lt;span class="s"&gt;'CounterState(counterValue:1, wasIncremented:true)'&lt;/span&gt;
    &lt;span class="s"&gt;' when the increment function is called'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="nl"&gt;build:&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;counterCubit&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="nl"&gt;act:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;cubit&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;cubit&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;increment&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
  &lt;span class="nl"&gt;expect:&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nl"&gt;counterValue:&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nl"&gt;wasIncremented:&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt;&lt;span class="p"&gt;)],&lt;/span&gt;
&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;




&lt;/li&gt;
&lt;li&gt;

&lt;p&gt;test &lt;code&gt;decrement&lt;/code&gt; function&lt;/p&gt;

&lt;p&gt;The same procedure applies also to decrement function, the only difference being that will &lt;code&gt;act&lt;/code&gt; by calling the &lt;code&gt;decrement&lt;/code&gt;  function and that will &lt;code&gt;expect&lt;/code&gt; a &lt;code&gt;CounterState&lt;/code&gt; with a &lt;code&gt;counterValue of -1&lt;/code&gt; inside of &lt;code&gt;1&lt;/code&gt; since we subtract 1 from the initial &lt;code&gt;counterValue&lt;/code&gt; .&lt;br&gt;
&lt;/p&gt;

&lt;pre class="highlight dart"&gt;&lt;code&gt;&lt;span class="n"&gt;blocTest&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="s"&gt;'the CounterCubit should emit a '&lt;/span&gt;
    &lt;span class="s"&gt;'CounterState(counterValue:-1, wasIncremented:false)'&lt;/span&gt;
    &lt;span class="s"&gt;' when the decrement function is called'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="nl"&gt;build:&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;counterCubit&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="nl"&gt;act:&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;cubit&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;cubit&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="na"&gt;decrement&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
  &lt;span class="nl"&gt;expect:&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
        &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="n"&gt;CounterState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nl"&gt;counterValue:&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nl"&gt;wasIncremented:&lt;/span&gt; &lt;span class="kc"&gt;false&lt;/span&gt;&lt;span class="p"&gt;)],&lt;/span&gt;
&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;




&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Let’s run all the test now &lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--34kR09tA--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-06_at_8.21.19_AM.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--34kR09tA--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/v1/Flutter%20Bloc%20dd67c4da85364af8b95ad111152caf8f/Screen_Shot_2023-02-06_at_8.21.19_AM.png" alt="Screen Shot 2023-02-06 at 8.21.19 AM.png" width="" height=""&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Every Thing Passed  🎉  🎉&lt;/p&gt;

&lt;p&gt;⇒ Now we can know for sure that the &lt;code&gt;CounterCubit&lt;/code&gt; works as it should.&lt;/p&gt;

&lt;p&gt;🤔 Think about this scenario for example:&lt;/p&gt;

&lt;p&gt;Let’s say you were moved away from this project and another guy comes into place to continue the development, he doesn’t know Dart that well and he think that the &lt;code&gt;Equatable&lt;/code&gt; package is not needed and that application can work just fine without it so he refactors the code, runs the app and indeed the app is still working perfectly but underneath if we run the &lt;code&gt;CounterCubit&lt;/code&gt; test we can see that if there would be apart inside our app comparing two identical states, the output would have been completely different.&lt;/p&gt;

&lt;p&gt;this is exactly why app testing shouldn’t be skipped, it may seem like the refactoring works fine but in reality it isn’t.&lt;/p&gt;

&lt;p&gt;so i guess now you understood why it’s worth spending the extra time writing tests for user app.&lt;/p&gt;




&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;Resources&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;playlist&lt;/p&gt;

&lt;p&gt;&lt;a href="https://www.youtube.com/watch?v=w6XWjpBK4W8&amp;amp;list=PLptHs0ZDJKt_T-oNj_6Q98v-tBnVf-S_o&amp;amp;index=1"&gt;Introduction to "BLoC - from Zero To HERO" Series&lt;/a&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;Bloc Library (official website) → recommended&lt;/p&gt;

&lt;p&gt;&lt;a href="https://bloclibrary.dev/#/gettingstarted"&gt;Bloc State Management Library&lt;/a&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;
&lt;li&gt;

&lt;p&gt;Source Code of projects with Bloc&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://github.com/HanySameh/FlutterBloc"&gt;FlutterBloc&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://github.com/HanySameh/FlutterChallenges/tree/master/challenge_2"&gt;BlogClubApp&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;
&lt;/ul&gt;

</description>
      <category>flutter</category>
      <category>dart</category>
      <category>bloc</category>
      <category>mobile</category>
    </item>
  </channel>
</rss>
