brief 1.10.1 → 1.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile.lock +1 -1
- data/README.md +57 -0
- data/apps/blueprint/{example/brief.rb → documentation/concept.md} +0 -0
- data/apps/blueprint/documentation/feature.md +4 -0
- data/apps/blueprint/documentation/milestone.md +1 -1
- data/apps/blueprint/documentation/mockup.md +8 -0
- data/apps/blueprint/documentation/page.md +5 -0
- data/apps/blueprint/documentation/persona.md +10 -0
- data/apps/blueprint/documentation/project.md +6 -0
- data/apps/blueprint/documentation/release.md +6 -0
- data/apps/blueprint/documentation/roadmap.md +6 -0
- data/apps/blueprint/documentation/sitemap.md +6 -0
- data/apps/blueprint/documentation/wireframe.md +7 -1
- data/apps/blueprint/examples/concept.md +16 -0
- data/apps/blueprint/examples/diagram.md +32 -0
- data/apps/blueprint/examples/epic.md +32 -0
- data/apps/blueprint/examples/feature.md +25 -0
- data/apps/blueprint/examples/milestone.md +12 -0
- data/apps/blueprint/examples/mockup.md +32 -0
- data/apps/blueprint/examples/outline.md +26 -0
- data/apps/blueprint/examples/page.md +10 -0
- data/apps/blueprint/examples/persona.md +11 -0
- data/apps/blueprint/examples/project.md +31 -0
- data/apps/blueprint/examples/release.md +28 -0
- data/apps/blueprint/examples/roadmap.md +25 -0
- data/apps/blueprint/examples/sitemap.md +19 -0
- data/apps/blueprint/examples/wireframe.md +32 -0
- data/apps/blueprint/models/concept.rb +14 -0
- data/apps/blueprint/models/mockup.rb +15 -0
- data/apps/blueprint/models/persona.rb +0 -1
- data/apps/blueprint/models/wireframe.rb +2 -0
- data/lib/brief/model/definition.rb +13 -2
- data/lib/brief/model.rb +42 -6
- data/lib/brief/version.rb +1 -1
- metadata +21 -5
- data/apps/blueprint/documentation/user_story.md +0 -1
- data/apps/blueprint/example/docs/diagrams/example-diagram.md +0 -0
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA1:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 84967b7efa46a60164d94b566b050555cadfef37
         | 
| 4 | 
            +
              data.tar.gz: 0a590d06c6fb630aa91697c3c1422858565b0e77
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 60e74d585fe255f2d1cc4ed0bd944abb10be2858e3d68e3ccdd848cca455aa677fd24eef39bccd298f536f248bd9666d2ca30df3d10592f8531f3c9dd5a5446d
         | 
| 7 | 
            +
              data.tar.gz: acf778f8a01397e6b42c6a37621b05f4de4203f1cdeccd706d51f93c30bd7c77ddf41234c9ef0122f4f30510ab09528ebd071c5180df53eae32c6471825b85e7
         | 
    
        data/Gemfile.lock
    CHANGED
    
    
    
        data/README.md
    CHANGED
    
    | @@ -105,3 +105,60 @@ That is powerful stuff. | |
| 105 105 | 
             
            gem install brief
         | 
| 106 106 | 
             
            brief --help
         | 
