Notice: Function _load_textdomain_just_in_time was called incorrectly. Translation loading for the wordpress-seo domain was triggered too early. This is usually an indicator for some code in the plugin or theme running too early. Translations should be loaded at the init action or later. Please see Debugging in WordPress for more information. (This message was added in version 6.7.0.) in /home2/thebrand/public_html/wp-includes/functions.php on line 6114

Warning: Cannot modify header information - headers already sent by (output started at /home2/thebrand/public_html/wp-includes/functions.php:6114) in /home2/thebrand/public_html/wp-includes/rest-api/class-wp-rest-server.php on line 1893

Warning: Cannot modify header information - headers already sent by (output started at /home2/thebrand/public_html/wp-includes/functions.php:6114) in /home2/thebrand/public_html/wp-includes/rest-api/class-wp-rest-server.php on line 1893

Warning: Cannot modify header information - headers already sent by (output started at /home2/thebrand/public_html/wp-includes/functions.php:6114) in /home2/thebrand/public_html/wp-includes/rest-api/class-wp-rest-server.php on line 1893

Warning: Cannot modify header information - headers already sent by (output started at /home2/thebrand/public_html/wp-includes/functions.php:6114) in /home2/thebrand/public_html/wp-includes/rest-api/class-wp-rest-server.php on line 1893

Warning: Cannot modify header information - headers already sent by (output started at /home2/thebrand/public_html/wp-includes/functions.php:6114) in /home2/thebrand/public_html/wp-includes/rest-api/class-wp-rest-server.php on line 1893

Warning: Cannot modify header information - headers already sent by (output started at /home2/thebrand/public_html/wp-includes/functions.php:6114) in /home2/thebrand/public_html/wp-includes/rest-api/class-wp-rest-server.php on line 1893

Warning: Cannot modify header information - headers already sent by (output started at /home2/thebrand/public_html/wp-includes/functions.php:6114) in /home2/thebrand/public_html/wp-includes/rest-api/class-wp-rest-server.php on line 1893

