fae-railsz 2.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/README.md +5 -0
- data/Rakefile +37 -0
- data/app/assets/fonts/fae/icons.eot +0 -0
- data/app/assets/fonts/fae/icons.svg +56 -0
- data/app/assets/fonts/fae/icons.ttf +0 -0
- data/app/assets/fonts/fae/icons.woff +0 -0
- data/app/assets/fonts/fae/lato-bold-webfont.eot +0 -0
- data/app/assets/fonts/fae/lato-bold-webfont.svg +4551 -0
- data/app/assets/fonts/fae/lato-bold-webfont.ttf +0 -0
- data/app/assets/fonts/fae/lato-bold-webfont.woff +0 -0
- data/app/assets/fonts/fae/lato-light-webfont.eot +0 -0
- data/app/assets/fonts/fae/lato-light-webfont.svg +4241 -0
- data/app/assets/fonts/fae/lato-light-webfont.ttf +0 -0
- data/app/assets/fonts/fae/lato-light-webfont.woff +0 -0
- data/app/assets/fonts/fae/lato-regular-webfont.eot +0 -0
- data/app/assets/fonts/fae/lato-regular-webfont.svg +4241 -0
- data/app/assets/fonts/fae/lato-regular-webfont.ttf +0 -0
- data/app/assets/fonts/fae/lato-regular-webfont.woff +0 -0
- data/app/assets/fonts/fae/selection.json +1334 -0
- data/app/assets/images/fae/error_bg.jpg +0 -0
- data/app/assets/images/fae/error_sad_face.png +0 -0
- data/app/assets/images/fae/icons/alert.svg +9 -0
- data/app/assets/images/fae/icons/arrow_down.svg +8 -0
- data/app/assets/images/fae/icons/arrow_left.svg +9 -0
- data/app/assets/images/fae/icons/arrow_right.svg +9 -0
- data/app/assets/images/fae/icons/arrow_stacked.svg +8 -0
- data/app/assets/images/fae/icons/arrow_up.svg +8 -0
- data/app/assets/images/fae/icons/calendar.svg +17 -0
- data/app/assets/images/fae/icons/check.svg +7 -0
- data/app/assets/images/fae/icons/checkmark.svg +8 -0
- data/app/assets/images/fae/icons/chevron_down.svg +7 -0
- data/app/assets/images/fae/icons/chevron_left.svg +10 -0
- data/app/assets/images/fae/icons/chevron_right.svg +10 -0
- data/app/assets/images/fae/icons/chevron_up.svg +7 -0
- data/app/assets/images/fae/icons/delete.svg +8 -0
- data/app/assets/images/fae/icons/delete_x.svg +8 -0
- data/app/assets/images/fae/icons/edit.svg +11 -0
- data/app/assets/images/fae/icons/handle.svg +13 -0
- data/app/assets/images/fae/icons/home.svg +10 -0
- data/app/assets/images/fae/icons/logout.svg +12 -0
- data/app/assets/images/fae/icons/magnifying_glass.svg +10 -0
- data/app/assets/images/fae/icons/menu.svg +11 -0
- data/app/assets/images/fae/icons/offlink.svg +25 -0
- data/app/assets/images/fae/icons/plus.svg +8 -0
- data/app/assets/images/fae/icons/pulldown.svg +11 -0
- data/app/assets/images/fae/icons/search.svg +11 -0
- data/app/assets/images/fae/icons/settings.svg +12 -0
- data/app/assets/images/fae/icons/sort.svg +11 -0
- data/app/assets/images/fae/icons/support.svg +15 -0
- data/app/assets/images/fae/icons/trash.svg +10 -0
- data/app/assets/images/fae/icons/trumbowyg.svg +1 -0
- data/app/assets/images/fae/icons/user.svg +13 -0
- data/app/assets/images/fae/icons/users.svg +19 -0
- data/app/assets/images/fae/icons/zoom.svg +12 -0
- data/app/assets/images/fae/tutorial_model_location.png +0 -0
- data/app/assets/images/fae/youtube_helper.jpg +0 -0
- data/app/assets/javascripts/fae/_modals.js +60 -0
- data/app/assets/javascripts/fae/_tables.js +403 -0
- data/app/assets/javascripts/fae/admin.js.erb +11 -0
- data/app/assets/javascripts/fae/application.js +63 -0
- data/app/assets/javascripts/fae/fae_init.js +8 -0
- data/app/assets/javascripts/fae/form/_ajax.js +380 -0
- data/app/assets/javascripts/fae/form/_cancel.js +38 -0
- data/app/assets/javascripts/fae/form/_filtering.js +276 -0
- data/app/assets/javascripts/fae/form/_form.js +60 -0
- data/app/assets/javascripts/fae/form/_slugger.js.erb +100 -0
- data/app/assets/javascripts/fae/form/_validator.js +459 -0
- data/app/assets/javascripts/fae/form/fae_chosen.js +44 -0
- data/app/assets/javascripts/fae/form/fileinputer.js +178 -0
- data/app/assets/javascripts/fae/form/hinter.js +111 -0
- data/app/assets/javascripts/fae/form/inputs/_checkbox.js +27 -0
- data/app/assets/javascripts/fae/form/inputs/_color.js +42 -0
- data/app/assets/javascripts/fae/form/inputs/_dates.js +78 -0
- data/app/assets/javascripts/fae/form/inputs/_select.js +162 -0
- data/app/assets/javascripts/fae/form/inputs/_text.js +118 -0
- data/app/assets/javascripts/fae/navigation/_global_search.js +184 -0
- data/app/assets/javascripts/fae/navigation/_language.js +89 -0
- data/app/assets/javascripts/fae/navigation/_navigation.js +206 -0
- data/app/assets/javascripts/fae/navigation/_subnav_highlighter.js +81 -0
- data/app/assets/javascripts/fae/navigation/sticky.js +186 -0
- data/app/assets/javascripts/fae/vendor/chosen.jquery.min.js +2 -0
- data/app/assets/javascripts/fae/vendor/frob_core_helpers.js +587 -0
- data/app/assets/javascripts/fae/vendor/fryr.js +437 -0
- data/app/assets/javascripts/fae/vendor/jqColorPicker.min.js +4 -0
- data/app/assets/javascripts/fae/vendor/jquery.daterangepicker.js +1292 -0
- data/app/assets/javascripts/fae/vendor/jquery.multi-select.js +534 -0
- data/app/assets/javascripts/fae/vendor/jquery.simplemodal.1.4.4.js +719 -0
- data/app/assets/javascripts/fae/vendor/jquery.tablesorter.js +1901 -0
- data/app/assets/javascripts/fae/vendor/js.cookie.js +139 -0
- data/app/assets/javascripts/fae/vendor/moment.min.js +7 -0
- data/app/assets/javascripts/fae/vendor/simplemde.min.js +13 -0
- data/app/assets/javascripts/fae/vendor/touch_punch.js +11 -0
- data/app/assets/javascripts/fae/vendor/trumbowyg.js.erb +4 -0
- data/app/assets/javascripts/fae/vendor/trumbowyg/plugins/upload/trumbowyg.upload.js +223 -0
- data/app/assets/javascripts/fae/vendor/trumbowyg/trumbowyg.js +1603 -0
- data/app/assets/stylesheets/fae/application.css +8 -0
- data/app/assets/stylesheets/fae/base.scss +82 -0
- data/app/assets/stylesheets/fae/globals/_fonts.scss +43 -0
- data/app/assets/stylesheets/fae/globals/_icons.scss +15 -0
- data/app/assets/stylesheets/fae/globals/_plugins.scss +51 -0
- data/app/assets/stylesheets/fae/globals/_tags.scss +68 -0
- data/app/assets/stylesheets/fae/globals/imports/_extends.scss +53 -0
- data/app/assets/stylesheets/fae/globals/imports/_mixins.scss +58 -0
- data/app/assets/stylesheets/fae/globals/imports/_variables.scss +165 -0
- data/app/assets/stylesheets/fae/globals/imports/finescss/_fine.scss +7 -0
- data/app/assets/stylesheets/fae/globals/imports/finescss/_fine_functions.scss +88 -0
- data/app/assets/stylesheets/fae/globals/imports/finescss/_fine_mixins.scss +280 -0
- data/app/assets/stylesheets/fae/globals/imports/finescss/_fine_variables.scss +30 -0
- data/app/assets/stylesheets/fae/globals/layout/_base.scss +48 -0
- data/app/assets/stylesheets/fae/globals/layout/_breadcrumbs.scss +45 -0
- data/app/assets/stylesheets/fae/globals/layout/_content-header.scss +99 -0
- data/app/assets/stylesheets/fae/globals/legacy/_pre-1.3.scss +659 -0
- data/app/assets/stylesheets/fae/globals/navigation/_base.scss +22 -0
- data/app/assets/stylesheets/fae/globals/navigation/_footer.scss +50 -0
- data/app/assets/stylesheets/fae/globals/navigation/_header.scss +149 -0
- data/app/assets/stylesheets/fae/globals/navigation/_mobilenav.scss +149 -0
- data/app/assets/stylesheets/fae/globals/navigation/_search.scss +76 -0
- data/app/assets/stylesheets/fae/globals/navigation/_sidenav.scss +142 -0
- data/app/assets/stylesheets/fae/globals/navigation/_utility.scss +95 -0
- data/app/assets/stylesheets/fae/modules/_alerts.scss +50 -0
- data/app/assets/stylesheets/fae/modules/_buttons.scss +62 -0
- data/app/assets/stylesheets/fae/modules/_modal.scss +78 -0
- data/app/assets/stylesheets/fae/modules/_toggles.scss +48 -0
- data/app/assets/stylesheets/fae/modules/forms/_asset-actions.scss +83 -0
- data/app/assets/stylesheets/fae/modules/forms/_base.scss +100 -0
- data/app/assets/stylesheets/fae/modules/forms/_checkbox.scss +87 -0
- data/app/assets/stylesheets/fae/modules/forms/_colorpicker.scss +57 -0
- data/app/assets/stylesheets/fae/modules/forms/_date.scss +335 -0
- data/app/assets/stylesheets/fae/modules/forms/_hints.scss +40 -0
- data/app/assets/stylesheets/fae/modules/forms/_label.scss +57 -0
- data/app/assets/stylesheets/fae/modules/forms/_radio.scss +69 -0
- data/app/assets/stylesheets/fae/modules/forms/_select.scss +317 -0
- data/app/assets/stylesheets/fae/modules/forms/_simple-mde.scss +29 -0
- data/app/assets/stylesheets/fae/modules/forms/_text.scss +62 -0
- data/app/assets/stylesheets/fae/modules/forms/_textarea.scss +16 -0
- data/app/assets/stylesheets/fae/modules/forms/_validation.scss +63 -0
- data/app/assets/stylesheets/fae/modules/tables/_actions.scss +41 -0
- data/app/assets/stylesheets/fae/modules/tables/_base.scss +63 -0
- data/app/assets/stylesheets/fae/modules/tables/_collapsible.scss +76 -0
- data/app/assets/stylesheets/fae/modules/tables/_filters.scss +61 -0
- data/app/assets/stylesheets/fae/modules/tables/_image.scss +21 -0
- data/app/assets/stylesheets/fae/modules/tables/_pagination.scss +34 -0
- data/app/assets/stylesheets/fae/modules/tables/_sorting.scss +58 -0
- data/app/assets/stylesheets/fae/modules/tables/_sticky.scss +9 -0
- data/app/assets/stylesheets/fae/modules/tables/_tooltips.scss +24 -0
- data/app/assets/stylesheets/fae/pages/_error.scss +35 -0
- data/app/assets/stylesheets/fae/pages/_help.scss +28 -0
- data/app/assets/stylesheets/fae/pages/_home.scss +18 -0
- data/app/assets/stylesheets/fae/pages/_login.scss +137 -0
- data/app/assets/stylesheets/fae/vendor/chosen.css +377 -0
- data/app/assets/stylesheets/fae/vendor/daterangepicker.css +227 -0
- data/app/assets/stylesheets/fae/vendor/reset.css +48 -0
- data/app/assets/stylesheets/fae/vendor/simplemde.min.css +7 -0
- data/app/assets/stylesheets/fae/vendor/trumbowyg.css +584 -0
- data/app/controllers/concerns/fae/application_controller_concern.rb +1 -0
- data/app/controllers/concerns/fae/asset_cloner.rb +46 -0
- data/app/controllers/concerns/fae/cloneable.rb +136 -0
- data/app/controllers/fae/application_controller.rb +123 -0
- data/app/controllers/fae/base_controller.rb +117 -0
- data/app/controllers/fae/files_controller.rb +26 -0
- data/app/controllers/fae/images_controller.rb +37 -0
- data/app/controllers/fae/nested_base_controller.rb +100 -0
- data/app/controllers/fae/options_controller.rb +29 -0
- data/app/controllers/fae/pages_controller.rb +44 -0
- data/app/controllers/fae/setup_controller.rb +54 -0
- data/app/controllers/fae/static_pages_controller.rb +54 -0
- data/app/controllers/fae/users_controller.rb +71 -0
- data/app/controllers/fae/utilities_controller.rb +61 -0
- data/app/helpers/fae/application_helper.rb +114 -0
- data/app/helpers/fae/fae_helper.rb +6 -0
- data/app/helpers/fae/form_helper.rb +240 -0
- data/app/helpers/fae/nested_form_helper.rb +39 -0
- data/app/helpers/fae/view_helper.rb +175 -0
- data/app/inputs/date_range_input.rb +17 -0
- data/app/inputs/radio_collection_input.rb +17 -0
- data/app/inputs/symbol_input.rb +5 -0
- data/app/models/concerns/fae/assets_validatable.rb +12 -0
- data/app/models/concerns/fae/authorization_concern.rb +12 -0
- data/app/models/concerns/fae/base_model_concern.rb +105 -0
- data/app/models/concerns/fae/change_concern.rb +1 -0
- data/app/models/concerns/fae/file_concern.rb +1 -0
- data/app/models/concerns/fae/image_concern.rb +1 -0
- data/app/models/concerns/fae/navigation_concern.rb +10 -0
- data/app/models/concerns/fae/option_concern.rb +1 -0
- data/app/models/concerns/fae/page_validatable.rb +26 -0
- data/app/models/concerns/fae/paper_trailer.rb +8 -0
- data/app/models/concerns/fae/role_concern.rb +1 -0
- data/app/models/concerns/fae/sortable.rb +51 -0
- data/app/models/concerns/fae/static_page_concern.rb +1 -0
- data/app/models/concerns/fae/text_area_concern.rb +1 -0
- data/app/models/concerns/fae/text_field_concern.rb +1 -0
- data/app/models/concerns/fae/trackable.rb +124 -0
- data/app/models/concerns/fae/user_concern.rb +7 -0
- data/app/models/fae/authorization.rb +8 -0
- data/app/models/fae/change.rb +53 -0
- data/app/models/fae/file.rb +24 -0
- data/app/models/fae/image.rb +33 -0
- data/app/models/fae/navigation.rb +132 -0
- data/app/models/fae/option.rb +38 -0
- data/app/models/fae/role.rb +18 -0
- data/app/models/fae/static_page.rb +109 -0
- data/app/models/fae/text_area.rb +14 -0
- data/app/models/fae/text_field.rb +14 -0
- data/app/models/fae/user.rb +67 -0
- data/app/uploaders/fae/file_uploader.rb +26 -0
- data/app/uploaders/fae/image_uploader.rb +28 -0
- data/app/validators/fae/cross_model_uniqueness_validator.rb +14 -0
- data/app/views/devise/confirmations/new.html.slim +13 -0
- data/app/views/devise/mailer/confirmation_instructions.html.slim +3 -0
- data/app/views/devise/mailer/reset_password_instructions.html.slim +5 -0
- data/app/views/devise/mailer/unlock_instructions.html.slim +4 -0
- data/app/views/devise/passwords/edit.html.slim +10 -0
- data/app/views/devise/passwords/new.html.slim +10 -0
- data/app/views/devise/registrations/edit.html.slim +22 -0
- data/app/views/devise/registrations/new.html.slim +15 -0
- data/app/views/devise/sessions/new.html.slim +7 -0
- data/app/views/devise/shared/_links.slim +25 -0
- data/app/views/devise/unlocks/new.html.slim +13 -0
- data/app/views/fae/application/_breadcrumb.html.slim +19 -0
- data/app/views/fae/application/_content_form.html.slim +55 -0
- data/app/views/fae/application/_credit.slim +6 -0
- data/app/views/fae/application/_file_uploader.html.slim +36 -0
- data/app/views/fae/application/_flash_messages.slim +2 -0
- data/app/views/fae/application/_global_search_results.html.slim +37 -0
- data/app/views/fae/application/_header.slim +50 -0
- data/app/views/fae/application/_markdown_helper.slim +41 -0
- data/app/views/fae/application/_mobilenav.slim +66 -0
- data/app/views/fae/application/_sidenav.slim +23 -0
- data/app/views/fae/application/_user_log.html.slim +36 -0
- data/app/views/fae/images/_image_uploader.html.slim +66 -0
- data/app/views/fae/options/_form.html.slim +16 -0
- data/app/views/fae/options/edit.html.slim +1 -0
- data/app/views/fae/pages/activity_log.html.slim +32 -0
- data/app/views/fae/pages/disabled_environment.html.slim +4 -0
- data/app/views/fae/pages/error404.html.slim +7 -0
- data/app/views/fae/pages/help.html.slim +35 -0
- data/app/views/fae/pages/home.html.slim +36 -0
- data/app/views/fae/setup/first_user.html.slim +11 -0
- data/app/views/fae/shared/_errors.slim +4 -0
- data/app/views/fae/shared/_form_header.html.slim +40 -0
- data/app/views/fae/shared/_index_header.html.slim +26 -0
- data/app/views/fae/shared/_nested_table.html.slim +49 -0
- data/app/views/fae/shared/_recent_changes.html.slim +22 -0
- data/app/views/fae/shared/_shared_nested_table.html.slim +46 -0
- data/app/views/fae/static_pages/index.html.slim +13 -0
- data/app/views/fae/users/_form.html.slim +19 -0
- data/app/views/fae/users/edit.html.slim +1 -0
- data/app/views/fae/users/index.html.slim +23 -0
- data/app/views/fae/users/new.html.slim +1 -0
- data/app/views/fae/users/settings.html.slim +1 -0
- data/app/views/kaminari/fae/_gap.html.slim +8 -0
- data/app/views/kaminari/fae/_next_page.html.slim +9 -0
- data/app/views/kaminari/fae/_page.html.slim +15 -0
- data/app/views/kaminari/fae/_paginator.html.slim +15 -0
- data/app/views/kaminari/fae/_prev_page.html.slim +9 -0
- data/app/views/layouts/devise.html.slim +29 -0
- data/app/views/layouts/fae/application.html.slim +23 -0
- data/app/views/layouts/fae/error.html.slim +11 -0
- data/config/deploy.rb +73 -0
- data/config/deploy/dev.rb +19 -0
- data/config/deploy/prod.rb +19 -0
- data/config/deploy/stage.rb +19 -0
- data/config/initializers/assets.rb +1 -0
- data/config/initializers/carrierwave.rb +3 -0
- data/config/initializers/devise.rb +258 -0
- data/config/initializers/devise_monkeypatch.rb +11 -0
- data/config/initializers/fae_judge.rb +3 -0
- data/config/initializers/inflections.rb +16 -0
- data/config/initializers/kaminari_config.rb +10 -0
- data/config/initializers/simple_form.rb +147 -0
- data/config/initializers/time_formats.rb +3 -0
- data/config/locales/devise.en.yml +59 -0
- data/config/locales/devise.zh-CN.yml +59 -0
- data/config/locales/fae.en.yml +10 -0
- data/config/locales/fae.zh-CN.yml +10 -0
- data/config/locales/simple_form.en.yml +26 -0
- data/config/locales/simple_form.zh-CN.yml +26 -0
- data/config/routes.rb +46 -0
- data/db/migrate/20140809222030_add_user_table.rb +49 -0
- data/db/migrate/20140822224029_create_fae_roles.rb +10 -0
- data/db/migrate/20141008180718_create_fae_images_table.rb +19 -0
- data/db/migrate/20141017194616_create_fae_options.rb +16 -0
- data/db/migrate/20141021181327_create_fae_files.rb +17 -0
- data/db/migrate/20141021183047_create_fae_text_areas.rb +16 -0
- data/db/migrate/20141021184311_create_fae_pages.rb +13 -0
- data/db/migrate/20141105214814_create_fae_text_fields.rb +15 -0
- data/db/migrate/20150930224821_create_fae_changes.rb +17 -0
- data/lib/fae-rails.rb +6 -0
- data/lib/fae/concerns/models/base.rb +8 -0
- data/lib/fae/engine.rb +37 -0
- data/lib/fae/options.rb +35 -0
- data/lib/fae/validation_helper_collection.rb +76 -0
- data/lib/fae/version.rb +3 -0
- data/lib/file_size_validator.rb +71 -0
- data/lib/generators/fae/base_generator.rb +156 -0
- data/lib/generators/fae/controller_generator.rb +13 -0
- data/lib/generators/fae/install_generator.rb +61 -0
- data/lib/generators/fae/model_generator.rb +11 -0
- data/lib/generators/fae/nested_index_scaffold_generator.rb +36 -0
- data/lib/generators/fae/nested_scaffold_generator.rb +51 -0
- data/lib/generators/fae/page_generator.rb +65 -0
- data/lib/generators/fae/scaffold_generator.rb +15 -0
- data/lib/generators/fae/templates/assets/fae.js +6 -0
- data/lib/generators/fae/templates/assets/fae.scss +2 -0
- data/lib/generators/fae/templates/controllers/nested_index_scaffold_controller.rb +81 -0
- data/lib/generators/fae/templates/controllers/nested_scaffold_controller.rb +13 -0
- data/lib/generators/fae/templates/controllers/scaffold_controller.rb +13 -0
- data/lib/generators/fae/templates/controllers/static_pages_controller.rb +10 -0
- data/lib/generators/fae/templates/initializers/fae.rb +63 -0
- data/lib/generators/fae/templates/initializers/fae_fine.rb +51 -0
- data/lib/generators/fae/templates/initializers/judge.rb +6 -0
- data/lib/generators/fae/templates/models/concerns/authorization_concern.rb +27 -0
- data/lib/generators/fae/templates/models/concerns/navigation_concern.rb +33 -0
- data/lib/generators/fae/templates/models/pages_model.rb +14 -0
- data/lib/generators/fae/templates/tasks/fae_tasks.rake +19 -0
- data/lib/generators/fae/templates/views/_form.html.slim +18 -0
- data/lib/generators/fae/templates/views/_form_index_nested.html.slim +13 -0
- data/lib/generators/fae/templates/views/_form_nested.html.slim +17 -0
- data/lib/generators/fae/templates/views/edit.html.slim +1 -0
- data/lib/generators/fae/templates/views/edit_nested.html.slim +3 -0
- data/lib/generators/fae/templates/views/index.html.slim +35 -0
- data/lib/generators/fae/templates/views/index_nested.html.slim +8 -0
- data/lib/generators/fae/templates/views/new.html.slim +1 -0
- data/lib/generators/fae/templates/views/new_nested.html.slim +3 -0
- data/lib/generators/fae/templates/views/static_page_form.html.slim +15 -0
- data/lib/generators/fae/templates/views/table_nested.html.slim +4 -0
- metadata +692 -0
@@ -0,0 +1,88 @@
|
|
1
|
+
//////////////////////////////
|
2
|
+
// FINE Functions
|
3
|
+
//////////////////////////////
|
4
|
+
|
5
|
+
// Return a negative integer of the supplied value
|
6
|
+
@function negate($integer) {
|
7
|
+
@if $integer > 0 {
|
8
|
+
@return 0 - $integer;
|
9
|
+
} @else {
|
10
|
+
@return $integer;
|
11
|
+
}
|
12
|
+
}
|
13
|
+
|
14
|
+
// Z-index function: comma-separated list and item taken
|
15
|
+
// http://www.smashingmagazine.com/2014/06/12/sassy-z-index-management-for-complex-layouts/
|
16
|
+
@function z($list, $element) {
|
17
|
+
$z-index: index($list, $element);
|
18
|
+
|
19
|
+
@if $z-index {
|
20
|
+
@return $z-index;
|
21
|
+
}
|
22
|
+
|
23
|
+
@warn "There is no item '#{$element}' in this list; choose one of: #{$list}";
|
24
|
+
@return null;
|
25
|
+
}
|
26
|
+
|
27
|
+
// Taken from Foundation
|
28
|
+
@function emCalc($pxWidth) {
|
29
|
+
@return $pxWidth / $em-base * 1em;
|
30
|
+
}
|
31
|
+
|
32
|
+
@function remCalc($pxWidth) {
|
33
|
+
@return $pxWidth / $em-base * 1rem;
|
34
|
+
}
|
35
|
+
|
36
|
+
// Helper for finding value in a faux sass hash -- i.e. a list
|
37
|
+
// http://hugogiraudel.com/2013/08/12/sass-functions/
|
38
|
+
@function match($collection, $value) {
|
39
|
+
@each $item in $collection {
|
40
|
+
$index: index($item, $value);
|
41
|
+
@if $index {
|
42
|
+
$return: if($index == 1, 2, $index);
|
43
|
+
@return nth($item, $return);
|
44
|
+
}
|
45
|
+
}
|
46
|
+
@return false;
|
47
|
+
}
|
48
|
+
|
49
|
+
// Grabs a key from $list
|
50
|
+
// @param {key} $key - Key to get value from $list map
|
51
|
+
// @return - Value of key
|
52
|
+
@function mapperize($list, $key) {
|
53
|
+
@if map-has-key($list, $key) {
|
54
|
+
@return map-get($list, $key);
|
55
|
+
} @else {
|
56
|
+
@warn "#{$key} was not found";
|
57
|
+
@return null;
|
58
|
+
}
|
59
|
+
}
|
60
|
+
|
61
|
+
@function gray($key: 30) {
|
62
|
+
@return mapperize($grays, $key);
|
63
|
+
}
|
64
|
+
|
65
|
+
@function fae-icon($key: 'home') {
|
66
|
+
$icon-code: mapperize($fae-required-icons, $key);
|
67
|
+
// Unicode chars are escaped; instead of using a slash in the map,
|
68
|
+
// we add the slash here
|
69
|
+
// https://github.com/sass/sass/issues/659#issuecomment-64818741
|
70
|
+
@return unquote("\"\\#{$icon-code}\"");
|
71
|
+
}
|
72
|
+
|
73
|
+
// Choose from a light or dark contrasting foreground color given a background
|
74
|
+
// Original function: https://medium.com/@mkel23/calculating-color-contrast-with-sass-eff39ef23f96
|
75
|
+
@function pickForegroundColor($background, $c-light, $c-dark) {
|
76
|
+
$r: red($background);
|
77
|
+
$g: green($background);
|
78
|
+
$b: blue($background);
|
79
|
+
|
80
|
+
$yiq: (($r*299)+($g*587)+($b*114))/1000;
|
81
|
+
|
82
|
+
@if ($yiq >= 170) {
|
83
|
+
@return $c-dark; // Dark foreground
|
84
|
+
}
|
85
|
+
@else {
|
86
|
+
@return $c-light; // Light foreground
|
87
|
+
}
|
88
|
+
}
|
@@ -0,0 +1,280 @@
|
|
1
|
+
// scss-lint:disable VendorPrefixes
|
2
|
+
|
3
|
+
// Shortcut for text color of hover action
|
4
|
+
@mixin hover($color: false) {
|
5
|
+
&:hover {
|
6
|
+
@if $color {
|
7
|
+
color: $color;
|
8
|
+
} @else {
|
9
|
+
@content;
|
10
|
+
}
|
11
|
+
}
|
12
|
+
}
|
13
|
+
|
14
|
+
// Remove all list properties
|
15
|
+
@mixin list--none {
|
16
|
+
margin: 0;
|
17
|
+
padding: 0;
|
18
|
+
list-style: none;
|
19
|
+
}
|
20
|
+
|
21
|
+
// Make a triangle (taken from Bourbon)
|
22
|
+
@mixin triangle($direction: top, $color: $c-black, $size: 30px, $shadow: false) {
|
23
|
+
position: relative;
|
24
|
+
background: $color;
|
25
|
+
|
26
|
+
&:after {
|
27
|
+
border: solid transparent;
|
28
|
+
content: ' ';
|
29
|
+
height: 0;
|
30
|
+
width: 0;
|
31
|
+
position: absolute;
|
32
|
+
pointer-events: none;
|
33
|
+
border-color: rgba($c-black, 0);
|
34
|
+
border-width: $size;
|
35
|
+
|
36
|
+
@if ($direction == top) {
|
37
|
+
bottom: 100%;
|
38
|
+
left: 7%;
|
39
|
+
margin-left: $size;
|
40
|
+
border-bottom-color: $color;
|
41
|
+
}
|
42
|
+
|
43
|
+
@if ($direction == bottom) {
|
44
|
+
top: 100%;
|
45
|
+
left: 50%;
|
46
|
+
border-top-color: $color;
|
47
|
+
margin-left: negate($size);
|
48
|
+
// border-width: $size;
|
49
|
+
}
|
50
|
+
|
51
|
+
@if ($direction == left) {
|
52
|
+
top: 20%;
|
53
|
+
left: 0;
|
54
|
+
margin-left: -$size * 2;
|
55
|
+
border-right-color: $color;
|
56
|
+
}
|
57
|
+
|
58
|
+
@if ($direction == right) {
|
59
|
+
top: 20%;
|
60
|
+
left: auto;
|
61
|
+
right: 0;
|
62
|
+
margin-right: -$size * 2;
|
63
|
+
border-left-color: $color;
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
@if ($shadow) {
|
68
|
+
&:before {
|
69
|
+
border: solid transparent;
|
70
|
+
content: ' ';
|
71
|
+
height: 0;
|
72
|
+
width: 0;
|
73
|
+
position: absolute;
|
74
|
+
pointer-events: none;
|
75
|
+
border-color: rgba($c-black, 0);
|
76
|
+
border-width: $size;
|
77
|
+
z-index: 2;
|
78
|
+
|
79
|
+
@if ($direction == left) {
|
80
|
+
top: 20%;
|
81
|
+
left: 0;
|
82
|
+
margin-left: -(($size * 2) + 1);
|
83
|
+
border-right-color: $shadow;
|
84
|
+
}
|
85
|
+
|
86
|
+
@if ($direction == top) {
|
87
|
+
bottom: 100%;
|
88
|
+
left: 7%;
|
89
|
+
margin-left: $size;
|
90
|
+
border-bottom-color: $shadow;
|
91
|
+
}
|
92
|
+
}
|
93
|
+
|
94
|
+
&:after {
|
95
|
+
z-index: 3;
|
96
|
+
}
|
97
|
+
}
|
98
|
+
}
|
99
|
+
|
100
|
+
// Clearfix
|
101
|
+
@mixin clearfix {
|
102
|
+
&:before,
|
103
|
+
&:after {
|
104
|
+
content: ' ';
|
105
|
+
display: table;
|
106
|
+
}
|
107
|
+
|
108
|
+
&:after {
|
109
|
+
clear: both;
|
110
|
+
}
|
111
|
+
}
|
112
|
+
|
113
|
+
// Throw it your list of css classes without periods and it'll return a z-index or nothing at all if the parent selector is not in the list
|
114
|
+
// @example
|
115
|
+
// $list: (
|
116
|
+
// '.modal-bg',
|
117
|
+
// '.modal-content'
|
118
|
+
// );
|
119
|
+
//
|
120
|
+
// .modal-bg {
|
121
|
+
// @include stack($list);
|
122
|
+
// }
|
123
|
+
@mixin stack($list, $element:false) {
|
124
|
+
$z: false;
|
125
|
+
|
126
|
+
@if $element {
|
127
|
+
$z: z($list, $element);
|
128
|
+
} @else {
|
129
|
+
$parents: &;
|
130
|
+
$target: length($parents);
|
131
|
+
$element: nth($parents, $target);
|
132
|
+
$z: z($list, inspect($element));
|
133
|
+
}
|
134
|
+
|
135
|
+
@if $z {
|
136
|
+
z-index: $z;
|
137
|
+
}
|
138
|
+
}
|
139
|
+
|
140
|
+
// Media Query Fun
|
141
|
+
// http://www.sitepoint.com/managing-responsive-breakpoints-sass/
|
142
|
+
@mixin bp($name, $breakpoint_list: $breakpoints) {
|
143
|
+
// If the key exists in the map
|
144
|
+
@if map-has-key($breakpoint_list, $name) {
|
145
|
+
// Prints a media query based on the value
|
146
|
+
@media #{inspect(map-get($breakpoint_list, $name))} {
|
147
|
+
@content;
|
148
|
+
}
|
149
|
+
} @else {
|
150
|
+
// If the key doesn't exist in the map
|
151
|
+
@warn "Unfortunately, no value with #{$name} could be retrieved from `$breakpoint`. "
|
152
|
+
+ 'Please make sure it is defined in `$breakpoints` map.';
|
153
|
+
}
|
154
|
+
}
|
155
|
+
|
156
|
+
// Style placeholder text at the root level or on an element
|
157
|
+
@mixin placeholder {
|
158
|
+
|
159
|
+
@if & {
|
160
|
+
|
161
|
+
&::-webkit-input-placeholder {
|
162
|
+
@content;
|
163
|
+
}
|
164
|
+
|
165
|
+
&::-moz-placeholder {
|
166
|
+
@content;
|
167
|
+
}
|
168
|
+
|
169
|
+
&:-ms-input-placeholder {
|
170
|
+
@content;
|
171
|
+
}
|
172
|
+
|
173
|
+
} @else {
|
174
|
+
|
175
|
+
// scss-lint:disable QualifyingElement
|
176
|
+
input[placeholder],
|
177
|
+
textarea[placeholder] {
|
178
|
+
@content;
|
179
|
+
}
|
180
|
+
|
181
|
+
::-moz-placeholder {
|
182
|
+
@content;
|
183
|
+
}
|
184
|
+
|
185
|
+
:-moz-placeholder {
|
186
|
+
@content;
|
187
|
+
}
|
188
|
+
|
189
|
+
::-webkit-input-placeholder {
|
190
|
+
@content;
|
191
|
+
}
|
192
|
+
|
193
|
+
:-ms-input-placeholder {
|
194
|
+
@content;
|
195
|
+
}
|
196
|
+
|
197
|
+
}
|
198
|
+
}
|
199
|
+
|
200
|
+
// IE
|
201
|
+
@mixin ie($version: '') {
|
202
|
+
@if & {
|
203
|
+
.ie#{unquote($version)} & {
|
204
|
+
@content;
|
205
|
+
}
|
206
|
+
} @else {
|
207
|
+
.ie#{unquote($version)} {
|
208
|
+
@content;
|
209
|
+
}
|
210
|
+
}
|
211
|
+
}
|
212
|
+
|
213
|
+
// Touch and mobile
|
214
|
+
@mixin touch {
|
215
|
+
@if & {
|
216
|
+
.touch & {
|
217
|
+
@content;
|
218
|
+
}
|
219
|
+
} @else {
|
220
|
+
.touch {
|
221
|
+
@content;
|
222
|
+
}
|
223
|
+
}
|
224
|
+
}
|
225
|
+
|
226
|
+
// Include the icomoon font properties
|
227
|
+
@mixin icomoon {
|
228
|
+
font-family: 'icomoon';
|
229
|
+
speak: none;
|
230
|
+
font-style: normal;
|
231
|
+
font-weight: normal;
|
232
|
+
font-variant: normal;
|
233
|
+
text-transform: none;
|
234
|
+
line-height: 1;
|
235
|
+
|
236
|
+
// Better Font Rendering
|
237
|
+
-webkit-font-smoothing: antialiased;
|
238
|
+
-moz-osx-font-smoothing: grayscale;
|
239
|
+
}
|
240
|
+
|
241
|
+
// Vertically center element
|
242
|
+
// http://zerosixthree.se/vertical-align-anything-with-just-3-lines-of-css/
|
243
|
+
@mixin vertical-center {
|
244
|
+
position: relative;
|
245
|
+
top: 50%;
|
246
|
+
transform: translateY(-50%);
|
247
|
+
}
|
248
|
+
|
249
|
+
/// Makes an item relatively sized according
|
250
|
+
/// to a ratio and the screen size
|
251
|
+
/// @param {number} $width
|
252
|
+
/// @param {number} $height
|
253
|
+
/// @example scss - aspect-ratio mixin
|
254
|
+
/// @include aspect-ratio(1, 0.8);
|
255
|
+
@mixin aspect-ratio($x, $y) {
|
256
|
+
|
257
|
+
@if (type-of($x) != number) or
|
258
|
+
(type-of($y) != number) {
|
259
|
+
@error 'You need to enter a number as the second and third paramaters.'
|
260
|
+
}
|
261
|
+
|
262
|
+
overflow: hidden;
|
263
|
+
|
264
|
+
&:before {
|
265
|
+
display: block;
|
266
|
+
content: "";
|
267
|
+
width: 100%;
|
268
|
+
padding-top: ($y / $x) * 100%;
|
269
|
+
}
|
270
|
+
|
271
|
+
> *:first-child {
|
272
|
+
position: absolute;
|
273
|
+
top: 0;
|
274
|
+
left: 0;
|
275
|
+
right: 0;
|
276
|
+
bottom: 0;
|
277
|
+
width: 100%;
|
278
|
+
height: 100%;
|
279
|
+
}
|
280
|
+
}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
// FINE Standard Breakpoints
|
2
|
+
$fine-breakpoints: (
|
3
|
+
'small' : ( min-width: 420px ),
|
4
|
+
'small-down' : ( max-width: 420px ),
|
5
|
+
'medium' : ( min-width: 768px ),
|
6
|
+
'medium-down' : ( max-width: 768px ),
|
7
|
+
'medium-only' : unquote('(min-width: 768px) and (max-width: 1024px)'),
|
8
|
+
'medium-portrait' : unquote('(min-width: 768px) and (max-width: 959px)'),
|
9
|
+
'large' : ( min-width: 1024px ),
|
10
|
+
'large-down' : ( max-width: 1024px ),
|
11
|
+
'print' : ( only print ),
|
12
|
+
'screen' : ( only screen ),
|
13
|
+
'retina' : unquote('only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2)'),
|
14
|
+
'portrait' : unquote('only screen and (orientation: portrait)'),
|
15
|
+
'landscape' : unquote('only screen and (orientation: landscape)'),
|
16
|
+
);
|
17
|
+
|
18
|
+
// Project $breakpoints map to guard against deletion in project _variables
|
19
|
+
$breakpoints: () !default;
|
20
|
+
|
21
|
+
$em-base: 16px !default;
|
22
|
+
|
23
|
+
$f-sans: 'Helvetica Neue', Helvetica, Arial, sans-serif;
|
24
|
+
$f-serif: Times New Roman, Georgia, serif;
|
25
|
+
$f-script: Brush Script MT, Trebuchet MS, 'Helvetica Neue', Helvetica, Arial, script;
|
26
|
+
$f-monospace: 'Bitstream Vera Sans Mono', Consolas, Monaco, Menlo, 'Andale Mono', monospace;
|
27
|
+
$f-international: 'Microsoft YaHei New', 'Microsoft Yahei', '微软雅黑', 宋体, SimSun, STXihei, '华文细黑', 'MS PGothic', $f-sans;
|
28
|
+
|
29
|
+
$c-white: #fff;
|
30
|
+
$c-black: #000;
|
@@ -0,0 +1,48 @@
|
|
1
|
+
.main-content {
|
2
|
+
position: relative;
|
3
|
+
min-height: 100%;
|
4
|
+
|
5
|
+
@include bp(large) {
|
6
|
+
min-height: calc(100% - 90px); // roughly the size of the header
|
7
|
+
}
|
8
|
+
|
9
|
+
&:before {
|
10
|
+
content: '';
|
11
|
+
position: absolute;
|
12
|
+
left: $sidenav-width - 10px;
|
13
|
+
top: 0;
|
14
|
+
width: 10px;
|
15
|
+
height: 100%;
|
16
|
+
}
|
17
|
+
}
|
18
|
+
|
19
|
+
.content {
|
20
|
+
padding: 30px $content-buffer;
|
21
|
+
padding-bottom: 0;
|
22
|
+
display: block; // IE, Safari don't treat <main> as a block element
|
23
|
+
|
24
|
+
&.-bottom-shim {
|
25
|
+
padding-bottom: 150px;
|
26
|
+
}
|
27
|
+
|
28
|
+
h2 {
|
29
|
+
padding: 17px $content-buffer;
|
30
|
+
color: pickForegroundColor($c-custom-highlight, $c-white, $c-black);
|
31
|
+
background: $c-custom-highlight;
|
32
|
+
border-top: 1px solid $c-border;
|
33
|
+
text-transform: uppercase;
|
34
|
+
font-size: 14px;
|
35
|
+
letter-spacing: .2em;
|
36
|
+
// counters the padding from .content
|
37
|
+
margin: 0 negate($content-buffer) 30px;
|
38
|
+
}
|
39
|
+
|
40
|
+
h3 {
|
41
|
+
display: block;
|
42
|
+
margin-bottom: 10px;
|
43
|
+
font-weight: bold;
|
44
|
+
font-size: 15px;
|
45
|
+
color: $c-text-heavy;
|
46
|
+
margin-bottom: 20px;
|
47
|
+
}
|
48
|
+
}
|