| 107 107 | 
             
            ```
         | 
| 108 | 
            +
             | 
| 109 | 
            +
            ### Structure of a Briefcase
         | 
| 110 | 
            +
             | 
| 111 | 
            +
            - `docs/` contain diferent markdown files with YAML frontmatter.
         | 
| 112 | 
            +
            - `models/` define your own model classes.
         | 
| 113 | 
            +
            - `data/` dump data sources as JSON in here to use them in the renderer 
         | 
| 114 | 
            +
            - `assets/` you can include / reference assets like PNG or SVG images
         | 
| 115 | 
            +
            - `brief.rb` the brief config file
         | 
| 116 | 
            +
             | 
| 117 | 
            +
            ### Servers
         | 
| 118 | 
            +
             | 
| 119 | 
            +
            Brief ships with a number of different "servers" which can sit on top of
         | 
| 120 | 
            +
            a single `briefcase` or a folder with a bunch of different briefcases.
         | 
| 121 | 
            +
             | 
| 122 | 
            +
            These servers provide an interface for common things like searching a
         | 
| 123 | 
            +
            collection of documents, rendering documents, or adding,editing,removing
         | 
| 124 | 
            +
            documents.
         | 
| 125 | 
            +
             | 
| 126 | 
            +
            Currently there is a standard REST interface, and a Websockets
         | 
| 127 | 
            +
            interface.
         | 
| 128 | 
            +
             | 
| 129 | 
            +
            ### Apps
         | 
| 130 | 
            +
             | 
| 131 | 
            +
            The brief gem ships with a couple of `apps`.  These `apps` are
         | 
| 132 | 
            +
            collections of models and represent a sample application you can use.
         | 
| 133 | 
            +
             | 
| 134 | 
            +
            You can use an `app` by saying so in your config file:
         | 
| 135 | 
            +
             | 
| 136 | 
            +
            ```ruby
         | 
| 137 | 
            +
            # brief.rb
         | 
| 138 | 
            +
            use "blueprint" # => $BRIEF_GEM/apps/blueprint
         | 
| 139 | 
            +
            ```
         | 
| 140 | 
            +
             | 
| 141 | 
            +
            ## Other neat features (TODO)
         | 
| 142 | 
            +
             | 
| 143 | 
            +
            ### Special Link & Image Tags
         | 
| 144 | 
            +
             | 
| 145 | 
            +
            - You can include the content from other documents pretty easily
         | 
| 146 | 
            +
             | 
| 147 | 
            +
              ```markdown
         | 
| 148 | 
            +
              [include:content](path=feature.html.md)
         | 
| 149 | 
            +
              ```
         | 
| 150 | 
            +
             | 
| 151 | 
            +
            - You can create links to other documents pretty easily
         | 
| 152 | 
            +
             | 
| 153 | 
            +
              ```
         | 
| 154 | 
            +
              [link:title](path=feature.html.md)
         | 
| 155 | 
            +
              ```
         | 
| 156 | 
            +
             | 
| 157 | 
            +
              This will find the document at the specified path, and link to it with
         | 
| 158 | 
            +
              the title attribute from that document
         | 
| 159 | 
            +
             | 
| 160 | 
            +
            - You can inline SVG assets pretty easily:
         | 
| 161 | 
            +
             | 
| 162 | 
            +
              ```markdown
         | 
| 163 | 
            +
              
         | 
