We are hiring

Overview

This document contains normative guidelines for web applications built by the Product Development department of Fellowship Technologies, as specified by the UX team. It is to be readily available to anyone who wishes to check the iterative progress of our best practices.

Design Patterns

The primary benefit of using design patterns is that we are not constantly re-inventing the wheel when coming up with the general functionality of a site or web application. Another benefit is that these design patters often mirror or mimic other similar functionality found throughout the rest of the Internet. This allows users to feel more comfortable and familiar with a web application, rather than having to learn a foreign system.

Design patterns can help applications be understood quicker. They can be thought of in terms of various automobiles. Though they differ, the steering wheel and pedals are readily familiar to any licensed driver.


Color Swatches

These are the colors that we use in various capacities throughout the Fellowship One interface, as well as the branding of our groups app entitled InFellowship. While the palette is not strictly limited to this particular range, we have found these hues to be a good fit. Their hex values are: #EEEEE0, #DDDDD0, #BBBBB0, #FF9900, #6699CC, #336699, #669933, #336600, #993333, #663333, #996633, #554433.


Dynamic Interfaces

Add Another

Problem The user needs to add another piece of data, akin to the information s/he is currently viewing.
Pattern An add link is placed below the list of data. Delete links accompany each newly added item.
Result This allows the user to add new data, without having to visit a new page for data entry.

Confirmation

Problem The user needs to be informed when an action was accomplished successfully.
Pattern A dynamic message overlay appears for a few seconds, then quietly animates out of sight.
Result This gives brief feedback, without being obtrusive to the user as s/he continues to work.

Error Feedback

Problem The user needs to be made aware of potential problems with a form submission.
Pattern A message appears, prominently above page content, listing the errors that were found.
Result This allows the user to read the errors, and dismiss with the hide link when finished.

Drawer Navigation

Problem The user needs to see, at a glance, a listing of hierarchical links in an application.
Pattern A dynamic drawer menu slides down over the page content, revealing helpful links.
Result This allows the user easier access to sections of the application, no matter where s/he is.

Logout Counter

Problem In the interest of protecting personal data, an unattended session should be ended.
Pattern If a user leaves the browser idle for a period of time, s/he is prompted with a countdown.
Result Unless the user dismisses the modal within 5 minutes, the app redirects to the login page.

Menus & Actions

Gear Menu

Problem The user needs actionable items one-click away, without cluttering the interface.
Pattern A gear menu contains a list of collapsible actions, at the top-right of the interface.
Result This allows quick access to a variety of actions, while still allowing the user to work.

Actions

Problem The user needs to have actionable items visibly nearby, but not as the page's focal point.
Pattern An actions sidebar is provided, which is supplementary to the page's primary purpose.
Result The user can focus on the task at hand, but can also take secondary actions, if need be.

Forms

Fieldset vs. Box

Problem Data needs to be grouped into logical sections, for easier visual scanning and reading.
Pattern Small portions go in a <fieldset>. Larger groupings should be in <div class="box">.
Result This helps visually distinguish the size of data sets and importance of form elements.

Simple Form

Problem The user wants to enter a small amount of data, and needs an accommodating interface.
Pattern When a form only requires limited information, labels and inputs belong on their own lines.
Result This allows the user to quickly fill out the form, because it is easy to scan visually.
Code View example
01.<p class="form_element">
02.    <label for="group_name">
03.        Name
04.    </label>
05.    <input type="text" name="group_name" id="group_name" />
06.</p>
07.<p class="form_element">
08.    <label for="group_desc">
09.        Description
10.    </label>
11.    <input type="text" name="group_desc" id="group_desc" />
12.</p>
13.<p>
14.    <input type="submit" value="Submit" />
15.</p>

Complex Form

Problem The user wants to enter a large amount of data, and needs an accommodating interface.
Pattern Form labels and inputs are arranged side-by-side to allow more inputs per vertical space.
Result This allows the user to enter more data, without having to scroll the page as much.
Code View example
01.<table class="form">
02.    <tr>
03.        <th>
04.            <label for="input_1">
05.                Label text
06.            </label>
07.        </th>
08.        <td>
09.            <input type="text" name="input_1" id="input_1" />
10.        </td>
11.    </tr>
12.    <tr>
13.        <th>
14.            <label for="input_2">
15.                Label text
16.            </label>
17.        </th>
18.        <td>
19.            <input type="text" name="input_2" id="input_2" />
20.        </td>
21.    </tr>
22.    <!-- etc. -->
23.</table>
24.<hr />
25.<p>
26.    <input type="submit" value="Submit" />
27.</p>

Miscellaneous

Step Wizard

Problem The user needs to perform a sequence of tasks, without knowing how long it will take.
Pattern A series of steps and accompanying descriptions appear above each part of the process.
Result The user has a way to gauge his/her progress while working on each respective task.

