forked from CenterForOpenScience/osf-style
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
234 lines (212 loc) · 17.1 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="">
<meta name="author" content="">
<title>OSF Style & UI Guidelines</title>
<!-- Bootstrap core CSS -->
<link href="bower_components/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet">
<link href='https://fonts.googleapis.com/css?family=Open+Sans:400,600,300,700' rel='stylesheet' type='text/css'>
<link href="vendor/prism/prism.css" rel="stylesheet" />
<!-- OSF style -->
<link href="css/base.css" rel="stylesheet">
<!-- Guidelines style -->
<link href="page.css" rel="stylesheet">
<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css">
<!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
<!--[if lt IE 9]>
<script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->
</head>
<body role="document">
<nav class="navbar navbar-inverse osf-navbar navbar-fixed-top">
<div class="container">
<!-- Brand and toggle get grouped for better mobile display -->
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
<span class="sr-only">Toggle navigation</span>
<span class="fa fa-bars fa-lg fa-inverse"></span>
</button>
<a class="navbar-brand" href="index.html">OSF Style Guide </span></a>
</div>
<!-- Collect the nav links, forms, and other content for toggling -->
<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
<ul class="nav navbar-nav">
<li class="active"><a href="index.html">Home<span class="sr-only">(current)</span></a></li>
<li><a href="style.html">Style Guide</a></li>
<li><a href="ui.html">UI Guide </a></li>
<li><a href="language.html">Language</a></li>
</ul>
<div class="navbar-form navbar-right">
<button id="openGithub" role="button" class="btn btn-info"><i class="fa fa-github"></i> Open in Github</button>
</div>
</div><!-- /.navbar-collapse -->
</div><!-- /.container-fluid -->
</nav>
<div class="container-full style-header">
<div id="top" class="container theme-showcase" >
<!-- Main jumbotron for a primary marketing message or call to action -->
<div class="jumbotron">
<h1>OSF Style and UI Guidelines</h1>
<p style="text-align: justify">This project aims to bring together resources to build Design and Layout of OSF components. As you are working with OSF please use this project as reference for how elements on your page should look and how the HTML and CSS should be used. This is a collaborative project. So please feel free to suggest changes or pull requests. </p>
<p class="m-t-lg">
<a href="https://github.com/caneruguz/osf-style" class="btn btn-success btn-lg">Contribute</a>
<a href="https://github.com/caneruguz/osf-style/issues" class="btn btn-warning btn-lg">Report issues</a>
</p>
</div>
</div>
</div>
<div class="nav-rows container">
<div class="row">
<div class="col-xs-12 col-sm-9">
<div class="row m-t-lg">
<div class="col-xs-12">
<div class="alert alert-warning text-center">
<h3> Is what you are looking for not here? </h3>
<p class="m-b-lg"> If the style or component you are looking for is not featured here then you should follow the exact syntax of Bootstrap. </p>
<a href="http://getbootstrap.com/" class="btn btn-default m-t-lg">Check Bootstrap documentation</a>
</div>
</div>
</div>
<!--GENERAL PRINCIPLES PAGE-->
<div id="principles" >
<div class="page-header">
<h1>General principles</h1>
</div>
<div class="row">
<div class="col-xs-12">
<div>
<p>These are general guidelines that developers need to keep in mind when developing user interactions. They identify our priorities and UI development needs to take into consideration these principles.</p>
<h4 id="app_state" class="f-w-md"><a></a>Let the user know about state where applicable</h4>
<p>When a state change in the UI is happening the user should be notified of some of these processes where it helps the user understand what's going on and differentiate the situation from a potential unresponsive or erroneous scenario.</p>
<p>Some examples:</p>
<ul>
<li>Items that are actionable need to be visually distinct (e.g. links, buttons, draggable items).</li>
<li>Pending processes should be identified if taking too long. Pending processes are events that are expected to take a little time, anything that is expected to be observable by the user. For instance uploads and most saves have pending status while the action if being completed. Most often ajax call require the consideration for pending events since they include communication with server. How long after the action starts to show the message is up to the developer and varies considerably. The important point is to match user expectation about time and make sure they know what's going on. </li>
<li>When page loads if there are still asynchronous components loading, a loading indicator needs to make that clear.</li>
<li>Normally actionable items that are non-actionable should be muted (greyed out).</li>
<li>Tooltips should be used to explain states that do not otherwise make sense.</li>
<li>Actionable items should be protected against multiple hits (e.g. Delete buttons turning to muted Deleting...).</li>
<li>If using active states, the active component needs to be visually distinct, for instance in buttons, panels, tabs.</li>
<li>Toggle buttons should change to reflect the current state. For instance a collapsed item should have an icon that suggests opening and that icon should change when the state needs to suggest closing.</li>
<li>Utilize the <strong>cursor</strong> attribute of CSS to change cursors on hover but only when this change makes sense. (<a href="https://developer.mozilla.org/en-US/docs/Web/CSS/cursor">https://developer.mozilla.org/en-US/docs/Web/CSS/cursor</a>)
<ul>
<li><strong>default</strong> is for general purpose.</li>
<li><strong>pointer</strong> is for links and items that are clickable.</li>
<li><strong>move</strong> is for items that can be moved with drag already.</li>
<li><strong>row/col-resize</strong> To drag and resize horizontal or vertical items, content.</li>
</ul>
</li>
</ul>
<hr>
<h4 id="errors" class="f-w-md"><a ></a>Let the user know about errors and offer alternatives where possible</h4>
<p>Sometimes user driven or connectivity based errors halt or make certain UI actions possible. The interface should provide alternatives and information</p>
<p>Example with space limitation:</p>
<div class="osf-box-lt p-lg">
Can't connect to Dropbox at the moment. [Learn more]
</div>
<p>Example:</p>
<div class="osf-box-lt p-lg">
We are having trouble connecting to the Dropbox server at the moment. This may be because their servers are not reachable or your internet connection may be down. Please try reloading this page or [read more about this error]
</div>
<hr>
<h4 id="consistency" class="f-w-md"><a ></a>Be consistent about UI components</h4>
<p>To the greatest extent possible, all our components should be using the exact same styling by using the OSF Style Guidelines. This means:</p>
<ul>
<li>Buttons should look exactly the same in style, with color differences denoting similar meaning.</li>
<li>Color palette should be used in similar ways; (e.g. we should have a single highlight background color for all hover effects)</li>
<li>Element use for common tasks should be the same, e.g. different sections within pages should not use tabs in one place and accordion menus in others if the target elements are exactly the same.</li>
<li>Different icons should not be used to mean the same thing and one icon should not be used for multiple meanings. Icon association should make sense to the task.</li>
<li>Responsive components should become responsive in similar ways. For instance if icons lose their labels in small views, that should be the case with all icons.</li>
</ul>
<hr>
<h4 id="empty_space" class="f-w-md"><a ></a>Utilize empty space with actionable suggestions</h4>
<p>There are many areas where users don't have content available. In these cases their pages or elements will be empty. We can use these instances to offer actionable tasks with appropriate links.</p>
<p>Example:</p>
<div class="osf-box-lt p-lg">
You don't have any registrations at the moment.<br>
[Learn more about Registrations] [Create a Registration]
</div>
<hr>
<h4 id="mobile" class="f-w-md"><a ></a>Take steps to make website functional in mobile devices</h4>
<ul>
<li>Check <a href="http://www.smashingmagazine.com/2011/01/12/guidelines-for-responsive-web-design/"> responsiveness </a> in every page.</li>
<li>Make Header texts proportionally smaller in smaller devices, no need for an H1 in a phone.</li>
<li>Make text that does not fit constrained widths end with ...</li>
<li>Make different versions for mobile buttons that have less text. - Make sure all images are responsive.</li>
<li>Check show/hide relationships in mobile devices, often it's unnecessary.</li>
<li>Check empty vertical space in rows.</li>
<li>Check that horizontally listed items stack properly in narrow view.</li>
<li>Check that tables respond properly to narrow views, scrolling if necessary.</li>
<li>Make sure touch and event based actions either work well or have fallbacks in mobile devices.</li>
</ul>
<hr>
<h4 id="large" class="f-w-md"><a ></a>Take steps to make sure the website is functional in very large devices</h4>
<p>Where possible, let the user utilize the large workspace that they have by providing meaningful expansion of the space:</p>
<ul>
<li>Expand tables, grids, and stacked components that have uniform items (e.g. galleries).</li>
<li>Do not expand Text! Instead fit several columns.</li>
<li>Remove show/hide options to show everything as space allows, that reduces an extra step.</li>
<li>Stack similar content horizontally as columns.</li>
<li>Center content if not utilizing the entire width.</li>
</ul>
<hr>
<h4 id="form_inputs" class="f-w-md"><a ></a>Improve the form input and toggle process where possible</h4>
<p>Follow these guidelines when making forms or add elements such as drop downs.</p>
<ul>
<li>If your dropdown has few elements, consider another input or toggle method, like a button group or radio buttons.</li>
<li>Make input elements large and text visible.</li>
<li>Uniformity in input elements is important, stick to themes or frameworks; if you are adding custom css to established framework css for inputs you are most likely doing it wrong.</li>
<li>Do not remove the visual separation of focus on input elements, but make it fit to your general theme.</li>
<li>Most of the time select and checkbox items are too small, consider increasing their size or generally make sure they fill your font's line height.</li>
<li>Make sure tab goes to the next item if there is a form with multiple items.</li>
<li>If using JS for form inputs, bind Enter key.</li>
<li>Don't have a "Clear Form" button.</li>
<li>Avoid using too many borders in form structures. Alignment is a way to denote edges as well and inputs already have borders.</li>
<li>Use a good combination of placeholder and label for inputs, often one is enough, both are unnecessary. Don't repeat the label in the placeholder. Label is better for cross browser use.</li>
<li>Tie your labels to your form elements with "for" so that when users click on the label the input gets selection.</li>
</ul>
<hr>
<h4 id="history" class="f-w-md"><a ></a>Respect history</h4>
<p>If you are using a single page approach where page loads are not required for significant events, remember that users consider significant layout changes to denote page changes and will want to press back to go back to the previous state.</p>
<hr>
<h4 class="f-w-md"><a id="Ignore_these_rules_when_necessary_148"></a>Ignore these rules when necessary</h4>
<p>There are times where these general practices may not make sense for rare instances. In those cases it is better UI practice to abandon convention and use custom solutions. These cases should be few and should require discussion.</p>
</div>
</div>
</div>
</div>
</div>
<div id="side-menu" class="col-sm-3 hidden-xs">
<ul class="nav nav-pills nav-stacked m-t-xl" data-spy="affix" data-offset-top="350" data-offset-bottom="200">
<li class="active"><a href="#top">Top</a></li>
<li >
<a href="#principles">General principles</a>
<ul class="nav subnav" >
<li><a href="#language">Language</a></li>
<li><a href="#app_state">Application state</a></li>
<li><a href="#errors">Errors</a></li>
<li><a href="#empty_space">Empty space</a></li>
<li><a href="#mobile">Mobile</a></li>
<li><a href="#large">Large screens</a></li>
<li><a href="#form_inputs">Form inputs</a></li>
<li><a href="#history">History</a></li>
</ul>
</li>
</ul>
</div>
</div>
</div>
<!-- Bootstrap core JavaScript
================================================== -->
<!-- Placed at the end of the document so the pages load faster -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script src="bower_components/bootstrap/dist/js/bootstrap.min.js"></script>
<script src="vendor/prism/prism.js"></script>
<script src="script.js"></script>
</body>
</html>