<?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>DEV Community: Claudio Neto</title>
    <description>The latest articles on DEV Community by Claudio Neto (@claudionts).</description>
    <link>https://dev.to/claudionts</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%2F559258%2Ff53aebf6-3598-4b5d-905b-2da21a865859.jpg</url>
      <title>DEV Community: Claudio Neto</title>
      <link>https://dev.to/claudionts</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/claudionts"/>
    <language>en</language>
    <item>
      <title>Utilizando o Formik Context</title>
      <dc:creator>Claudio Neto</dc:creator>
      <pubDate>Wed, 13 Jan 2021 18:34:35 +0000</pubDate>
      <link>https://dev.to/claudionts/utilizando-o-formik-context-15na</link>
      <guid>https://dev.to/claudionts/utilizando-o-formik-context-15na</guid>
      <description>&lt;p&gt;Com o uso do Formik Context é mais fácil de organizar a estrutura de seus formulários, deixando de lado a preocupação de ficar passando várias propriedades entre os componentes; facilitando também a criação de componentes genéricos.&lt;br&gt;
Na imagem abaixo vemos como funciona o Formik Context. Declarando o formulário Formik, seus elementos filhos tem o acesso instantâneo do estado atual do formulário declarado no componente pai.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fkbjg5f7u3zbbtyl2tfdl.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fkbjg5f7u3zbbtyl2tfdl.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Posso colocar meu formulário com duas sessões separadas em componentes diferentes, AddressForm (formulário de endereço) e ProfileForm (formulário do perfil do usuário), dessa forma você consegue organizar melhor seus formulários no projeto. Não precisando passar a instância do Formik em cada componente criado, possibilitando gerenciar todas sessões do seu formulário em um único contexto.&lt;/p&gt;

&lt;p&gt;Bora pro código?!&lt;br&gt;
Vamos criar um projeto com 2 componentes, o primeiro declara o Formik e o input "name", o componente filho acessa o valor do campo "name" no estado do Formik em tempo real e exibe no browser.&lt;br&gt;
Executando os comandos abaixo no terminal criamos o projeto:&lt;/p&gt;


&lt;div class="ltag_gist-liquid-tag"&gt;
  
&lt;/div&gt;


&lt;p&gt;Após criar o projeto, iremos usar o trecho de código abaixo no arquivo App.tsx, para testarmos o Formik Context:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F5zlhwancrsfry4dcurjx.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2F5zlhwancrsfry4dcurjx.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;O conteúdo digitado no input será consultado e exibido instantâneamente em outro componente, resultado:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fjijwvxlo2lcmgy1csmwx.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fi%2Fjijwvxlo2lcmgy1csmwx.gif" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Terá novos artigos sobre o assunto, demonstrando o formulário com várias sessões, e também a criação de Input e Autocomplete Genéricos&lt;/p&gt;

&lt;p&gt;&lt;iframe src="https://codesandbox.io/embed/cranky-bhaskara-b5lbt"&gt;
&lt;/iframe&gt;
&lt;/p&gt;

</description>
    </item>
  </channel>
</rss>
