tolaria 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (219) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +66 -0
  3. data/.yardopts +4 -0
  4. data/CNAME +1 -0
  5. data/CONTRIBUTING.md +32 -0
  6. data/Gemfile +2 -0
  7. data/LICENSE.md +9 -0
  8. data/README.md +538 -0
  9. data/Rakefile +52 -0
  10. data/app/assets/fonts/admin/fontawesome.eot +0 -0
  11. data/app/assets/fonts/admin/fontawesome.svg +565 -0
  12. data/app/assets/fonts/admin/fontawesome.ttf +0 -0
  13. data/app/assets/fonts/admin/fontawesome.woff +0 -0
  14. data/app/assets/fonts/admin/fontawesome.woff2 +0 -0
  15. data/app/assets/images/admin/columbia_banner.png +0 -0
  16. data/app/assets/images/admin/favicon.ico +0 -0
  17. data/app/assets/images/admin/noise.png +0 -0
  18. data/app/assets/images/admin/select_arrows.svg +1 -0
  19. data/app/assets/javascripts/admin/admin.js +4 -0
  20. data/app/assets/javascripts/admin/base.js +12 -0
  21. data/app/assets/javascripts/admin/lib/backbone.js +1888 -0
  22. data/app/assets/javascripts/admin/lib/jquery.chosen.js +1272 -0
  23. data/app/assets/javascripts/admin/lib/jquery.js +10361 -0
  24. data/app/assets/javascripts/admin/lib/jquery.selection.js +352 -0
  25. data/app/assets/javascripts/admin/lib/moment.js +3103 -0
  26. data/app/assets/javascripts/admin/lib/no.js +6 -0
  27. data/app/assets/javascripts/admin/lib/underscore.js +1570 -0
  28. data/app/assets/javascripts/admin/models/composer_buttons.js +45 -0
  29. data/app/assets/javascripts/admin/models/rails_meta.js +4 -0
  30. data/app/assets/javascripts/admin/views/field_with_errors.js +19 -0
  31. data/app/assets/javascripts/admin/views/fields/attachment_field.js +32 -0
  32. data/app/assets/javascripts/admin/views/fields/has_many.js +64 -0
  33. data/app/assets/javascripts/admin/views/fields/image_association_select.js +31 -0
  34. data/app/assets/javascripts/admin/views/fields/markdown_composer.js +167 -0
  35. data/app/assets/javascripts/admin/views/fields/searchable_select.js +70 -0
  36. data/app/assets/javascripts/admin/views/fields/slug_field.js +38 -0
  37. data/app/assets/javascripts/admin/views/fields/swatch_field.js +55 -0
  38. data/app/assets/javascripts/admin/views/fields/timestamp_field.js +80 -0
  39. data/app/assets/javascripts/admin/views/flash_message.js +18 -0
  40. data/app/assets/javascripts/admin/views/form_orchestrator.js +41 -0
  41. data/app/assets/javascripts/admin/views/navigation.js +20 -0
  42. data/app/assets/javascripts/admin/views/resource_form.js +18 -0
  43. data/app/assets/javascripts/admin/views/search_form.js +20 -0
  44. data/app/assets/javascripts/admin/views/sessions.js +109 -0
  45. data/app/assets/javascripts/admin/views/virtual_form.js +47 -0
  46. data/app/assets/stylesheets/admin/_base.scss +5 -0
  47. data/app/assets/stylesheets/admin/_reset.scss +149 -0
  48. data/app/assets/stylesheets/admin/_root.scss +63 -0
  49. data/app/assets/stylesheets/admin/admin.scss +4 -0
  50. data/app/assets/stylesheets/admin/components/_blank_slate.scss +44 -0
  51. data/app/assets/stylesheets/admin/components/_buttons.scss +82 -0
  52. data/app/assets/stylesheets/admin/components/_flash_message.scss +64 -0
  53. data/app/assets/stylesheets/admin/components/_footer.scss +9 -0
  54. data/app/assets/stylesheets/admin/components/_header.scss +107 -0
  55. data/app/assets/stylesheets/admin/components/_index_table.scss +120 -0
  56. data/app/assets/stylesheets/admin/components/_main.scss +68 -0
  57. data/app/assets/stylesheets/admin/components/_markdown_body.scss +109 -0
  58. data/app/assets/stylesheets/admin/components/_navigation.scss +110 -0
  59. data/app/assets/stylesheets/admin/components/_pagination.scss +36 -0
  60. data/app/assets/stylesheets/admin/components/_pill.scss +11 -0
  61. data/app/assets/stylesheets/admin/components/_resource_form.scss +222 -0
  62. data/app/assets/stylesheets/admin/components/_search_form.scss +36 -0
  63. data/app/assets/stylesheets/admin/components/_sessions.scss +152 -0
  64. data/app/assets/stylesheets/admin/components/_show_table.scss +67 -0
  65. data/app/assets/stylesheets/admin/components/forms/_attachment_field.scss +59 -0
  66. data/app/assets/stylesheets/admin/components/forms/_chosen.scss +478 -0
  67. data/app/assets/stylesheets/admin/components/forms/_image_association_select.scss +20 -0
  68. data/app/assets/stylesheets/admin/components/forms/_markdown_composer.scss +149 -0
  69. data/app/assets/stylesheets/admin/components/forms/_nested_fields.scss +63 -0
  70. data/app/assets/stylesheets/admin/components/forms/_searchable_select.scss +8 -0
  71. data/app/assets/stylesheets/admin/components/forms/_slug_field.scss +20 -0
  72. data/app/assets/stylesheets/admin/components/forms/_swatch_field.scss +47 -0
  73. data/app/assets/stylesheets/admin/components/forms/_timestamp_field.scss +15 -0
  74. data/app/assets/stylesheets/admin/components/help_link.scss +6 -0
  75. data/app/assets/stylesheets/admin/mixins/_clearfix.scss +18 -0
  76. data/app/assets/stylesheets/admin/mixins/_min_max_width.scss +11 -0
  77. data/app/assets/stylesheets/admin/mixins/_rgbb.scss +7 -0
  78. data/app/assets/stylesheets/admin/mixins/_visuallyhidden.scss +33 -0
  79. data/app/assets/stylesheets/admin/settings/_animations.scss +21 -0
  80. data/app/assets/stylesheets/admin/settings/_breakpoints.scss +2 -0
  81. data/app/assets/stylesheets/admin/settings/_colors.scss +32 -0
  82. data/app/assets/stylesheets/admin/settings/_fonts.scss +31 -0
  83. data/app/assets/stylesheets/admin/settings/_icons.scss +1658 -0
  84. data/app/controllers/admin/admin_controller.rb +21 -0
  85. data/app/controllers/admin/sessions_controller.rb +112 -0
  86. data/app/controllers/tolaria/resource_controller.rb +132 -0
  87. data/app/controllers/tolaria/tolaria_controller.rb +40 -0
  88. data/app/helpers/admin/table_helper.rb +175 -0
  89. data/app/helpers/admin/view_helper.rb +76 -0
  90. data/app/mailers/passcode_mailer.rb +11 -0
  91. data/app/models/administrator.rb +146 -0
  92. data/app/views/admin/administrators/_form.html.erb +16 -0
  93. data/app/views/admin/administrators/_index.html.erb +20 -0
  94. data/app/views/admin/administrators/_search.html.erb +5 -0
  95. data/app/views/admin/administrators/_show.html.erb +14 -0
  96. data/app/views/admin/help/help_link.html.erb +16 -0
  97. data/app/views/admin/session/form.html.erb +52 -0
  98. data/app/views/admin/shared/_flash_messages.html.erb +42 -0
  99. data/app/views/admin/shared/_footer.html.erb +8 -0
  100. data/app/views/admin/shared/_head.html.erb +11 -0
  101. data/app/views/admin/shared/_header.html.erb +43 -0
  102. data/app/views/admin/shared/_navigation.html.erb +47 -0
  103. data/app/views/admin/shared/_skiplinks.html.erb +0 -0
  104. data/app/views/admin/shared/forms/_attachment_field.html.erb +17 -0
  105. data/app/views/admin/shared/forms/_has_many.html.erb +14 -0
  106. data/app/views/admin/shared/forms/_has_many_header.html.erb +19 -0
  107. data/app/views/admin/shared/forms/_image_association_select.html.erb +6 -0
  108. data/app/views/admin/shared/forms/_image_field.html.erb +19 -0
  109. data/app/views/admin/shared/forms/_markdown_composer.html.erb +29 -0
  110. data/app/views/admin/shared/forms/_searchable_select.html.erb +3 -0
  111. data/app/views/admin/shared/forms/_slug_field.html.erb +9 -0
  112. data/app/views/admin/shared/forms/_swatch_field.html.erb +4 -0
  113. data/app/views/admin/shared/forms/_timestamp_field.html.erb +19 -0
  114. data/app/views/admin/tolaria_resource/_form_buttons.html.erb +10 -0
  115. data/app/views/admin/tolaria_resource/_index_table.html.erb +73 -0
  116. data/app/views/admin/tolaria_resource/_search_form.html.erb +32 -0
  117. data/app/views/admin/tolaria_resource/_show_buttons.html.erb +13 -0
  118. data/app/views/admin/tolaria_resource/edit.html.erb +34 -0
  119. data/app/views/admin/tolaria_resource/index.html.erb +36 -0
  120. data/app/views/admin/tolaria_resource/new.html.erb +1 -0
  121. data/app/views/admin/tolaria_resource/show.html.erb +52 -0
  122. data/app/views/kaminari/admin/_first_page.html.erb +9 -0
  123. data/app/views/kaminari/admin/_last_page.html.erb +9 -0
  124. data/app/views/kaminari/admin/_next_page.html.erb +9 -0
  125. data/app/views/kaminari/admin/_page.html.erb +17 -0
  126. data/app/views/kaminari/admin/_paginator.html.erb +21 -0
  127. data/app/views/kaminari/admin/_prev_page.html.erb +9 -0
  128. data/app/views/layouts/admin/admin.html.erb +21 -0
  129. data/app/views/layouts/admin/sessions.html.erb +12 -0
  130. data/app/views/passcode_mailer/passcode.text.erb +5 -0
  131. data/lib/generators/tolaria/install/install_generator.rb +21 -0
  132. data/lib/generators/tolaria/install/templates/administrators_migration.rb +31 -0
  133. data/lib/generators/tolaria/install/templates/tolaria_initializer.rb +93 -0
  134. data/lib/tasks/admin.rake +32 -0
  135. data/lib/tolaria.rb +27 -0
  136. data/lib/tolaria/active_record.rb +55 -0
  137. data/lib/tolaria/admin.rb +4 -0
  138. data/lib/tolaria/categories.rb +21 -0
  139. data/lib/tolaria/config.rb +40 -0
  140. data/lib/tolaria/default_config.rb +74 -0
  141. data/lib/tolaria/engine.rb +23 -0
  142. data/lib/tolaria/form_buildable.rb +203 -0
  143. data/lib/tolaria/help_links.rb +78 -0
  144. data/lib/tolaria/introspection.rb +13 -0
  145. data/lib/tolaria/manage.rb +57 -0
  146. data/lib/tolaria/managed_class.rb +90 -0
  147. data/lib/tolaria/markdown.rb +28 -0
  148. data/lib/tolaria/random_tokens.rb +16 -0
  149. data/lib/tolaria/reload.rb +21 -0
  150. data/lib/tolaria/routes.rb +33 -0
  151. data/lib/tolaria/version.rb +13 -0
  152. data/test/demo/Rakefile +4 -0
  153. data/test/demo/app/assets/javascripts/application.js +1 -0
  154. data/test/demo/app/assets/stylesheets/application.scss +1 -0
  155. data/test/demo/app/controllers/application_controller.rb +5 -0
  156. data/test/demo/app/controllers/concerns/.keep +0 -0
  157. data/test/demo/app/controllers/homepage_controller.rb +4 -0
  158. data/test/demo/app/helpers/application_helper.rb +2 -0
  159. data/test/demo/app/mailers/.keep +0 -0
  160. data/test/demo/app/models/.keep +0 -0
  161. data/test/demo/app/models/blog_post.rb +43 -0
  162. data/test/demo/app/models/footnote.rb +5 -0
  163. data/test/demo/app/models/image.rb +19 -0
  164. data/test/demo/app/models/legal_page.rb +24 -0
  165. data/test/demo/app/models/miscellany.rb +12 -0
  166. data/test/demo/app/models/topic.rb +22 -0
  167. data/test/demo/app/models/video.rb +16 -0
  168. data/test/demo/app/views/admin/blog_posts/_form.html.erb +48 -0
  169. data/test/demo/app/views/admin/blog_posts/_search.html.erb +5 -0
  170. data/test/demo/app/views/admin/help/markdown-help.md +95 -0
  171. data/test/demo/app/views/admin/images/_form.html.erb +26 -0
  172. data/test/demo/app/views/admin/legal_pages/_form.html.erb +15 -0
  173. data/test/demo/app/views/admin/topics/_form.html.erb +3 -0
  174. data/test/demo/app/views/admin/videos/_form.html.erb +11 -0
  175. data/test/demo/app/views/homepage/homepage.html.erb +3 -0
  176. data/test/demo/app/views/layouts/application.html.erb +14 -0
  177. data/test/demo/bin/bundle +3 -0
  178. data/test/demo/bin/rails +4 -0
  179. data/test/demo/bin/rake +4 -0
  180. data/test/demo/bin/setup +29 -0
  181. data/test/demo/config.ru +4 -0
  182. data/test/demo/config/application.rb +26 -0
  183. data/test/demo/config/boot.rb +4 -0
  184. data/test/demo/config/database.yml +18 -0
  185. data/test/demo/config/environment.rb +3 -0
  186. data/test/demo/config/environments/development.rb +43 -0
  187. data/test/demo/config/environments/test.rb +44 -0
  188. data/test/demo/config/initializers/assets.rb +11 -0
  189. data/test/demo/config/initializers/cookies_serializer.rb +2 -0
  190. data/test/demo/config/initializers/filter_parameter_logging.rb +3 -0
  191. data/test/demo/config/initializers/inflections.rb +17 -0
  192. data/test/demo/config/initializers/markdown.rb +44 -0
  193. data/test/demo/config/initializers/secret_token.rb +2 -0
  194. data/test/demo/config/initializers/session_store.rb +2 -0
  195. data/test/demo/config/initializers/tolaria.rb +17 -0
  196. data/test/demo/config/initializers/wrap_parameters.rb +14 -0
  197. data/test/demo/config/routes.rb +4 -0
  198. data/test/demo/db/migrate/20150601202901_create_administrators.rb +31 -0
  199. data/test/demo/db/migrate/20150603204006_add_testing_models.rb +27 -0
  200. data/test/demo/db/migrate/20150609232013_create_footnotes.rb +10 -0
  201. data/test/demo/db/migrate/20150610135235_create_additional_demo_objects.rb +50 -0
  202. data/test/demo/db/schema.rb +112 -0
  203. data/test/demo/log/.keep +0 -0
  204. data/test/demo/public/404.html +67 -0
  205. data/test/demo/public/422.html +67 -0
  206. data/test/demo/public/500.html +66 -0
  207. data/test/demo/public/favicon.ico +0 -0
  208. data/test/integration/help_link_test.rb +73 -0
  209. data/test/integration/interface_test.rb +63 -0
  210. data/test/integration/router_test.rb +73 -0
  211. data/test/integration/session_test.rb +88 -0
  212. data/test/test_helper.rb +58 -0
  213. data/test/unit/configuration_test.rb +21 -0
  214. data/test/unit/managed_classes_test.rb +54 -0
  215. data/test/unit/markdown_test.rb +12 -0
  216. data/test/unit/menu_test.rb +32 -0
  217. data/test/unit/random_tokens_test.rb +13 -0
  218. data/tolaria.gemspec +35 -0
  219. metadata +499 -0
