{"id":374,"date":"2024-12-24T16:12:42","date_gmt":"2024-12-24T16:12:42","guid":{"rendered":"https:\/\/bendauphinee.com\/writing\/?p=374"},"modified":"2025-01-07T17:30:09","modified_gmt":"2025-01-07T17:30:09","slug":"designing-an-app-from-scratch-part-2-wireframing-requirements","status":"publish","type":"post","link":"https:\/\/bendauphinee.com\/writing\/2024\/12\/24\/designing-an-app-from-scratch-part-2-wireframing-requirements\/","title":{"rendered":"An App From Scratch: Part 2 &#8211; Wireframing Requirements"},"content":{"rendered":"\n<p class=\"has-small-font-size\">7 minute reading time; ~1325 words<\/p>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity is-style-wide\"\/>\n\n\n\n<p>Welcome back!<\/p>\n\n\n\n<p>Today, we&#8217;re going to talk about wireframing from our requirements and stories, and exploring how talking through a wireframe helps us refine our specifications. <\/p>\n\n\n\n<p>Between the last post and this one, I&#8217;ve taken the requirements and user stories that we wrote about, and cleaned them up into a <a href=\"https:\/\/bendauphinee.com\/writing\/building-tailgunner\/project-plan-v1\/\">project plan<\/a>. The documentation is still light, and that&#8217;s intentional, as we&#8217;re focusing on a very narrow scope of work; we want to get the basic template management and editing up and running first.<\/p>\n\n\n\n<p>By the end of this post, we will have some refined wireframes and requirements, and a firm foundation for working on workflows and technical requirements!<\/p>\n\n\n\n<p class=\"has-accent-5-background-color has-background\">If you haven&#8217;t read it already, I&#8217;d suggest you start at <a href=\"https:\/\/bendauphinee.com\/writing\/2024\/12\/20\/designing-an-app-from-scratch-part-1-what-to-build\/\" data-type=\"link\" data-id=\"https:\/\/bendauphinee.com\/writing\/2024\/12\/20\/designing-an-app-from-scratch-part-1-what-to-build\/\">An App From Scratch: Part 1 \u2013 What To Build<\/a>. You can also find all the related documents and code here: <a href=\"https:\/\/bendauphinee.com\/writing\/building-tailgunner\/\">Building Tailgunner<\/a>.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Wireframes<\/h2>\n\n\n\n<p>From our initial project plan, I created wireframes based on two user stories (<a href=\"https:\/\/bendauphinee.com\/writing\/building-tailgunner\/project-plan-v1\/#us1\" data-type=\"page\" data-id=\"316\">US1<\/a>, <a href=\"https:\/\/bendauphinee.com\/writing\/building-tailgunner\/project-plan-v1\/#us2\" data-type=\"page\" data-id=\"316\">US2<\/a>) to illustrate the requirements. These wireframes are intentionally not high-fidelity, focusing on interaction points rather than exact design details.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">Initial Designs<\/h3>\n\n\n\n<p>After carefully reading both user stories, and the requirements in them, I&#8217;ve made a wireframe of both pages that cover what is needed from the requirements. Below, you can see the template list page, showing some mock information, and covering the details from our second user story.<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-scaled.jpeg\" data-rel=\"lightbox-gallery-kDcE0SJ4\" data-rl_title=\"\" data-rl_caption=\"\" title=\"\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"392\" src=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-1024x392.jpeg\" alt=\"\" class=\"wp-image-377\" srcset=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-1024x392.jpeg 1024w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-300x115.jpeg 300w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-768x294.jpeg 768w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-1536x588.jpeg 1536w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-2048x784.jpeg 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<p>You can see how the requirements translate into an actual interface, and how many unspoken requirements or ideas are included in the mockup that aren&#8217;t in the documentation itself. For example, you can see the dates aren&#8217;t absolute dates, but rather relative dates, making them easier to read and work with.<\/p>\n\n\n\n<p>This is a <strong>medium-fidelity wireframe<\/strong> (<strong>low-fidelity<\/strong> is usually sketches on paper). This level of design is detailed enough to have a conversation about the stories and how they translate, but not so detailed that you&#8217;re locked into specific design choices. Later, once we have a solid agreement, and are working toward final technical requirements, the design team (or I \ud83d\ude06) will generate <strong>high-fidelity wireframes<\/strong>, which usually have specific color and layout choices, and are much closer to the finished product.<\/p>\n\n\n\n<p>Note: the icons only have color because the design set I used had them. Overall it&#8217;s recommended to minimize color usage in a mockup like this. The idea is to figure out if we have the right elements to cover the requirements and make the tool usable, not to convey the exact design.<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing.jpeg\" data-rel=\"lightbox-gallery-kDcE0SJ4\" data-rl_title=\"\" data-rl_caption=\"\" title=\"\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"968\" src=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-1024x968.jpeg\" alt=\"\" class=\"wp-image-378\" srcset=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-1024x968.jpeg 1024w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-300x284.jpeg 300w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-768x726.jpeg 768w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-1536x1452.jpeg 1536w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-2048x1936.jpeg 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">Breaking Down The Elements<\/h3>\n\n\n\n<p>Here you can see how each story is broken down and applied to the wireframes we&#8217;ve put together. In yellow notes, you&#8217;ll see each requirement, and the wireframe elements that it matches, and in pink, you can see assumptions or mistakes we made in the designs.<\/p>\n\n\n\n<p>As part of the review and discussion around the initial wireframes, these assumptions and mistakes should be addressed, and either added to the requirements, or removed from the wireframe and noted as out of scope (this way we have a record of what we have explicitly considered and chosen to exclude).<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-Explained-scaled.jpeg\" data-rel=\"lightbox-gallery-kDcE0SJ4\" data-rl_title=\"\" data-rl_caption=\"\" title=\"\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"529\" src=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-Explained-1024x529.jpeg\" alt=\"\" class=\"wp-image-396\" srcset=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-Explained-1024x529.jpeg 1024w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-Explained-300x155.jpeg 300w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-Explained-768x397.jpeg 768w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-Explained-1536x794.jpeg 1536w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-Explained-2048x1058.jpeg 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-Explained-scaled.jpeg\" data-rel=\"lightbox-gallery-kDcE0SJ4\" data-rl_title=\"\" data-rl_caption=\"\" title=\"\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"732\" src=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-Explained-1024x732.jpeg\" alt=\"\" class=\"wp-image-397\" srcset=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-Explained-1024x732.jpeg 1024w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-Explained-300x214.jpeg 300w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-Explained-768x549.jpeg 768w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-Explained-1536x1098.jpeg 1536w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-Explained-2048x1464.jpeg 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\">Revised Requirements<\/h3>\n\n\n\n<p>Now that we&#8217;ve reviewed our requirements in context of an actual wireframe, and highlighted the talking points, it&#8217;s time to revise our requirements to better align with stakeholder expectations.<\/p>\n\n\n\n<div class=\"wp-block-group has-base-2-color has-contrast-background-color has-text-color has-background has-link-color wp-elements-dfc1a4bd4d175da9b92425082dc1a9be has-global-padding is-layout-constrained wp-container-core-group-is-layout-9597dc02 wp-block-group-is-layout-constrained\" style=\"padding-top:var(--wp--preset--spacing--10);padding-right:var(--wp--preset--spacing--10);padding-bottom:var(--wp--preset--spacing--10);padding-left:var(--wp--preset--spacing--10)\">\n<p id=\"us1\"><strong>US1 &#8211; User Story<\/strong><\/p>\n\n\n\n<p>As a business owner, I want to create a custom form template based on my needs so that I can capture specific data unique to my workflow.<\/p>\n\n\n\n<p><strong>Acceptance Criteria<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Business owners can define fields and field types (e.g., text, number, dropdown).<\/li>\n\n\n\n<li>Templates can be saved and reused.<\/li>\n<\/ul>\n\n\n\n<p><strong>Requirements<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>Template Management<\/strong>\n<ul class=\"wp-block-list\">\n<li>The system shall provide an interface for business owners to create custom form templates. Each template will represent a type of data we can manage. The system shall allow business owners to:\n<ul class=\"wp-block-list\">\n<li>Name each template.<\/li>\n\n\n\n<li>View a list of saved templates.<\/li>\n\n\n\n<li>Edit or delete saved templates.<\/li>\n\n\n\n<li>Clone template to a new one. This will copy all field definitions as well.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>Template Editing<\/strong>\n<ul class=\"wp-block-list\">\n<li><mark style=\"background-color:#9ce1ff\" class=\"has-inline-color\">Business owners shall be able to change the name or description within the edit interface.<\/mark><\/li>\n\n\n\n<li>Business owners shall be able to add, edit, and delete fields within the template.<\/li>\n\n\n\n<li>The system shall allow business owners to:\n<ul class=\"wp-block-list\">\n<li>Define field labels (what the form shows).<\/li>\n\n\n\n<li>Define field names (what the data is saved as).<\/li>\n\n\n\n<li>Specify field types (e.g., text, number, dropdown). Field types shall include at least:\n<ul class=\"wp-block-list\">\n<li>Text<\/li>\n\n\n\n<li>Number<\/li>\n\n\n\n<li>Dropdown\n<ul class=\"wp-block-list\">\n<li><mark style=\"background-color:#9ce1ff\" class=\"has-inline-color\">Add, edit, reorder, and delete options for the dropdown<\/mark><\/li>\n<\/ul>\n<\/li>\n\n\n\n<li>Date<\/li>\n\n\n\n<li>Checkbox<\/li>\n\n\n\n<li>JSON block<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><mark style=\"background-color:#9ce1ff\" class=\"has-inline-color\">Re-order the defined fields<\/mark><\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><mark style=\"background-color:#9ce1ff\" class=\"has-inline-color\">Business owners shall be able to delete or clone the template from the edit interface<\/mark>.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/div>\n\n\n\n<div class=\"wp-block-group has-base-2-color has-contrast-background-color has-text-color has-background has-link-color wp-elements-463abec0a14f5f3402e9a91ad7aa78b7 has-global-padding is-layout-constrained wp-container-core-group-is-layout-9597dc02 wp-block-group-is-layout-constrained\" style=\"padding-top:var(--wp--preset--spacing--10);padding-right:var(--wp--preset--spacing--10);padding-bottom:var(--wp--preset--spacing--10);padding-left:var(--wp--preset--spacing--10)\">\n<p id=\"us2\"><strong>US2 &#8211; User Story<\/strong><\/p>\n\n\n\n<p>As a user, I want to use a predefined form template so that I can ensure data is entered in a consistent format.<\/p>\n\n\n\n<p><strong>Acceptance Criteria<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>The user can select the form from a list of all available templates.<\/li>\n\n\n\n<li>The list of templates shows when the template was created, as well as some statistics on usage.<\/li>\n<\/ul>\n\n\n\n<p><strong>Requirements<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>The system should show a list of available templates for the user to browse.\n<ul class=\"wp-block-list\">\n<li>The list shall show:\n<ul class=\"wp-block-list\">\n<li>Template name<\/li>\n\n\n\n<li>Description<\/li>\n\n\n\n<li>Date created<\/li>\n\n\n\n<li>Date last used<\/li>\n\n\n\n<li>Number of records entered<\/li>\n\n\n\n<li>The user shall be able to select the template, and use it to enter new records.<\/li>\n\n\n\n<li><mark style=\"background-color:#9ce1ff\" class=\"has-inline-color\">The user shall be able to select the template, to see what records have been entered.<\/mark><\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/div>\n\n\n\n<p>Now that we&#8217;re done a first pass at the wireframes, and have revised our user stories, it&#8217;s become obvious that we need to break our first story up, because it&#8217;s doing too much. Here you can see how that&#8217;s been done, splitting out pieces from the original US1 to US5. We&#8217;re keeping the original numbering, because other documents may already be referencing these stories.<\/p>\n\n\n\n<div class=\"wp-block-group has-base-2-color has-contrast-background-color has-text-color has-background has-link-color wp-elements-d6c83467202f15184056244f71d8c1fd has-global-padding is-layout-constrained wp-container-core-group-is-layout-9597dc02 wp-block-group-is-layout-constrained\" style=\"padding-top:var(--wp--preset--spacing--10);padding-right:var(--wp--preset--spacing--10);padding-bottom:var(--wp--preset--spacing--10);padding-left:var(--wp--preset--spacing--10)\">\n<p id=\"us1\"><strong>US1 &#8211; User Story<\/strong><\/p>\n\n\n\n<p>As a business owner, I want to create a custom form template based on my needs so that I can capture specific data unique to my workflow.<\/p>\n\n\n\n<p><strong>Acceptance Criteria<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Business owners can define fields and field types (e.g., text, number, dropdown).<\/li>\n\n\n\n<li>Templates can be saved and reused.<\/li>\n<\/ul>\n\n\n\n<p><strong>Requirements<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Business owners shall be able to change the name or description within the edit interface.<\/li>\n\n\n\n<li>Business owners shall be able to add, edit, and delete fields within the template.<\/li>\n\n\n\n<li>The system shall allow business owners to:\n<ul class=\"wp-block-list\">\n<li>Define field labels (what the form shows).<\/li>\n\n\n\n<li>Define field names (what the data is saved as).<\/li>\n\n\n\n<li>Specify field types (e.g., text, number, dropdown). Field types shall include at least:\n<ul class=\"wp-block-list\">\n<li>Text<\/li>\n\n\n\n<li>Number<\/li>\n\n\n\n<li>Dropdown\n<ul class=\"wp-block-list\">\n<li>Add, edit, re-order, and delete options for the dropdown<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li>Date<\/li>\n\n\n\n<li>Checkbox<\/li>\n\n\n\n<li>JSON block<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li>Re-order the defined fields<\/li>\n\n\n\n<li>Business owners shall be able to delete or clone the template from the edit interface<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/div>\n\n\n\n<div class=\"wp-block-group has-base-2-color has-contrast-background-color has-text-color has-background has-link-color wp-elements-98ff9751887d371ce333b0703687afda has-global-padding is-layout-constrained wp-container-core-group-is-layout-9597dc02 wp-block-group-is-layout-constrained\" style=\"padding-top:var(--wp--preset--spacing--10);padding-right:var(--wp--preset--spacing--10);padding-bottom:var(--wp--preset--spacing--10);padding-left:var(--wp--preset--spacing--10)\">\n<p id=\"us5\"><strong>US5 &#8211; User Story<\/strong><\/p>\n\n\n\n<p>As a business owner, I want to list, create, edit, and delete custom form templates based on my needs so that I can capture specific data unique to my workflow.<\/p>\n\n\n\n<p><strong>Acceptance Criteria<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Business owners can browse a list of active templates.<\/li>\n\n\n\n<li>Templates can be managed via the list interface, without having to use the edit interface.<\/li>\n<\/ul>\n\n\n\n<p><strong>Requirements<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>The system shall provide an interface for business owners to create custom form templates. Each template will represent a type of data we can manage. The system shall allow business owners to:\n<ul class=\"wp-block-list\">\n<li>Name each template.<\/li>\n\n\n\n<li>View a list of saved templates.<\/li>\n\n\n\n<li>Edit or delete saved templates.<\/li>\n\n\n\n<li>Clone template to a new one. This will copy all field definitions as well.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/div>\n\n\n\n<p>Below are the updated wireframes, based on the updates we made to the stories above.<\/p>\n\n\n\n<figure class=\"wp-block-gallery has-nested-images columns-default is-cropped wp-block-gallery-1 is-layout-flex wp-block-gallery-is-layout-flex\">\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-v2-Explained-scaled.jpeg\" data-rel=\"lightbox-gallery-kDcE0SJ4\" data-rl_title=\"\" data-rl_caption=\"\" title=\"\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"526\" data-id=\"424\" src=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-v2-Explained-1024x526.jpeg\" alt=\"\" class=\"wp-image-424\" srcset=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-v2-Explained-1024x526.jpeg 1024w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-v2-Explained-300x154.jpeg 300w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-v2-Explained-768x394.jpeg 768w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-v2-Explained-1536x788.jpeg 1536w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-List-v2-Explained-2048x1051.jpeg 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n\n\n\n<figure class=\"wp-block-image size-large\"><a href=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-v2-Explained-scaled.jpeg\" data-rel=\"lightbox-gallery-kDcE0SJ4\" data-rl_title=\"\" data-rl_caption=\"\" title=\"\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"542\" data-id=\"423\" src=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-v2-Explained-1024x542.jpeg\" alt=\"\" class=\"wp-image-423\" srcset=\"https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-v2-Explained-1024x542.jpeg 1024w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-v2-Explained-300x159.jpeg 300w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-v2-Explained-768x406.jpeg 768w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-v2-Explained-1536x813.jpeg 1536w, https:\/\/bendauphinee.com\/writing\/wp-content\/uploads\/2024\/12\/Tailgunner-Template-List-Template-Editing-v2-Explained-2048x1084.jpeg 2048w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/a><\/figure>\n<\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">Wrapping It Up<\/h2>\n\n\n\n<p>As you can see from the discussion around just two stories and two wireframes, there is a lot of material to explore. In this post, we worked through the refinement process, and ended up with three more fleshed out stories, and some good wireframes to guide discussions around workflow and technical requirements.<\/p>\n\n\n\n<p>Did I miss something in my stories or wireframe? Share your thoughts in the comments below!<\/p>\n\n\n\n<p>Thanks for taking the time to read this, and stay tuned for the next part: <a href=\"https:\/\/bendauphinee.com\/writing\/2024\/12\/27\/designing-an-app-from-scratch-part-3-workflows\/\" data-type=\"post\" data-id=\"277\">documenting and validating workflows<\/a>.<\/p>\n\n\n\n<p>Cheers!<\/p>\n","protected":false},"excerpt":{"rendered":"<p>7 minute reading time; ~1325 words Welcome back! Today, we&#8217;re going to talk about wireframing from our requirements and stories, and exploring how talking through a wireframe helps us refine our specifications. Between the last post and this one, I&#8217;ve taken the requirements and user stories that we wrote about, and cleaned them up into [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[17,21],"tags":[],"class_list":["post-374","post","type-post","status-publish","format-standard","hentry","category-business-development","category-software-engineering"],"_links":{"self":[{"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/posts\/374","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/comments?post=374"}],"version-history":[{"count":36,"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/posts\/374\/revisions"}],"predecessor-version":[{"id":666,"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/posts\/374\/revisions\/666"}],"wp:attachment":[{"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/media?parent=374"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/categories?post=374"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/bendauphinee.com\/writing\/wp-json\/wp\/v2\/tags?post=374"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}