| 164 | 
            +
              ```
         | 
| 
            File without changes
         | 
| @@ -0,0 +1,8 @@ | |
| 1 | 
            +
            #### Mockups
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Mockups are notes that acompany a screen or user interface mockup.
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            Mockups can include data about annotations (like x,y coordinates) which will map up with the headings of the document.
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            This is a good way to display annotated images and talk about the
         | 
| 8 | 
            +
            integration points between the User Interface and the domain model.
         | 
| @@ -1 +1,11 @@ | |
| 1 1 | 
             
            #### Personas
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Personas are used to help understand the different audiences for the software.  
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            Persona models can be used in a lot of clever ways, beyond just
         | 
| 6 | 
            +
            describing who they are.
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            In a set of features, there will be user stories.  User stories have a predictable structure, and because of this it is possible to query all of the user stories and filter them by persona.  
         | 
| 9 | 
            +
             | 
| 10 | 
            +
            This gives us a view into the product design development that is
         | 
| 11 | 
            +
            centered around a specific persona, which can be a very useful way to look at a set of features.
         | 
| @@ -1 +1,7 @@ | |
| 1 1 | 
             
            #### Projects
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Any large software effort will consist of a Software Project,
         | 
| 4 | 
            +
            sometimes but not always represented by a single codebase or git
         | 
| 5 | 
            +
            repository.
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            The blueprint itself will have many epics, features, user stories.  It will have mockups, wireframes, sitemaps.  There will be domain concepts to talk about, personas to consider, etc.  Projects are a good way to slice these up, and summarize things.
         | 
| @@ -1 +1,7 @@ | |
| 1 1 | 
             
            #### Releases
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Releases are broadcast style message that accompany an important
         | 
| 4 | 
            +
             deployment of a software project to a staging, production, or client environment.
         | 
| 5 | 
            +
             | 
| 6 | 
            +
             Releases can be used to generate emails, reports, invoices, slack
         | 
| 7 | 
            +
             channel announcements, whatever.
         | 
| @@ -1 +1,7 @@ | |
| 1 1 | 
             
            #### Sitemaps
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Sitemaps should be accompanied by an ideally clickable SVG diagram.  
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            Sitemaps are used to describe the different navigation elements, and screens that will make up a website or an application.
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            Each screen can be associated with a Wireframe or Mockup document.
         | 
| @@ -1 +1,7 @@ | |
| 1 | 
            -
             | 
| 1 | 
            +
            ##### Wireframes
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Mockups are notes that acompany a screen or user interface mockup.
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            Mockups can include data about annotations (like x,y coordinates) which will map up with the headings of the document.
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            This is a good way to display annotated wireframes and talk about the integration points between the User Interface and the domain model, or just provide explanation about the wireframe itself.
         | 
| @@ -0,0 +1,16 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: concept
         | 
| 3 | 
            +
            title: Brief Document
         | 
| 4 | 
            +
            ---
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            The Brief Document is a markdown file with YAML frontmatter that gets turned into document metadata.  These documents are the primary user interface for the software.
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            # Relationships
         | 
| 9 | 
            +
             | 
| 10 | 
            +
            ## Brief Model
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            Based on the folder the document is in, or based on the type specified in the YAML frontmatter, a document will map to a `Brief Model`
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            ## Briefcase
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            Every document should belong to a briefcase.  The briefcase is where the document relates to other documents, and where it gets its model rules and behaviors from.
         | 
| @@ -0,0 +1,32 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: diagram
         | 
| 3 | 
            +
            title: Anatomy of a Brief Model
         | 
| 4 | 
            +
            attachments:
         | 
| 5 | 
            +
              - diagrams/anatomy-of-a-brief-model.svg
         | 
| 6 | 
            +
            annotations:
         | 
| 7 | 
            +
              "Annotation One": 
         | 
| 8 | 
            +
                x: 400
         | 
| 9 | 
            +
                y: 20
         | 
| 10 | 
            +
              "Annotation Two":
         | 
| 11 | 
            +
                x: 450
         | 
| 12 | 
            +
                y: 20
         | 
| 13 | 
            +
            ---
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            
         | 
| 16 | 
            +
             | 
| 17 | 
            +
            Notice how we're inlining the SVG diagram.  Pretty neat.
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            Using javascript to join the elements of the SVG to your writing is a really powerful technique for combining graphics and writing
         | 
| 20 | 
            +
            together in a scriptable way!
         | 
| 21 | 
            +
             | 
| 22 | 
            +
            # Annotations
         | 
| 23 | 
            +
             | 
| 24 | 
            +
            ## Annotation One
         | 
| 25 | 
            +
             | 
| 26 | 
            +
            This can be displayed in context along with the annotation bubble for the diagram.
         | 
| 27 | 
            +
             | 
| 28 | 
            +
            ## Annotation Two
         | 
| 29 | 
            +
             | 
| 30 | 
            +
            This can also be displayed in context.
         | 
| 31 | 
            +
             | 
| 32 | 
            +
             | 
| @@ -0,0 +1,32 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: epic
         | 
| 3 | 
            +
            title: Apps Repositories
         | 
| 4 | 
            +
            ---
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # Apps Repositories
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            The Brief project has the concept of an `app`.  An `app` is a
         | 
| 9 | 
            +
            collection of models that represent different templates for
         | 
| 10 | 
            +
            documents that you can write which can then be processed by the brief `app` in question and be used to do specific things.
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            # Features
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            ## App Browsing
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            - As a **writer** I would like to **view the available brief apps** so that I can **take advantage of creative writing automation ideas contributed by others**
         | 
| 17 | 
            +
             | 
| 18 | 
            +
            - As a **programmer** I would like to **publish my app to the
         | 
| 19 | 
            +
              community repository** so that I can **share my inventions with
         | 
| 20 | 
            +
              others**
         | 
| 21 | 
            +
             | 
| 22 | 
            +
            ## Model Documentation
         | 
| 23 | 
            +
             | 
| 24 | 
            +
            - As a **writer** I would like to **understand the way my writing can be turned into data** so that I can **present my writing in more compelling forms** 
         | 
| 25 | 
            +
             | 
| 26 | 
            +
            - As a **programmer** I would like to **document the model
         | 
| 27 | 
            +
              behavior** so that I can **provide a more usable interface to the writer**
         | 
| 28 | 
            +
             | 
| 29 | 
            +
            ## Example Documents
         | 
| 30 | 
            +
             | 
| 31 | 
            +
            - As a **writer** I would like to **see examples of other
         | 
| 32 | 
            +
              documents** so that I can **conform to the document structure**
         | 
| @@ -0,0 +1,25 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: feature
         | 
| 3 | 
            +
            title: App Browsing
         | 
| 4 | 
            +
            epic: Apps Repositories
         | 
| 5 | 
            +
            ---
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            # App Browsing
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            A briefcase can be configured to use an existing "app" instead of defining all of the models and such every time.
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            These apps can be shared over github, and can be browsed by others so that they can use the models themselves.
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            # User Stories
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            - As a **writer** I would like to **view the available brief apps** so that I can **take advantage of creative writing automation ideas contributed by others**
         | 
| 16 | 
            +
             | 
| 17 | 
            +
            - As a **programmer** I would like to **publish my app to the
         | 
| 18 | 
            +
              community repository** so that I can **share my inventions with
         | 
| 19 | 
            +
              others**
         | 
| 20 | 
            +
             | 
| 21 | 
            +
            # Wireframes
         | 
| 22 | 
            +
             | 
| 23 | 
            +
            - App Browser. Search Apps View
         | 
| 24 | 
            +
            - App Browser. App Detail View 
         | 
| 25 | 
            +
             | 
| @@ -0,0 +1,32 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: mockup
         | 
| 3 | 
            +
            title: Anatomy of a Brief Model
         | 
| 4 | 
            +
            attachments:
         | 
| 5 | 
            +
              - diagrams/anatomy-of-a-brief-model.svg
         | 
| 6 | 
            +
            annotations:
         | 
| 7 | 
            +
              "Annotation One": 
         | 
| 8 | 
            +
                x: 400
         | 
| 9 | 
            +
                y: 20
         | 
| 10 | 
            +
              "Annotation Two":
         | 
| 11 | 
            +
                x: 450
         | 
| 12 | 
            +
                y: 20
         | 
| 13 | 
            +
            ---
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            
         | 
| 16 | 
            +
             | 
| 17 | 
            +
            Notice how we're inlining the SVG diagram.  Pretty neat.
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            Using javascript to join the elements of the SVG to your writing is a really powerful technique for combining graphics and writing
         | 
| 20 | 
            +
            together in a scriptable way!
         | 
| 21 | 
            +
             | 
| 22 | 
            +
            # Annotations
         | 
| 23 | 
            +
             | 
| 24 | 
            +
            ## Annotation One
         | 
| 25 | 
            +
             | 
| 26 | 
            +
            This can be displayed in context along with the annotation bubble for the diagram.
         | 
| 27 | 
            +
             | 
| 28 | 
            +
            ## Annotation Two
         | 
| 29 | 
            +
             | 
| 30 | 
            +
            This can also be displayed in context.
         | 
| 31 | 
            +
             | 
| 32 | 
            +
             | 
| @@ -0,0 +1,26 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: outline
         | 
| 3 | 
            +
            title: Table of Contents
         | 
| 4 | 
            +
            ---
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # Table of Contents 
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            - Example Documents
         | 
| 9 | 
            +
              - [link:title](path=concept)
         | 
| 10 | 
            +
             | 
| 11 | 
            +
                [include:summary](path=concept)
         | 
| 12 | 
            +
             | 
| 13 | 
            +
              - [link:title](path=diagram)
         | 
| 14 | 
            +
             | 
| 15 | 
            +
              - [link:title](path=epic)
         | 
| 16 | 
            +
             | 
| 17 | 
            +
            - Section One
         | 
| 18 | 
            +
              - Section One A
         | 
| 19 | 
            +
              - Section One B
         | 
| 20 | 
            +
              - Section One C
         | 
| 21 | 
            +
            - Section Two
         | 
| 22 | 
            +
              - Section Two A
         | 
| 23 | 
            +
              - Section Two B
         | 
| 24 | 
            +
              - Section Two C
         | 
| 25 | 
            +
             | 
| 26 | 
            +
             | 
| @@ -0,0 +1,11 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: persona
         | 
| 3 | 
            +
            title: Brief Writer
         | 
| 4 | 
            +
            ---
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            THe Brief Writer wants to be able to get more out of the energy they
         | 
| 7 | 
            +
            spend writing.  By agreeing to follow a certain structure and
         | 
| 8 | 
            +
            organizational template, the writer can take advantage of models that
         | 
| 9 | 
            +
            help turn the document into an active software object that can be used
         | 
| 10 | 
            +
            to power all sorts of different software powered workflows or
         | 
| 11 | 
            +
            presentation tools.
         | 
| @@ -0,0 +1,31 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: project
         | 
| 3 | 
            +
            title: Brief Writing Toolkit
         | 
| 4 | 
            +
            status: in progress
         | 
| 5 | 
            +
            ---
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            # Brief Writing Toolkit
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            This is a description of the project.
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            This document could very easily be broken apart into much smaller,
         | 
| 12 | 
            +
            more focused documents, and indeed it should be.  
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            When starting a blueprint, you might want to just start at the project
         | 
| 15 | 
            +
            level since often you will know ahead of time how you might structure
         | 
| 16 | 
            +
            the solution by project.
         | 
| 17 | 
            +
             | 
| 18 | 
            +
            ## Dependencies
         | 
| 19 | 
            +
             | 
| 20 | 
            +
            - it depends on this
         | 
| 21 | 
            +
            - it depends on this too
         | 
| 22 | 
            +
            - a lot of dependencies. ugh.
         | 
| 23 | 
            +
             | 
| 24 | 
            +
            # Sitemap
         | 
| 25 | 
            +
             | 
| 26 | 
            +
            
         | 
| 27 | 
            +
             | 
| 28 | 
            +
            # Personas
         | 
| 29 | 
            +
             | 
| 30 | 
            +
            ## Persona One
         | 
| 31 | 
            +
            ## Persona Two
         | 
| @@ -0,0 +1,28 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: release
         | 
| 3 | 
            +
            title: Release 1
         | 
| 4 | 
            +
            status: delivered
         | 
| 5 | 
            +
            delivered_at: 2015-06-01
         | 
| 6 | 
            +
            environment: staging
         | 
| 7 | 
            +
            ---
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            # Release 1
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            Congratulations, we almost made it.
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            Here are the features we delivered across the various projects.  We
         | 
| 14 | 
            +
            need your help testing and reviewing them. 
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            ## Some Epic Title
         | 
| 17 | 
            +
             | 
| 18 | 
            +
            - Feature one
         | 
| 19 | 
            +
            - Feature two
         | 
| 20 | 
            +
            - Feature three
         | 
| 21 | 
            +
             | 
| 22 | 
            +
            ## Some Other Epic Title
         | 
| 23 | 
            +
             | 
| 24 | 
            +
            - Feature a
         | 
| 25 | 
            +
            - Feature b
         | 
| 26 | 
            +
            - Feature c
         | 
| 27 | 
            +
             | 
| 28 | 
            +
            Please test these features out.
         | 
| @@ -0,0 +1,25 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: roadmap
         | 
| 3 | 
            +
            title: Brief Writing Desktop App 
         | 
| 4 | 
            +
            ---
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            # Milestones
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            ## Release 1
         | 
| 9 | 
            +
             | 
| 10 | 
            +
            Here we should be able to do x,y,z.  We will need to coordinate with
         | 
| 11 | 
            +
            the marketing people, and have some things drawn up by the lawyers.
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            Here is what we expect feature wise
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            ### Some Epic Title
         | 
| 16 | 
            +
             | 
| 17 | 
            +
            We need these features.
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            ### Another Epic Title
         | 
| 20 | 
            +
             | 
| 21 | 
            +
            We also need these features.
         | 
| 22 | 
            +
             | 
| 23 | 
            +
            ## Release 2
         | 
| 24 | 
            +
             | 
| 25 | 
            +
            By this point we should expect to be having actual users.
         | 
| @@ -0,0 +1,32 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            type: wireframe
         | 
| 3 | 
            +
            title: Anatomy of a Brief Model
         | 
| 4 | 
            +
            attachments:
         | 
| 5 | 
            +
              - diagrams/anatomy-of-a-brief-model.svg
         | 
| 6 | 
            +
            annotations:
         | 
| 7 | 
            +
              "Annotation One": 
         | 
| 8 | 
            +
                x: 400
         | 
| 9 | 
            +
                y: 20
         | 
| 10 | 
            +
              "Annotation Two":
         | 
| 11 | 
            +
                x: 450
         | 
| 12 | 
            +
                y: 20
         | 
| 13 | 
            +
            ---
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            
         | 
| 16 | 
            +
             | 
| 17 | 
            +
            Notice how we're inlining the SVG diagram.  Pretty neat.
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            Using javascript to join the elements of the SVG to your writing is a really powerful technique for combining graphics and writing
         | 
| 20 | 
            +
            together in a scriptable way!
         | 
| 21 | 
            +
             | 
| 22 | 
            +
            # Annotations
         | 
| 23 | 
            +
             | 
| 24 | 
            +
            ## Annotation One
         | 
| 25 | 
            +
             | 
| 26 | 
            +
            This can be displayed in context along with the annotation bubble for the diagram.
         | 
| 27 | 
            +
             | 
| 28 | 
            +
            ## Annotation Two
         | 
| 29 | 
            +
             | 
| 30 | 
            +
            This can also be displayed in context.
         | 
| 31 | 
            +
             | 
| 32 | 
            +
             | 
| @@ -9,7 +9,10 @@ module Brief | |
| 9 9 | 
             
                              :defined_actions,
         | 
| 10 10 | 
             
                              :section_mappings,
         | 
| 11 11 | 
             
                              :template_body,
         | 
| 12 | 
            -
                              :example_body
         | 
| 12 | 
            +
                              :example_body,
         | 
| 13 | 
            +
                              :documentation_path,
         | 
| 14 | 
            +
                              :example_path,
         | 
| 15 | 
            +
                              :template_path
         | 
| 13 16 |  | 
| 14 17 | 
             
                def initialize(name, options = {})
         | 
| 15 18 | 
             
                  @name             = name
         | 
| @@ -66,10 +69,18 @@ module Brief | |
| 66 69 | 
             
                # TODO
         | 
| 67 70 | 
             
                # There is probably a way to inspect the filename of the code calling you
         | 
| 68 71 | 
             
                # which would be a better way of handling this that doesn't require
         | 
| 69 | 
            -
                def defined_in(filename=nil)
         | 
| 72 | 
            +
                def defined_in(filename=nil, options={})
         | 
| 70 73 | 
             
                  if filename
         | 
| 71 74 | 
             
                    filename = Pathname(filename)
         | 
| 72 75 | 
             
                    @doc_options[:defined_in] = filename
         | 
| 76 | 
            +
             | 
| 77 | 
            +
                    self.example_path ||= options.fetch(:example_path) do
         | 
| 78 | 
            +
                      filename.parent.join("..","examples", filename.basename.to_s.gsub('.rb','.md'))
         | 
| 79 | 
            +
                    end
         | 
| 80 | 
            +
             | 
| 81 | 
            +
                    self.documentation_path ||= options.fetch(:documentation_path) do
         | 
| 82 | 
            +
                      filename.parent.join("..","documentation", filename.basename.to_s.gsub('.rb','.md'))
         | 
| 83 | 
            +
                    end
         | 
| 73 84 | 
             
                  end
         | 
| 74 85 |  | 
| 75 86 | 
             
                  @doc_options[:defined_in]
         | 
    
        data/lib/brief/model.rb
    CHANGED
    
    | @@ -183,6 +183,28 @@ module Brief | |
| 183 183 | 
             
                    end
         | 
| 184 184 | 
             
                  end
         | 
| 185 185 |  | 
| 186 | 
            +
                  def example_content
         | 
| 187 | 
            +
                    if example_path && example_path.exist?
         | 
| 188 | 
            +
                      return example_path.read.to_s
         | 
| 189 | 
            +
                    end
         | 
| 190 | 
            +
             | 
| 191 | 
            +
                    definition.example_body.to_s
         | 
| 192 | 
            +
                  end
         | 
| 193 | 
            +
             | 
| 194 | 
            +
                  def template_content
         | 
| 195 | 
            +
                    if template_path && template_path.exist?
         | 
| 196 | 
            +
                      return template_path.read.to_s
         | 
| 197 | 
            +
                    end
         | 
| 198 | 
            +
             | 
| 199 | 
            +
                    definition.template_body.to_s
         | 
| 200 | 
            +
                  end
         | 
| 201 | 
            +
             | 
| 202 | 
            +
                  def documentation_content
         | 
| 203 | 
            +
                    if documentation_path && documentation_path.exist?
         | 
| 204 | 
            +
                      return documentation_path.read.to_s
         | 
| 205 | 
            +
                    end
         | 
| 206 | 
            +
                  end
         | 
| 207 | 
            +
             | 
| 186 208 | 
             
                  def to_schema
         | 
| 187 209 | 
             
                    {
         | 
| 188 210 | 
             
                      schema: {
         | 
| @@ -196,8 +218,8 @@ module Brief | |
| 196 218 | 
             
                      name: name,
         | 
| 197 219 | 
             
                      group: name.to_s.pluralize,
         | 
| 198 220 | 
             
                      actions: defined_actions,
         | 
| 199 | 
            -
                      example:  | 
| 200 | 
            -
                      template:  | 
| 221 | 
            +
                      example: example_content,
         | 
| 222 | 
            +
                      template: template_content,
         | 
| 201 223 | 
             
                      urls: {
         | 
| 202 224 | 
             
                        browse_url: "browse/#{ type_alias.to_s.pluralize }",
         | 
| 203 225 | 
             
                        schema_url: "schema/#{ type_alias }"
         | 
| @@ -305,14 +327,28 @@ module Brief | |
| 305 327 | 
             
                    definition.send(:defined_in, *args)
         | 
| 306 328 | 
             
                  end
         | 
| 307 329 |  | 
| 330 | 
            +
                  def template_path(*args)
         | 
| 331 | 
            +
                    definition.send(:template_path=, *args) unless args.empty?
         | 
| 332 | 
            +
                    definition.send(:template_path)
         | 
| 333 | 
            +
                  end
         | 
| 334 | 
            +
             | 
| 335 | 
            +
                  def example_path(*args)
         | 
| 336 | 
            +
                    definition.send(:example_path=, *args) unless args.empty?
         | 
| 337 | 
            +
                    definition.send(:example_path)
         | 
| 338 | 
            +
                  end
         | 
| 339 | 
            +
             | 
| 340 | 
            +
                  def documentation_path(*args)
         | 
| 341 | 
            +
                    definition.send(:documentation_path=, *args) unless args.empty?
         | 
| 342 | 
            +
                    definition.send(:documentation_path)
         | 
| 343 | 
            +
                  end
         | 
| 344 | 
            +
             | 
| 308 345 | 
             
                  def method_missing(meth, *args, &block)
         | 
| 309 | 
            -
                    # these methods  | 
| 310 | 
            -
                    #  | 
| 346 | 
            +
                    # these methods have a special effect on the behavior of the
         | 
| 347 | 
            +
                    # model definition.  we need to make sure we call finalize after
         | 
| 348 | 
            +
                    # them
         | 
| 311 349 | 
             
                    if %w(meta content template example actions helpers).include?(meth.to_s)
         | 
| 312 350 | 
             
                      definition.send(meth, *args, &block)
         | 
| 313 351 | 
             
                      finalize
         | 
| 314 | 
            -
                    # these methods allow the model class to inspect itself and report
         | 
| 315 | 
            -
                    # whatever methods and actions are defined on the model class
         | 
| 316 352 | 
             
                    elsif %w(defined_helper_methods defined_actions).include?(meth.to_s)
         | 
| 317 353 | 
             
                      definition.send(meth)
         | 
| 318 354 | 
             
                    elsif meth.to_s.match(/^on_(.*)_change$/)
         | 
    
        data/lib/brief/version.rb
    CHANGED
    
    
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: brief
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 1. | 
| 4 | 
            +
              version: 1.11.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Jonathan Soeder
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2015-05- | 
| 11 | 
            +
            date: 2015-05-28 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: hashie
         | 
| @@ -289,9 +289,12 @@ files: | |
| 289 289 | 
             
            - Rakefile
         | 
| 290 290 | 
             
            - TUTORIAL.md
         | 
| 291 291 | 
             
            - apps/blueprint/config.rb
         | 
| 292 | 
            +
            - apps/blueprint/documentation/concept.md
         | 
| 292 293 | 
             
            - apps/blueprint/documentation/diagram.md
         | 
| 293 294 | 
             
            - apps/blueprint/documentation/epic.md
         | 
| 295 | 
            +
            - apps/blueprint/documentation/feature.md
         | 
| 294 296 | 
             
            - apps/blueprint/documentation/milestone.md
         | 
| 297 | 
            +
            - apps/blueprint/documentation/mockup.md
         | 
| 295 298 | 
             
            - apps/blueprint/documentation/outline.md
         | 
| 296 299 | 
             
            - apps/blueprint/documentation/page.md
         | 
| 297 300 | 
             
            - apps/blueprint/documentation/persona.md
         | 
| @@ -299,14 +302,27 @@ files: | |
| 299 302 | 
             
            - apps/blueprint/documentation/release.md
         | 
| 300 303 | 
             
            - apps/blueprint/documentation/roadmap.md
         | 
| 301 304 | 
             
            - apps/blueprint/documentation/sitemap.md
         | 
| 302 | 
            -
            - apps/blueprint/documentation/user_story.md
         | 
| 303 305 | 
             
            - apps/blueprint/documentation/wireframe.md
         | 
| 304 | 
            -
            - apps/blueprint/ | 
| 305 | 
            -
            - apps/blueprint/ | 
| 306 | 
            +
            - apps/blueprint/examples/concept.md
         | 
| 307 | 
            +
            - apps/blueprint/examples/diagram.md
         | 
| 308 | 
            +
            - apps/blueprint/examples/epic.md
         | 
| 309 | 
            +
            - apps/blueprint/examples/feature.md
         | 
| 310 | 
            +
            - apps/blueprint/examples/milestone.md
         | 
| 311 | 
            +
            - apps/blueprint/examples/mockup.md
         | 
| 312 | 
            +
            - apps/blueprint/examples/outline.md
         | 
| 313 | 
            +
            - apps/blueprint/examples/page.md
         | 
| 314 | 
            +
            - apps/blueprint/examples/persona.md
         | 
| 315 | 
            +
            - apps/blueprint/examples/project.md
         | 
| 316 | 
            +
            - apps/blueprint/examples/release.md
         | 
| 317 | 
            +
            - apps/blueprint/examples/roadmap.md
         | 
| 318 | 
            +
            - apps/blueprint/examples/sitemap.md
         | 
| 319 | 
            +
            - apps/blueprint/examples/wireframe.md
         | 
| 320 | 
            +
            - apps/blueprint/models/concept.rb
         | 
| 306 321 | 
             
            - apps/blueprint/models/diagram.rb
         | 
| 307 322 | 
             
            - apps/blueprint/models/epic.rb
         | 
| 308 323 | 
             
            - apps/blueprint/models/feature.rb
         | 
| 309 324 | 
             
            - apps/blueprint/models/milestone.rb
         | 
| 325 | 
            +
            - apps/blueprint/models/mockup.rb
         | 
| 310 326 | 
             
            - apps/blueprint/models/outline.rb
         | 
| 311 327 | 
             
            - apps/blueprint/models/page.rb
         | 
| 312 328 | 
             
            - apps/blueprint/models/persona.rb
         | 
| @@ -1 +0,0 @@ | |
| 1 | 
            -
            #### Features
         | 
| 
            File without changes
         |