@@ -0,0 +1,20 @@
1
+ .image-association-select {
2
+
3
+ &-image {
4
+ border-radius: 1px;
5
+ border: 1px solid $cPlum;
6
+ display: inline-block;
7
+ margin-top: 12px;
8
+ max-width: 100%;
9
+ width: 520px;
10
+
11
+ &.-hidden {
12
+ display: none;
13
+ }
14
+
15
+ @include min-width($bpFull) {
16
+ margin-left: 20%;
17
+ }
18
+ }
19
+
20
+ }
@@ -0,0 +1,149 @@
1
+ .markdown-composer {
2
+
3
+ @include min-width($bpFull) {
4
+ float: left;
5
+ width: 79%;
6
+ max-width: 620px;
7
+ }
8
+
9
+ &-controls {
10
+
11
+ @include clearfix;
12
+ background: $cWhite;
13
+ border-radius: 2px 2px 0 0;
14
+ border: 1px solid $cGrey;
15
+ border-bottom: 0;
16
+ padding: 12px 10px 12px 10px;
17
+ transition: background-color 100ms linear, border-color 100ms linear;
18
+ max-width: 1150px;
19
+ margin: 0 auto -1px auto;
20
+ -moz-user-select: none;
21
+ -ms-user-select: none;
22
+ -webkit-user-select: none;
23
+ user-select: none;
24
+
25
+ &-left {
26
+ float: left;
27
+ }
28
+
29
+ &-right {
30
+ float: right;
31
+ }
32
+
33
+ .-focused &,
34
+ .-fullscreen & {
35
+ border-color: darken($cSapphire, 10);
36
+ border-bottom: 0;
37
+ border-right-color: $cSapphire;
38
+ }
39
+
40
+ }
41
+
42
+ textarea {
43
+ border-radius: 0px 0px 2px 2px;
44
+ border-top: 1px dashed $cGrey;
45
+ color: #000;
46
+ font-family: $fMonospace;
47
+ max-width: none;
48
+ font-size: 14px;
49
+ padding: 12px 12px 12px 12px;
50
+ width: 100%;
51
+ &:focus {
52
+ border-top-color: $cGrey;
53
+ }
54
+ }
55
+
56
+ // THIS ISN'T EVEN MY FINAL FORM!
57
+
58
+ .-fullscreen-toggle {
59
+ display: none;
60
+ @include min-width($bpFull) {
61
+ display: block;
62
+ }
63
+ }
64
+
65
+ &.-fullscreen {
66
+
67
+ display: block;
68
+ position: fixed;
69
+ z-index: 1000000;
70
+ top: 0;
71
+ left: 0;
72
+ width: 100%;
73
+ height: 100%;
74
+ background: $cWhite;
75
+ padding: 3% 5%;
76
+ background: $cCoolGrey;
77
+ max-width: none;
78
+
79
+ .markdown-composer-workspace {
80
+ @include clearfix;
81
+ position: relative;
82
+ height: 100%;
83
+ max-width: 1150px;
84
+ margin: 0 auto;
85
+ }
86
+
87
+ textarea {
88
+ display: block;
89
+ width: 50%;
90
+ height: 94%;
91
+ position: absolute;
92
+ top: 0;
93
+ left: 0;
94
+ font-size: 14px;
95
+ border-left-color: darken($cSapphire, 10);
96
+ border-bottom-color: $cSapphire;
97
+ border-right-color: $cTaupe;
98
+ }
99
+
100
+ .markdown-composer-preview {
101
+
102
+ height: 94%;
103
+ overflow-y: scroll;
104
+ padding: 12px 16px;
105
+ position: absolute;
106
+ right: 0;
107
+ top: 0;
108
+ width: 50%;
109
+
110
+ background: #fdfdfd;
111
+ border-top: 1px dashed $cGrey;
112
+ border-radius: 0 0 2px 0;
113
+ border-bottom: 1px solid $cSapphire;
114
+ border-right: 1px solid $cSapphire;
115
+
116
+ }
117
+
118
+ }
119
+
120
+ }
121
+
122
+ .markdown-composer-button {
123
+
124
+ background: none;
125
+ color: $cGrey;
126
+ transition: color 100ms linear;
127
+
128
+ span {
129
+ font-size: 12px;
130
+ font-weight: bold;
131
+ line-height: 16px;
132
+ text-transform: uppercase;
133
+ }
134
+
135
+ }
136
+
137
+ .markdown-composer.-focused,
138
+ .markdown-composer:hover,
139
+ .markdown-composer:focus {
140
+
141
+ .markdown-composer-button {
142
+ color: $cBlack;
143
+ &:hover, &:active {
144
+ color: $cSapphire;
145
+ }
146
+ }
147
+
148
+ }
149
+
@@ -0,0 +1,63 @@
1
+ .has-many {
2
+
3
+ h3 {
4
+ @include clearfix;
5
+ display: block;
6
+ clear: both;
7
+ float: left;
8
+ width: 100%;
9
+ width: calc(100% + 20px);
10
+ background-color: $cCoolGrey;
11
+ border-top: 1px solid $cPlum;
12
+ border-bottom: 1px solid black(0.2);
13
+ padding: 8px 4px;
14
+ font-size: 14px;
15
+ padding: 8px 0 8px 20px;
16
+ margin: -16px -16px 15px -20px;
17
+ span {
18
+ font-weight: bold;
19
+ float: left;
20
+ padding: 2px 0 2px 0;
21
+ }
22
+ .button {
23
+ float: right;
24
+ margin: 0 20px 0 0;
25
+ }
26
+ }
27
+
28
+ &-create {
29
+
30
+ @include clearfix;
31
+ border-bottom: 1px dashed $cGrey;
32
+ border-top: 3px double $cGrey;
33
+ clear: both;
34
+ margin-top: -16px;
35
+ padding: 30px 0;
36
+ text-align: center;
37
+ transition: background-color 100ms linear;
38
+ width: 100%;
39
+ &:hover, &:active, &:focus {
40
+ background: black(0.02);
41
+ }
42
+ }
43
+
44
+ &-undo {
45
+ @include clearfix;
46
+ display: block;
47
+ clear: both;
48
+ float: left;
49
+ width: 100%;
50
+ text-align: center;
51
+ padding: 30px 5% 30px 5%;
52
+ margin: -16px 0 16px 0;
53
+ &:hover, &:active, &:focus {
54
+ background: black(0.01);
55
+ }
56
+ &-text {
57
+ display: block;
58
+ margin: 0 0 15px 0;
59
+ }
60
+ }
61
+
62
+ }
63
+
@@ -0,0 +1,8 @@
1
+ .searchable-select {
2
+ min-height: 41px;
3
+ @include min-width($bpFull) {
4
+ float: left;
5
+ width: 79%;
6
+ max-width: 520px;
7
+ }
8
+ }
@@ -0,0 +1,20 @@
1
+ .slug-field {
2
+
3
+ &-preview {
4
+ font-family: $fMonospace;
5
+ font-size: 12px;
6
+ margin: 0 0 0 0;
7
+ padding: 6px 8px;
8
+ background: $cCoolGrey;
9
+ border-radius: 0 0 2px 2px;
10
+ border: 1px solid $cGrey;
11
+ border-top: 0;
12
+ @include min-width($bpFull) {
13
+ float: left;
14
+ width: 79%;
15
+ max-width: 520px;
16
+ margin-left: 20%;
17
+ }
18
+ }
19
+
20
+ }
@@ -0,0 +1,47 @@
1
+ .swatch-field {
2
+
3
+ @include clearfix;
4
+
5
+ input[type=text] {
6
+ font-family: $fMonospace;
7
+ font-size: 16px;
8
+ width: 9em;
9
+ float: left;
10
+ margin: 0 0.5em 0 0;
11
+ }
12
+
13
+ &-swatch {
14
+ position: relative;
15
+ display: block;
16
+ float: left;
17
+ border: 1px solid $cPlum;
18
+ border-radius: 1px;
19
+ width: 39px;
20
+ height: 39px;
21
+ background: linear-gradient(135deg, white 48%, #FBA4B4 48%, #FBA4B4 52%, white 52%);
22
+
23
+ // Show a 20% light and dark region in the swatch
24
+ &.-active {
25
+ &:before {
26
+ position: absolute;
27
+ width: 20%;
28
+ height: 100%;
29
+ content: "";
30
+ right: 20%;
31
+ top: 0;
32
+ background: white(0.20);
33
+ }
34
+ &:after {
35
+ position: absolute;
36
+ width: 20%;
37
+ height: 100%;
38
+ content: "";
39
+ right: 0;
40
+ top: 0;
41
+ background: black(0.20);
42
+ }
43
+ }
44
+
45
+ }
46
+
47
+ }
@@ -0,0 +1,15 @@
1
+ .timestamp-field {
2
+
3
+ @include clearfix;
4
+
5
+ &-selects {
6
+ display: none;
7
+ }
8
+
9
+ input[type=text] {
10
+ color: #000;
11
+ font-family: $fMonospace;
12
+ font-size: 16px;
13
+ }
14
+
15
+ }
@@ -0,0 +1,6 @@
1
+ .help-link-body {
2
+ font-size: 16px;
3
+ max-width: 720px;
4
+ padding: 20px 0;
5
+ position: relative;
6
+ }
@@ -0,0 +1,18 @@
1
+ // -------------------------------------------------------------------------
2
+ // MICRO CLEARFIX
3
+ // http://nicolasgallagher.com/micro-clearfix-hack/
4
+ // -------------------------------------------------------------------------
5
+
6
+ @mixin clearfix {
7
+
8
+ &:before,
9
+ &:after {
10
+ content: " ";
11
+ display: table;
12
+ }
13
+
14
+ &:after {
15
+ clear: both;
16
+ }
17
+
18
+ }
@@ -0,0 +1,11 @@
1
+ @mixin min-width($size) {
2
+ @media screen and (min-width: $size) {
3
+ @content;
4
+ }
5
+ }
6
+
7
+ @mixin max-width($size) {
8
+ @media screen and (max-width: $size) {
9
+ @content;
10
+ }
11
+ }
@@ -0,0 +1,7 @@
1
+ @function black($opacity) {
2
+ @return rgba(0,0,0,$opacity);
3
+ }
4
+
5
+ @function white($opacity) {
6
+ @return rgba(255,255,255,$opacity);
7
+ }
@@ -0,0 +1,33 @@
1
+ // -------------------------------------------------------------------------
2
+ // Various Helpers to Show and Hide Content
3
+ // -------------------------------------------------------------------------
4
+
5
+ // Undo visuallyhidden styles
6
+ @mixin undo-visuallyhidden {
7
+ clip: auto;
8
+ height: auto;
9
+ margin: 0;
10
+ overflow: visible;
11
+ position: static;
12
+ width: auto;
13
+ }
14
+
15
+ // Hide only visually, but have it available for screenreaders: http://h5bp.com/v
16
+ @mixin visuallyhidden {
17
+ border: 0;
18
+ clip: rect(0 0 0 0);
19
+ height: 1px;
20
+ margin: -1px;
21
+ overflow: hidden;
22
+ padding: 0;
23
+ position: absolute;
24
+ width: 1px;
25
+ &.focusable:active,
26
+ &.focusable:focus {
27
+ @include undo-visuallyhidden;
28
+ }
29
+ }
30
+
31
+ .visuallyhidden {
32
+ @include visuallyhidden;
33
+ }
@@ -0,0 +1,21 @@
1
+ @-webkit-keyframes fa-spin {
2
+ 0% {
3
+ -webkit-transform: rotate(0deg);
4
+ transform: rotate(0deg);
5
+ }
6
+ 100% {
7
+ -webkit-transform: rotate(359deg);
8
+ transform: rotate(359deg);
9
+ }
10
+ }
11
+
12
+ @keyframes fa-spin {
13
+ 0% {
14
+ -webkit-transform: rotate(0deg);
15
+ transform: rotate(0deg);
16
+ }
17
+ 100% {
18
+ -webkit-transform: rotate(359deg);
19
+ transform: rotate(359deg);
20
+ }
21
+ }
@@ -0,0 +1,2 @@
1
+ $bpNarrow: 600px;
2
+ $bpFull: 860px;
@@ -0,0 +1,32 @@
1
+ $cEggshell: #fcfcfc;
2
+ $cTaupe: #D5D5D7;
3
+ $cPlum: #343242;
4
+ $cBlack: #222222;
5
+ $cThreespotPink: #d21172;
6
+ $cWhite: #fefefe;
7
+ $cGrey: #d8d8d8;
8
+ $cDarkGrey: #777;
9
+ $cCoolGrey: #F7F8F9;
10
+ $cSlate: #4b4f55;
11
+
12
+ $cRuby: #da3946;
13
+ $cSapphire: #3497be;
14
+
15
+ $cButtonNeutral: #fcfcfc;
16
+ $cButtonNeutralActive: #fff;
17
+
18
+ $cButtonPrimary: #00addf;
19
+ $cButtonPrimaryActive: lighten($cButtonPrimary, 3);
20
+
21
+ $cButtonDanger: #da3946;
22
+ $cButtonDangerActive: lighten($cButtonDanger, 10);
23
+
24
+ $plumShadow: 0px 1px 0px black(0.5);
25
+
26
+ @function black($alpha) {
27
+ @return rgba(0,0,0,$alpha);
28
+ }
29
+
30
+ @function white($alpha) {
31
+ @return rgba(255,255,255,$alpha);
32
+ }