Persistent Message

Problem The user needs to be made aware of an important message, provided by the business.
Pattern At the top of every page, a persistent system-wide notice is prominently displayed.
Result The user is presented with an announcement, but can still use the app unhindered.

Back Tab

Problem The user needs to return to a previous page, while maintaining the current state of the session.
Pattern In the top-left of the page, there is a back tab that will take the user to the previous page.
Result This allows the user to go back, without breaking the statefulness of the application.

Composition

Rich Text Editor

Problem The user needs to compose an rich text message, such as an email or church announcement.
Pattern A rich text editor offers a familiar interface, akin to what might be seen in a word processor.
Result This allows the user to compose a message using an intuitive point-and-click workflow.

Enhanced Actions

Problem The user needs to insert variables such as {FirstName} and {LastName} into a message.
Pattern Using one-click actions on the side of a page, the user can easily supplement an email.
Result This allows a user to write messages quickly, which can be sent to multiple recipients.

Pill Tabs

Problem The user needs to access sub-content that has been obscured within the same page.
Pattern Using stylized links that function as tabs, the user can hide or show relevant material.
Result This allows the interface to remain uncluttered, while still facilitating heavier content.
Code View example
01.<ul id="criteria_options">
02.    <li>
03.        <a href="..." class="current">Color theme</a>
04.    </li>
05.    <li>
06.        <a href="...">Header logo</a>
07.    </li>
08.    <li>
09.        <a href="...">Custom content</a>
10.    </li>
11.</ul>

Problem The user needs to perform a search using a specific set of criteria, beyond a basic query.
Pattern Using a toggle-able set of additional search fields, the user can enter more specific details.
Result By providing additional search criteria, the user can narrow the result set considerably.
Code View example
01.<table class="horiz">
02.    <tr>
03.        <th>
04.            <label for="status">
05.                Status
06.            </label>
07.        </th>
08.        <th>
09.            <label for="sub_status">
10.                Sub status
11.            </label>
12.        </th>
13.        <th>
14.            <label for="attribute_group">
15.                Attribute group
16.            </label>
17.        </th>
18.        <th>
19.            <label for="attribute">
20.                Attribute
21.            </label>
22.        </th>
23.    </tr>
24.    <tr>
25.        <td>
26.            <select name="status" id="status">
27.                <option value="...">Choose a status</option>
28.                <!-- etc. -->
29.            </select>
30.        </td>
31.        <td>
32.            <select name="sub_status" id="sub_status">
33.                <option value="...">Choose a sub status</option>
34.                <!-- etc. -->
35.            </select>
36.        </td>
37.        <td>
38.            <select name="attribute_group" id="attribute_group">
39.                <option value="...">Choose an attribute group</option>
40.                <!-- etc. -->
41.            </select>
42.        </td>
43.        <td>
44.            <select name="attribute" id="attribute">
45.                <option value="...">Then choose an attribute</option>
46.                <!-- etc. -->
47.            </select>
48.        </td>
49.    </tr>
50.</table>

Match Indicator

Problem When attempting to compare two or more data sets, the user needs to know if they match.
Pattern A strength indicator depicts visually (on a scale of 1 to 5) how close of a match is found.
Result This allows a user to easily see how closely related the results are to the search criteria.

Personalized Data

Avatar or Photo

Problem An interface must account for multiple individual photos, without slowing the page load.
Pattern Icons are present, that when hovered over, display either a generic avatar or user photo.
Result Users can view profile images conveniently, and browser performance remains efficient.

Involvement Graph

Problem The user needs to see how involved an individual has been in an area of ministry.
Pattern Attendance and involvement in various programs can be plotted chronologically.
Result This allows an administrator to gauge how active people are in their various roles.

Modal Window

Problem The user needs to be able to view more details about a person, without leaving the page.
Pattern Using a modal overlay, a person's contact info can be displayed above everything else.
Result This affords a quick synopsis while still maintaining all context of the task at hand.

Tables

Alpha Bar

Problem The user is viewing a great deal of information and needs to navigate through it logically.
Pattern For extremely large data sets, an alphabetical listing is displayed at the top of the table.
Result This allows the user to drill down via the first letter of a single aspect of data (name, etc).

Problem When viewing a set of data, the user needs to be able to delete one or more entries.
Pattern Delete links are displayed in the far-right hand of the data set, to prevent mis-clicks.
Result This allows the user to delete specific items without going to a separate admin page.

Sortable Rows

Problem The user needs to be able to rearrange the order of rows in a particular data table.
Pattern Up and down arrows facilitate the movement of a row, higher or lower in the table.
Result This allows the user to have more granular control over how the data is displayed.

Status Indicator

Problem The user needs to be see the status of a batch of requests that has been processed.
Pattern The status of each unique request is shown, and is color coded by success or failure.
Result This allows users to easily scan the page for requests that need special attention.