{"id":5773,"date":"2017-12-08T16:11:37","date_gmt":"2017-12-08T16:11:37","guid":{"rendered":"https:\/\/blog-stg.cheesecakelabs.com\/blog\/atomic-design-react\/"},"modified":"2022-07-01T17:24:43","modified_gmt":"2022-07-01T17:24:43","slug":"atomic-design-react","status":"publish","type":"post","link":"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/","title":{"rendered":"Atomic Design with React"},"content":{"rendered":"<p>How one methodology allowed me to create a great design system from scratch and made me a better developer, with principles of componentization, hierarchies and reuses of code.<\/p>\n<p><!--more--><\/p>\n<p><span style=\"font-weight: 400;\">I have recently had the opportunity to work on a new product from scratch made in React and PWA with the well-crafted and componentized UI at Cheesecake. However, when we discussed with the whole team the <a href=\"https:\/\/blog-stg.cheesecakelabs.com\/building-app-phase-3-product-development\/\">best way to approach the development<\/a>, we ended up having the same old problems that have happened in most past projects, such as:<\/span><\/p>\n<ul>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">Lack of Styleguide of components;<\/span><\/li>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">Lack of precision in estimating development time;<\/span><\/li>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">Great amount of setup time for developers;<\/span><\/li>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">Inconsistency between components and view;<\/span><\/li>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">Repeated code;<\/span><\/li>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">Side effects;<\/span><\/li>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">Very specific components to each pages;<\/span><\/li>\n<\/ul>\n<p><span style=\"font-weight: 400;\">We\u2019ve started to build the CSS architecture using the <a href=\"https:\/\/www.xfive.co\/blog\/itcss-scalable-maintainable-css-architecture\/\" target=\"_blank\" rel=\"noopener noreferrer\">ITCSS<\/a> methodology that organizes the style files on stacks from generics styles to the specifics ones, which helps you to scale large projects easily. But along with ITCSS, we were using CSS Modules to scope the components, so we noticed that component stack was getting huge and even the generic styles were being componentized and reused within other one.<\/span><\/p>\n<p><span style=\"font-weight: 400;\">That was the moment in which we paused to rethink our architecture and how we could set the components in a more distributed and organized way. Then we found a methodology called <\/span><a href=\"http:\/\/bradfrost.com\/blog\/post\/atomic-web-design\/\" target=\"_blank\" rel=\"noopener noreferrer\"><b>Atomic Design<\/b><\/a><span style=\"font-weight: 400;\"> that creates multiples stacks of components, with different hierarchies of complexity and dependence.<\/span><\/p>\n<p><img decoding=\"async\" class=\"alignnone size-full wp-image-5752\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Atomic-Design.png\" alt=\"\" width=\"1968\" height=\"448\" srcset=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Atomic-Design.png 1968w, https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Atomic-Design-768x175.png 768w\" sizes=\"(max-width: 1968px) 100vw, 1968px\" \/><\/p>\n<h2><span style=\"font-weight: 400;\">What is Atomic Design?<\/span><\/h2>\n<p><span style=\"font-weight: 400;\">Popularly known within the design world, Atomic Design helps to build consistent, solid and reusable design systems. Plus, in the world of React, Vue and frameworks that stimulate the componentization, Atomic Design is used unconsciously; but when used in the right way, it becomes a powerful ally for developers.<\/span><\/p>\n<p><span style=\"font-weight: 400;\">The name Atomic Design comes from the idea of separating the components in atoms, molecules, organisms, templates and pages, like in the image above. But what are the responsibilities of each separated part?<\/span><\/p>\n<h3>Atoms<\/h3>\n<p><img decoding=\"async\" class=\"size-full wp-image-5753 aligncenter\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Atoms.png\" alt=\"\" width=\"304\" height=\"132\"><\/p>\n<p><span style=\"font-weight: 400;\">Atoms are the smallest possible components, such as buttons, titles, inputs or event color pallets, animations, and fonts. They can be applied on any context, globally or within other components and templates, besides having many states, such as this example of button: disabled, hover, different sizes, etc.<\/span><\/p>\n<h3>Molecules<\/h3>\n<p><img decoding=\"async\" class=\"aligncenter wp-image-5755\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Molecules.png\" alt=\"\" width=\"601\" height=\"348\" srcset=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Molecules.png 1308w, https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Molecules-768x445.png 768w\" sizes=\"(max-width: 601px) 100vw, 601px\" \/><\/p>\n<p><span style=\"font-weight: 400;\">They are the composition of one or more components of atoms. Here we begin to compose complex components and reuse some of those components. Molecules can have their own properties and create functionalities by using atoms, which don&#8217;t have any function or action by themselves.<\/span><\/p>\n<h3>Organisms<\/h3>\n<p><img decoding=\"async\" class=\"size-full wp-image-5756 aligncenter\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Organisms.png\" alt=\"\" width=\"2712\" height=\"850\" srcset=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Organisms.png 2712w, https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Organisms-768x241.png 768w\" sizes=\"(max-width: 2712px) 100vw, 2712px\" \/><\/p>\n<p><span style=\"font-weight: 400;\">Organisms are the combination of molecules that work together or even with atoms that compose more elaborate interfaces. At this level, the components begin to have the final shape, but they are still ensured to be independent, portable and reusable enough to be reusable in any content. <\/span><\/p>\n<h3>Templates<\/h3>\n<p><img decoding=\"async\" class=\"aligncenter wp-image-5758\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Templates.png\" alt=\"\" width=\"600\" height=\"442\" srcset=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Templates.png 1170w, https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Templates-768x566.png 768w\" sizes=\"(max-width: 600px) 100vw, 600px\" \/><\/p>\n<p><span style=\"font-weight: 400;\">In this state we stop composing components and begin to set their context. Moreover, the templates create relationships between the organisms and others components through positions, placements and patterns of the pages but it doesn\u2019t have any style, color or component rendered. That\u2019s why it looks like a wireframe.<\/span><\/p>\n<h3>Pages<\/h3>\n<p><img decoding=\"async\" class=\"alignnone size-full wp-image-5759\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Pages.png\" alt=\"\" width=\"1536\" height=\"1011\" srcset=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Pages.png 1536w, https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Pages-768x506.png 768w\" sizes=\"(max-width: 1536px) 100vw, 1536px\" \/><\/p>\n<p><span style=\"font-weight: 400;\">Pages are the navigate parts of the application and it\u2019s where the components are distributed in one specific template. The components get real content and they\u2019re connected with the whole application. At this stage, we can test the efficiency of the design system to analyse if all the components are independent enough or if we need to split them in smaller parts.<\/span><\/p>\n<h2>React + Atomic Design<\/h2>\n<p><span style=\"font-weight: 400;\">When we started to use Atomic Design within React we had to adjust some rules of the methodology to ensure that components were reused as much as possible, that they were stateless, without styles of positions and very specific margins so to avoid any side effects in the pages of application.<\/span><\/p>\n<p><span style=\"font-weight: 400;\">So with each new component we asked ourselves: \u201cAre these components generic enough to avoid specificity and\/or repeated code in whatever context they are used?\u201d<\/span><\/p>\n<p><span style=\"font-weight: 400;\">So we were able to write a few rules:<\/span><\/p>\n<ol>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">The Atomic Design should have a file of <\/span><b>variables<\/b><span style=\"font-weight: 400;\"> and it must be imported by each component;<\/span><\/li>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">The <\/span><b>atoms<\/b><span style=\"font-weight: 400;\"> should be written without margins and positions;<\/span><\/li>\n<li style=\"font-weight: 400;\"><span style=\"font-weight: 400;\">Only the <\/span><b>molecules<\/b><span style=\"font-weight: 400;\"> and <\/span><b>organisms<\/b><span style=\"font-weight: 400;\"> can set the positions of atoms, but these stacks can\u2019t have any styles of margins and positions;<\/span><\/li>\n<li style=\"font-weight: 400;\"><b>Templates <\/b><span style=\"font-weight: 400;\">have only one function: to set the grid of pages but never positions of specific components;<\/span><\/li>\n<li><b>Pages <span style=\"font-weight: 400;\">render the components with a template defined and it\u2019s here that the <\/span>Atomic Design <span style=\"font-weight: 400;\">will be connected to the rest of the application;<\/span><\/b><\/li>\n<\/ol>\n<h2><span style=\"font-weight: 400;\">Let\u2019s code<\/span><\/h2>\n<p>What I will show here is everything in a<strong> <a href=\"https:\/\/github.com\/danilowoz\/react-atomic-design\" target=\"_blank\" rel=\"noopener noreferrer\">boilerplate on GitHub<\/a>,<\/strong> which you can test and then start your projects using Atomic Design, so let&#8217;s do it:<\/p>\n<p>&#8211;<\/p>\n<p><span style=\"font-weight: 400;\">To build a UI LIbrary we used an awesome tool called <a href=\"https:\/\/storybook.js.org\" target=\"_blank\" rel=\"noopener noreferrer\">Storybook<\/a><\/span><span style=\"font-weight: 400;\">, which is a great ally to the Atomic Design in React (you can use it for the <a href=\"https:\/\/blog-stg.cheesecakelabs.com\/react-native-examples-innovative-brands\/\">React Native<\/a> and Vue too), it allows to render the components and list all states\/variations of one.<\/span><\/p>\n<p><span style=\"font-weight: 400;\">With the Storybook installed the folder structure will look like this:<\/span><\/p>\n<p><img decoding=\"async\" class=\"alignnone wp-image-5757 size-full\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/path.png\" alt=\"\" width=\"1564\" height=\"988\" srcset=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/path.png 1564w, https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/path-768x485.png 768w\" sizes=\"(max-width: 1564px) 100vw, 1564px\" \/><\/p>\n<p><span style=\"font-weight: 400;\">Note that inside of the button component there is a file called \u2018index.js\u2019 which is the component itself, the \u2018styles.css\u2019 is the style that will be imported by CSS Modules (here we\u2019ve used the BEM CSS inside the structure; I recommend reading the article \u2018<a href=\"https:\/\/blog-stg.cheesecakelabs.com\/css-architecture-reactjs\/\" target=\"_blank\" rel=\"noopener noreferrer\">CSS Architecture with ReactJS<\/a>\u2019) and the \u2018stories.js\u2019 is the file that will import the component into the Storybook, which looks like this:<\/span><\/p>\n<p><img decoding=\"async\" class=\"alignnone size-full wp-image-5754\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/button.png\" alt=\"\" width=\"1564\" height=\"784\" srcset=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/button.png 1564w, https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/button-768x385.png 768w\" sizes=\"(max-width: 1564px) 100vw, 1564px\" \/><\/p>\n<p><span style=\"font-weight: 400;\">Each &#8216;add ()&#8217; function is a variation of the component and it is the best approach to describe each state individually rather than a single function, so it becomes easier to highlight and control each one of them. So if you describe all the component variations , the Storybook should look like this:<\/span><\/p>\n<p><img decoding=\"async\" class=\"alignnone size-full wp-image-5760\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Storybook.png\" alt=\"\" width=\"1536\" height=\"1011\" srcset=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Storybook.png 1536w, https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/Storybook-768x506.png 768w\" sizes=\"(max-width: 1536px) 100vw, 1536px\" \/><\/p>\n<p><span style=\"font-weight: 400;\">And the coolest part of the Storybook is that you can add some \u2018addons\u2019, such as the <a href=\"https:\/\/github.com\/storybooks\/storybook\/tree\/master\/addons\/info\" target=\"_blank\" rel=\"noopener noreferrer\">Storybook Info<\/a>, which does awesome things like: story source, props types, defaults values and which values are required or not.<\/span><\/p>\n<p><img decoding=\"async\" class=\"size-full wp-image-5764 aligncenter\" src=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/proptypes.png\" alt=\"\" width=\"446\" height=\"316\"><\/p>\n<h2><span style=\"font-weight: 400;\">Conclusion<\/span><\/h2>\n<p><span style=\"font-weight: 400;\">At the end of project, we reached the initial goals and we believe we left a good legacy, a structure which ensures that the project can grow and that other developers can understand the architecture quickly. Maybe we initially spent some extra time writing stories and etc, but the more the project grows, the more the benefits make clear why we should use such architecture.<\/span><\/p>\n<p><span style=\"font-weight: 400;\">However we could see that this architecture probably doesn\u2019t work for every project because it depends on several factors. The main one is that the design needs to be thought in the same way as the development: <\/span><b>in an atomic way<\/b><span style=\"font-weight: 400;\">. But the integration between design and development is a point that every project wants to reach, so it becomes a very positive point for <\/span><b>Atomic Design.<\/b><\/p>\n<h3>References<\/h3>\n<p><a href=\"https:\/\/github.com\/danilowoz\/react-atomic-design\" target=\"_blank\" rel=\"noopener noreferrer\"><strong>Boilerplate on GitHub<\/strong><\/a><\/p>\n<p><a href=\"https:\/\/blog-stg.cheesecakelabs.com\/css-architecture-reactjs\/\" target=\"_blank\" rel=\"noopener noreferrer\">CSS Architecture with ReactJS<\/a><\/p>\n<p><a href=\"http:\/\/bradfrost.com\/blog\/post\/atomic-web-design\/\" target=\"_blank\" rel=\"noopener noreferrer\">Atomic Web Design<\/a><\/p>\n<p><a href=\"http:\/\/patternlab.io\/\" target=\"_blank\" rel=\"noopener noreferrer\">Patternlab<\/a><\/p>\n<p><a href=\"https:\/\/medium.com\/buildit\/using-react-within-a-design-system-73d4bb0cc822\" target=\"_blank\" rel=\"noopener noreferrer\">Using React within a design system<\/a><\/p>\n<p><a href=\"https:\/\/medium.com\/@yejodido\/atomic-components-managing-dynamic-react-components-using-atomic-design-part-1-5f07451f261f\" target=\"_blank\" rel=\"noopener noreferrer\">Atomic components managing dynamic react components using atomic design <\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>How one methodology allowed me to create a great design system from scratch and made me a better developer, with principles of componentization, hierarchies and reuses of code.<\/p>\n","protected":false},"author":65,"featured_media":9283,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[341],"tags":[],"class_list":["post-5773","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-design-br"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v21.1 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Atomic Design with React | Cheesecake Labs<\/title>\n<meta name=\"description\" content=\"How atomic design with React allows creating a great design system from scratch with principles of componentization, hierarchies, and reuse of code.\" \/>\n<meta name=\"robots\" content=\"noindex, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Atomic Design with React | Cheesecake Labs\" \/>\n<meta property=\"og:description\" content=\"How atomic design with React allows creating a great design system from scratch with principles of componentization, hierarchies, and reuse of code.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/\" \/>\n<meta property=\"og:site_name\" content=\"Cheesecake Labs\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/cheesecakelabs\" \/>\n<meta property=\"article:published_time\" content=\"2017-12-08T16:11:37+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2022-07-01T17:24:43+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/danilo_blogpost2-02.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"3000\" \/>\n\t<meta property=\"og:image:height\" content=\"1065\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"Cheesecake Labs\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@cheesecakelabs\" \/>\n<meta name=\"twitter:site\" content=\"@cheesecakelabs\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. tempo de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"6 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/\",\"url\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/\",\"name\":\"Atomic Design with React | Cheesecake Labs\",\"isPartOf\":{\"@id\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/#website\"},\"datePublished\":\"2017-12-08T16:11:37+00:00\",\"dateModified\":\"2022-07-01T17:24:43+00:00\",\"author\":{\"@type\":\"person\",\"name\":\"Danilo Woznica\"},\"description\":\"How atomic design with React allows creating a great design system from scratch with principles of componentization, hierarchies, and reuse of code.\",\"breadcrumb\":{\"@id\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Atomic Design with React\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/#website\",\"url\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/\",\"name\":\"Cheesecake Labs\",\"description\":\"Empresa de desenvolvimento e design de aplicativos mobile &amp; web que est\u00e1 reinventando o desenvolvimento de produtos com times remotos. N\u00f3s desenvolvemos aplicativos iOS, Android e aplica\u00e7\u00f5es Web com as melhores empresas dos EUA, do Brasil e do mundo.\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Person\",\"name\":\"Danilo Woznica\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/09\/danilo-300x300.jpg\",\"contentUrl\":\"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/09\/danilo-300x300.jpg\",\"caption\":\"Danilo Woznica\"},\"description\":\"10 years of experience in Marketing and Sales in the Technology sector. My main purpose is help, support and structure efficient operations and also develop independent and multidisciplinary teams.\",\"url\":\"https:\/\/blog-stg.cheesecakelabs.com\/br\/\/autor\/danilo-woznica\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Atomic Design with React | Cheesecake Labs","description":"How atomic design with React allows creating a great design system from scratch with principles of componentization, hierarchies, and reuse of code.","robots":{"index":"noindex","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"og_locale":"pt_BR","og_type":"article","og_title":"Atomic Design with React | Cheesecake Labs","og_description":"How atomic design with React allows creating a great design system from scratch with principles of componentization, hierarchies, and reuse of code.","og_url":"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/","og_site_name":"Cheesecake Labs","article_publisher":"https:\/\/www.facebook.com\/cheesecakelabs","article_published_time":"2017-12-08T16:11:37+00:00","article_modified_time":"2022-07-01T17:24:43+00:00","og_image":[{"width":3000,"height":1065,"url":"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/12\/danilo_blogpost2-02.jpg","type":"image\/jpeg"}],"author":"Cheesecake Labs","twitter_card":"summary_large_image","twitter_creator":"@cheesecakelabs","twitter_site":"@cheesecakelabs","twitter_misc":{"Escrito por":null,"Est. tempo de leitura":"6 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/","url":"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/","name":"Atomic Design with React | Cheesecake Labs","isPartOf":{"@id":"https:\/\/blog-stg.cheesecakelabs.com\/br\/#website"},"datePublished":"2017-12-08T16:11:37+00:00","dateModified":"2022-07-01T17:24:43+00:00","author":{"@type":"person","name":"Danilo Woznica"},"description":"How atomic design with React allows creating a great design system from scratch with principles of componentization, hierarchies, and reuse of code.","breadcrumb":{"@id":"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/blog-stg.cheesecakelabs.com\/br\/atomic-design-react\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/blog-stg.cheesecakelabs.com\/br\/"},{"@type":"ListItem","position":2,"name":"Atomic Design with React"}]},{"@type":"WebSite","@id":"https:\/\/blog-stg.cheesecakelabs.com\/br\/#website","url":"https:\/\/blog-stg.cheesecakelabs.com\/br\/","name":"Cheesecake Labs","description":"Empresa de desenvolvimento e design de aplicativos mobile &amp; web que est\u00e1 reinventando o desenvolvimento de produtos com times remotos. N\u00f3s desenvolvemos aplicativos iOS, Android e aplica\u00e7\u00f5es Web com as melhores empresas dos EUA, do Brasil e do mundo.","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/blog-stg.cheesecakelabs.com\/br\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"pt-BR"},{"@type":"Person","name":"Danilo Woznica","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/blog-stg.cheesecakelabs.com\/br\/#\/schema\/person\/image\/","url":"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/09\/danilo-300x300.jpg","contentUrl":"https:\/\/ckl-website-static.s3.amazonaws.com\/wp-content\/uploads\/2017\/09\/danilo-300x300.jpg","caption":"Danilo Woznica"},"description":"10 years of experience in Marketing and Sales in the Technology sector. My main purpose is help, support and structure efficient operations and also develop independent and multidisciplinary teams.","url":"https:\/\/blog-stg.cheesecakelabs.com\/br\/\/autor\/danilo-woznica\/"}]}},"_links":{"self":[{"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/posts\/5773","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/users\/65"}],"replies":[{"embeddable":true,"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/comments?post=5773"}],"version-history":[{"count":1,"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/posts\/5773\/revisions"}],"predecessor-version":[{"id":10253,"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/posts\/5773\/revisions\/10253"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/media\/9283"}],"wp:attachment":[{"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/media?parent=5773"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/categories?post=5773"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog-stg.cheesecakelabs.com\/br\/wp-json\/wp\/v2\/tags?post=5773"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}