Warning: Cannot modify header information - headers already sent by (output started at /home2/thebrand/public_html/wp-includes/functions.php:6114) in /home2/thebrand/public_html/wp-includes/rest-api/class-wp-rest-server.php on line 1893
{"id":29854,"date":"2021-09-11T01:25:31","date_gmt":"2021-09-11T01:25:31","guid":{"rendered":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/"},"modified":"2021-09-11T01:25:31","modified_gmt":"2021-09-11T01:25:31","slug":"developer-decisions-for-building-flexible-components-8","status":"publish","type":"post","link":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/","title":{"rendered":"Developer Decisions For Building Flexible Components"},"content":{"rendered":"

In the real world, content often differs vastly from the neat, perfectly fitting content presented in designs. Added to that, on the modern web, users have an ever-increasing range of options for how they access the sites we build.<\/p>\n

In this article, we\u2019ll walk through the process of taking a seemingly simple design for a text-and-media component and deciding how best to translate it into code, keeping in mind the needs of both users and content authors. We\u2019re not going to delve into how<\/em> to code it \u2014 rather, the factors that will determine our development decisions. We\u2019ll consider the questions we need to ask (both ourselves and other stakeholders) at every step.<\/p>\n

Changing Our Development Mindset <\/p>\n

We simply can no longer design and develop only for \u201coptimal\u201d content or browsing conditions. Instead, we must embrace the inherent flexibility and unpredictability of the web, and build resilient components. Static mockups cannot cater to every scenario, so many design decisions fall to developers at build time. Like it or not, if you\u2019re a UI developer, you are<\/em> a designer \u2014 even if you don\u2019t consider yourself one!<\/p>\n

In my job at WordPress specialist web agency Atomic Smash<\/em>, we build websites for clients who need maximum flexibility from the components we provide, while ensuring the site still looks great, no matter what content they throw at it. Sometimes interpreting a design means asking the designer to further elaborate on their ideas (or even re-evaluate them). Other times, it means making design decisions on the fly or making recommendations based on our knowledge and experience. We\u2019ll look at some of the times these approaches might be appropriate in this case study.<\/p>\n

The Design <\/p>\n

We start with a simple design for a text-and-media component \u2014 something fairly commonly seen on product landing pages. It consists of an image or video on the left and a column on the right containing a heading, a paragraph of text and a call-to-action link. This design is for a (fictional) startup that helps people who want to learn a new skill find a tutor.<\/p>\n

<\/p>\n

Note:<\/strong> If you want to jump straight to the code and view all the possible solutions we alighted on for this component, you can find it in this Codepen demo<\/a>.<\/em><\/p>\n

Layout And Order <\/p>\n

The designer has stipulated that every other component should have the layout flipped so that the image is on the right and the text column on the left. <\/p>\n

<\/p>\n

In the mobile layout, however, the image is stacked above the text content in all cases. Assuming we build this layout using either Grid or flexbox, we could use flex-direction<\/code> or the order<\/code> property to reorder the layout for every second component:<\/p>\n

.text-and-media:nth-child(even) {     flex-direction: row-reverse; }<\/code><\/pre>\n

It\u2019s worth bearing in mind that while these will reorder the content visually, it does not change the DOM order. This means that to a partially-sighted person browsing the site using a screenreader, the order of the content may not appear logical, jumping from left-to-right to right-to-left.<\/p>\n

Speaking personally, in the case where the only content in one of the columns is an image, I feel that using the order<\/code> property is more or less okay. But if we had two columns of text, for instance, reordering with CSS might make for a confusing experience. In those cases, we have some other options available to us. We could:<\/p>\n

    \n
  1. Put forward our accessibility concerns and recommend that for mobile layouts the visual order is changed to match the desktop order.<\/li>\n
  2. Use Javascript to reorder the elements in the DOM.<\/li>\n<\/ol>\n

    We also need to consider whether to enforce the order through the :nth-child<\/code> selector or to allow the client to control the order (by adding a class to the component, say). The suitability of each option will likely depend on the project.<\/p>\n

    Dealing With Different Content Lengths <\/p>\n

    In the design, the proportion of text content compared to the image is quite pleasing. It allows the image to maintain an ideal aspect ratio. But what should happen if the text is longer or shorter than what\u2019s presented? Let\u2019s deal with the former first.<\/p>\n

    Longer Content<\/h3>\n

    We can set a character limit on the text field in our chosen CMS (if we\u2019re so inclined), but we should allow for at least some<\/em> variation in our component. If we add a longer paragraph, the opposing media column could behave in one of several ways:<\/p>\n

      \n
    1. The image or video remains at the top, while space is added below (fig. 1).<\/li>\n
    2. The image or video is centered, adding space at the top or bottom (fig. 2).<\/li>\n
    3. The proportions of the image or video are scaled to match the height, using object-fit: cover<\/code> to prevent distortion and ensure the image fills the available space. This would mean some parts of the image may be clipped (fig. 3).<\/li>\n<\/ol>\n

      <\/p>\n

      <\/p>\n

      <\/p>\n

      We decided that option 3 was the most pleasing visually, and that for the most part content authors would be able to source appropriate images where a small amount of clipping would be acceptable. But it presented more of a challenge for video content, where there is more of a risk that important parts could be clipped. We alighted on another option, which was to create a different variation of the design where the video would maintain its original aspect ratio, and be contained within a maximum width instead of aligning to the edge of the page.<\/p>\n

      <\/p>\n

      Content authors could choose this option when it better suited their needs.<\/p>\n

      Additionally, we opted to extend this choice to instances where an image was used instead of a video. It gives the client a wider variety of layout options without adversely impacting the design. Seen in the wider page context it could even be considered an improvement, allowing for more interesting pages when several of these blocks are used on a page.<\/p>\n

      Shorter Content<\/h3>\n

      Dealing with less content is a little simpler, but still presents us with some issues. How should the image behave when the text content is shorter? Should it become shallower, so that the overall height of the component is determined by the text content (fig. 4)? Or should we set a minimum aspect ratio, so that the image doesn\u2019t become letterboxed, or allow the image to take up its natural, intrinsic height? In that case, we also have the consideration of whether to align the text centrally or to the top (fig. 5 and 5a).<\/p>\n

      <\/p>\n

      <\/p>\n

      <\/p>\n

      Heading Length<\/h3>\n

      Let\u2019s not forget we\u2019ll also need to test headings of different lengths. In the design the headings are short and snappy, rarely wrapping onto a second line. But what if a heading is several lines long, or the content uses a lot of long words, resulting in text wrapping differently? This might especially be a problem in languages such as German, where words tend to be much longer than English, for example. Does the size of the heading font in the design allow for an appropriate line length when used in this layout? Should long words be hyphenated when they wrap? This article<\/a> by Ahmad Shadeed addresses the issue of content length and included some handy tips for ways to deal with it in CSS.<\/p>\n

      Are content authors permitted to omit a heading altogether where it suits them? That brings us to the next consideration.<\/p>\n

      Omitting Content <\/p>\n

      Building this component as flexibly as possible means making sure that content authors can omit certain fields and still have the design look and function properly. It seems reasonable that the client may wish to omit the body text, the link, or even the heading when using this component in the wild. We need to take care to test with every conceivable combination of content, so that we can be confident our component won\u2019t break under stress. It\u2019s good practice to ensure we\u2019re not rendering empty HTML tags when field content isn\u2019t present. This will help us avoid unforeseen layout bugs.<\/p>\n

      <\/p>\n

      We can<\/em> restrict content authors with \u201crequired\u201d fields in the CMS, but perhaps we might also wish to consider scenarios where a client might choose to omit the image, or, conversely, without any<\/em> of the text content? It might be helpful to provide them with these options. Here\u2019s an example of how we might elect to render the component in those cases:<\/p>\n

      <\/p>\n

      By indenting the text a little more and increasing the width of the body text, we can keep it feeling balanced, even when there is no image.<\/p>\n

      Multiple Links <\/p>\n

      Omitting content is one scenario. But at Atomic Smash, we found that more often, clients wanted the option to add more than one link to the component. That presents us with another choice: how to layout multiple links? Do we lay them out side-by-side (fig. 8), or stack them vertically (fig. 8a)?<\/p>\n

      <\/p>\n

      <\/p>\n

      How do we deal with link titles of wildly different lengths? A nice trick is to set the widths of both links to the maximum width of the longest (fig. 9). (This article<\/a> covers just that.) That works well for vertically stacked buttons, whereas laying them out horizontally presents us with even more choices (fig. 9a).<\/p>\n

      <\/p>\n

      <\/p>\n

      Do we need a secondary link style, to differentiate them? These are all questions to consider.<\/p>\n

      <\/p>\n

      We may also need to consider (in the case of a single link) whether, in fact, the clickable area of the link should encompass the entire component \u2014 so users can click anywhere on it to activate the link. That choice might perhaps depend on the wider context. It\u2019s certainly common in card-based UIs.<\/p>\n

      Video <\/p>\n

      When the component is used for video rather than a static image, we might notice that the design omits some key information. How is the video playback controlled? On hover? Does it autoplay on scroll? Should there be controls visible to the user?<\/p>\n

      If the video plays on hover, we must consider how the user of a device without hover capabilities accesses the video content. Alternatively, if the video autoplays, we should consider preventing this for users with a preference for reduced motion, who may suffer from vestibular disorders (or might simply wish to avoid jarring animations). We should also provide a way for all users to stop the video when they wish.<\/p>\n

      Putting It In Context <\/p>\n

      One issue with focusing so closely on components when it comes to web design, is sometimes we forget to consider how the components we build will appear in the context of the overall web page. We\u2019ll need to consider the spacing, both between components of the same type and in a page layout where other components are interspersed.<\/p>\n

      These text-and-media components are designed to be used sparingly, creating an eye-catching splash of color and a break from an otherwise linear layout. But using WordPress, a content author could easily decide to build an entire page made up of nothing but these components. That could end up looking rather dull, and not at all the effect we were hoping for!<\/p>\n

      During the build process, we decided to add an option to omit the background color. That allows us to break the page up and make it more interesting:<\/p>\n

      <\/p>\n

      We could either enforce a pattern using :nth-child<\/code> or add a field in the CMS to give the client more creative control.<\/p>\n

      Although this was not part of the original design, it shows that an open line of communication between designer and developer can help create better outcomes in terms of more flexible and robust designs.<\/p>\n

      WYSIWYG Text Styles <\/p>\n

      When considering content, we need to consider not just the length of text, but the actual HTML elements that might be permitted in the body text field. Content authors might want to add multiple paragraphs, anchor links, lists, and more to the body copy. At Atomic Smash we like to provide a WYSIWYG (What You See Is What You Get) or rich text field for these areas, which can allow for many different elements. It\u2019s important to test with different types of content, and style appropriately \u2014 including testing for sufficient color contrast on all background colors used.<\/p>\n

      <\/p>\n

      Wrapping Up <\/p>\n

      We\u2019ve touched on many different decisions involved with building this seemingly simple component. You might even be able to think of a few others we haven\u2019t covered here! By considering every aspect of the design and how it might be used in context, we\u2019ve ended up with something far more versatile, which hopefully should result in happier clients!<\/p>\n

      Sometimes, the more that is omitted from a design, the more time and attention will be required from a developer. I\u2019ve put together a checklist below of things to test and question when building a component, which you might find useful. It may be adapted for different components too. <\/p>\n

      Being able to look past the apparent simplicity, break down a component into its constituent parts, ask key questions (even before any development takes place), and even consider future uses, are all skills that will serve any developer well when building websites \u2014 and will help you provide vastly more accurate estimates when required. Good team communication and a strong collaborative process are invaluable for building resilient sites, but the end result makes it worth investing in nurturing this culture. Let\u2019s bake flexibility into our design and<\/em> build processes.<\/p>\n

      The Checklist <\/p>\n

      Things to test:<\/p>\n

        \n
      1. Accessibility of layout (mobile and desktop).<\/li>\n
      2. Images of different intrinsic aspect ratios \u2014 are they cropped appropriately?<\/li>\n
      3. Longer and shorter body text (including multiple paragraphs).<\/li>\n
      4. Longer and shorter heading (including various word lengths).<\/li>\n
      5. Omitting (variously) the heading, body text, links and image.<\/li>\n
      6. Multiple links (including different lengths of link text).<\/li>\n
      7. Accessibility of video content.<\/li>\n
      8. WYSIWYG text content (include links, lists, etc. in body text).<\/li>\n
      9. Test in context \u2014 include multiple components (with different content options), as well as other components mixed into the page layout.<\/li>\n<\/ol>\n

        Articles on Smashing Magazine \u2014 For Web Designers And Developers<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"

        In the real world, content often differs vastly from the neat, perfectly fitting content presented in designs. Added to that, on the modern web, users have an ever-increasing range of options for how they access the sites we build. In this article, we\u2019ll walk through the process of taking a seemingly simple design for a […]<\/p>\n","protected":false},"author":6,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[183],"tags":[422,1363,1710,194,2699],"class_list":["post-29854","post","type-post","status-publish","format-standard","hentry","category-news","tag-building","tag-components","tag-decisions","tag-developer","tag-flexible"],"yoast_head":"\nDeveloper Decisions For Building Flexible Components - The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Developer Decisions For Building Flexible Components - The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.\" \/>\n<meta property=\"og:description\" content=\"In the real world, content often differs vastly from the neat, perfectly fitting content presented in designs. Added to that, on the modern web, users have an ever-increasing range of options for how they access the sites we build. In this article, we\u2019ll walk through the process of taking a seemingly simple design for a […]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/\" \/>\n<meta property=\"og:site_name\" content=\"The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.\" \/>\n<meta property=\"article:publisher\" content=\"http:\/\/www.facebook.com\/thebrandingstore\" \/>\n<meta property=\"article:published_time\" content=\"2021-09-11T01:25:31+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cloud.netlifyusercontent.com\/assets\/344dbf88-fdf9-42bb-adb4-46f01eedd629\/d8bdd509-e324-4324-9bc8-51e1b4474c8d\/1-flexible-components-css.jpg\" \/>\n<meta name=\"author\" content=\"TBS\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@brandingstore\" \/>\n<meta name=\"twitter:site\" content=\"@brandingstore\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"TBS\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"12 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/\",\"url\":\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/\",\"name\":\"Developer Decisions For Building Flexible Components - The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.\",\"isPartOf\":{\"@id\":\"https:\/\/thebrandingstore.net\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/cloud.netlifyusercontent.com\/assets\/344dbf88-fdf9-42bb-adb4-46f01eedd629\/d8bdd509-e324-4324-9bc8-51e1b4474c8d\/1-flexible-components-css.jpg\",\"datePublished\":\"2021-09-11T01:25:31+00:00\",\"dateModified\":\"2021-09-11T01:25:31+00:00\",\"author\":{\"@id\":\"https:\/\/thebrandingstore.net\/#\/schema\/person\/ab355af6cfab88bc1a4d960c257c8a38\"},\"breadcrumb\":{\"@id\":\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#primaryimage\",\"url\":\"https:\/\/cloud.netlifyusercontent.com\/assets\/344dbf88-fdf9-42bb-adb4-46f01eedd629\/d8bdd509-e324-4324-9bc8-51e1b4474c8d\/1-flexible-components-css.jpg\",\"contentUrl\":\"https:\/\/cloud.netlifyusercontent.com\/assets\/344dbf88-fdf9-42bb-adb4-46f01eedd629\/d8bdd509-e324-4324-9bc8-51e1b4474c8d\/1-flexible-components-css.jpg\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/thebrandingstore.net\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Developer Decisions For Building Flexible Components\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/thebrandingstore.net\/#website\",\"url\":\"https:\/\/thebrandingstore.net\/\",\"name\":\"The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.\",\"description\":\"Branding Solutions for Business and Products, Logo design, Graphic Design, Web Design, Business Cards, E-commerce, Social Media, Prints, Photography, Video and More!\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/thebrandingstore.net\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/thebrandingstore.net\/#\/schema\/person\/ab355af6cfab88bc1a4d960c257c8a38\",\"name\":\"TBS\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/thebrandingstore.net\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/6c47fdedf1de6281cdaef4f87897119c?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/6c47fdedf1de6281cdaef4f87897119c?s=96&d=mm&r=g\",\"caption\":\"TBS\"},\"url\":\"https:\/\/thebrandingstore.net\/author\/tbs\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Developer Decisions For Building Flexible Components - The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/","og_locale":"en_US","og_type":"article","og_title":"Developer Decisions For Building Flexible Components - The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.","og_description":"In the real world, content often differs vastly from the neat, perfectly fitting content presented in designs. Added to that, on the modern web, users have an ever-increasing range of options for how they access the sites we build. In this article, we\u2019ll walk through the process of taking a seemingly simple design for a […]","og_url":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/","og_site_name":"The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.","article_publisher":"http:\/\/www.facebook.com\/thebrandingstore","article_published_time":"2021-09-11T01:25:31+00:00","og_image":[{"url":"https:\/\/cloud.netlifyusercontent.com\/assets\/344dbf88-fdf9-42bb-adb4-46f01eedd629\/d8bdd509-e324-4324-9bc8-51e1b4474c8d\/1-flexible-components-css.jpg"}],"author":"TBS","twitter_card":"summary_large_image","twitter_creator":"@brandingstore","twitter_site":"@brandingstore","twitter_misc":{"Written by":"TBS","Est. reading time":"12 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/","url":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/","name":"Developer Decisions For Building Flexible Components - The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.","isPartOf":{"@id":"https:\/\/thebrandingstore.net\/#website"},"primaryImageOfPage":{"@id":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#primaryimage"},"image":{"@id":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#primaryimage"},"thumbnailUrl":"https:\/\/cloud.netlifyusercontent.com\/assets\/344dbf88-fdf9-42bb-adb4-46f01eedd629\/d8bdd509-e324-4324-9bc8-51e1b4474c8d\/1-flexible-components-css.jpg","datePublished":"2021-09-11T01:25:31+00:00","dateModified":"2021-09-11T01:25:31+00:00","author":{"@id":"https:\/\/thebrandingstore.net\/#\/schema\/person\/ab355af6cfab88bc1a4d960c257c8a38"},"breadcrumb":{"@id":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#primaryimage","url":"https:\/\/cloud.netlifyusercontent.com\/assets\/344dbf88-fdf9-42bb-adb4-46f01eedd629\/d8bdd509-e324-4324-9bc8-51e1b4474c8d\/1-flexible-components-css.jpg","contentUrl":"https:\/\/cloud.netlifyusercontent.com\/assets\/344dbf88-fdf9-42bb-adb4-46f01eedd629\/d8bdd509-e324-4324-9bc8-51e1b4474c8d\/1-flexible-components-css.jpg"},{"@type":"BreadcrumbList","@id":"https:\/\/thebrandingstore.net\/developer-decisions-for-building-flexible-components-8\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/thebrandingstore.net\/"},{"@type":"ListItem","position":2,"name":"Developer Decisions For Building Flexible Components"}]},{"@type":"WebSite","@id":"https:\/\/thebrandingstore.net\/#website","url":"https:\/\/thebrandingstore.net\/","name":"The Branding Store | Logo Design, Web Design and E-commerce specialists.| Pembroke Pines, Florida.","description":"Branding Solutions for Business and Products, Logo design, Graphic Design, Web Design, Business Cards, E-commerce, Social Media, Prints, Photography, Video and More!","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/thebrandingstore.net\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/thebrandingstore.net\/#\/schema\/person\/ab355af6cfab88bc1a4d960c257c8a38","name":"TBS","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/thebrandingstore.net\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/6c47fdedf1de6281cdaef4f87897119c?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/6c47fdedf1de6281cdaef4f87897119c?s=96&d=mm&r=g","caption":"TBS"},"url":"https:\/\/thebrandingstore.net\/author\/tbs\/"}]}},"jetpack_featured_media_url":"","_links":{"self":[{"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/posts\/29854","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/users\/6"}],"replies":[{"embeddable":true,"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/comments?post=29854"}],"version-history":[{"count":0,"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/posts\/29854\/revisions"}],"wp:attachment":[{"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/media?parent=29854"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/categories?post=29854"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/thebrandingstore.net\/wp-json\/wp\/v2\/tags?post=29854"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}