diff options
| -rw-r--r-- | Gemfile.lock | 4 | ||||
| -rw-r--r-- | app/assets/javascripts/application.js | 1 | ||||
| -rw-r--r-- | app/assets/stylesheets/application.scss | 1 | ||||
| -rw-r--r-- | app/views/home/index.html.haml | 12 | ||||
| -rw-r--r-- | app/views/layouts/_navigation.html.haml | 10 | ||||
| -rw-r--r-- | app/views/layouts/application.html.erb | 14 | ||||
| -rw-r--r-- | app/views/layouts/application.html.haml | 23 | ||||
| -rw-r--r-- | core/config/initializers/simple_form.rb | 307 | ||||
| -rw-r--r-- | core/config/initializers/simple_form_bootstrap.rb | 45 | ||||
| -rw-r--r-- | core/config/locales/simple_form.en.yml | 26 | ||||
| -rw-r--r-- | ui_dependencies.rb | 2 | ||||
| -rw-r--r-- | users/app/views/sessions/new.html.haml | 15 | ||||
| -rw-r--r-- | users/app/views/users/new.html.haml | 17 | ||||
| -rw-r--r-- | users/config/locales/en.yml | 6 | 
14 files changed, 266 insertions, 217 deletions
| diff --git a/Gemfile.lock b/Gemfile.lock index f731561..a982c2a 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -53,7 +53,7 @@ GEM        i18n (~> 0.6)        multi_json (~> 1.0)      arel (3.0.2) -    bootstrap-sass (2.0.4.2) +    bootstrap-sass (2.1.0.0)      builder (3.0.3)      coffee-rails (3.2.2)        coffee-script (>= 2.2.0) @@ -166,7 +166,7 @@ PLATFORMS    ruby  DEPENDENCIES -  bootstrap-sass (~> 2.0.4) +  bootstrap-sass (~> 2.1.0)    coffee-rails (~> 3.2.2)    haml (~> 3.1.7)    haml-rails (~> 0.3.4) diff --git a/app/assets/javascripts/application.js b/app/assets/javascripts/application.js index a0b89db..dc975d4 100644 --- a/app/assets/javascripts/application.js +++ b/app/assets/javascripts/application.js @@ -15,3 +15,4 @@  //= require srp  //= require users  //= require_tree . +//= require bootstrap diff --git a/app/assets/stylesheets/application.scss b/app/assets/stylesheets/application.scss index cbd46a7..72c943a 100644 --- a/app/assets/stylesheets/application.scss +++ b/app/assets/stylesheets/application.scss @@ -1 +1,2 @@  @import "bootstrap"; +@import "bootstrap-responsive"; diff --git a/app/views/home/index.html.haml b/app/views/home/index.html.haml index 68e39bb..0be7ca2 100644 --- a/app/views/home/index.html.haml +++ b/app/views/home/index.html.haml @@ -1,15 +1,3 @@ -%h1 Leap Web Demo  Try to fetch a   = link_to "cert", cert_path - --if current_user -  %p  -    logged in as -    = current_user.login -    = link_to "logout", logout_path --else -  %p -    = link_to "login", login_path -    or  -    = link_to "signup", signup_path diff --git a/app/views/layouts/_navigation.html.haml b/app/views/layouts/_navigation.html.haml new file mode 100644 index 0000000..04d2356 --- /dev/null +++ b/app/views/layouts/_navigation.html.haml @@ -0,0 +1,10 @@ += link_to "Leap Web", root_path, :class => 'brand' +%ul.nav +  - if current_user +    %li +      = link_to t(:logout), logout_path +  - else +    %li +      = link_to t(:login), login_path +    %li +      = link_to t(:signup), signup_path diff --git a/app/views/layouts/application.html.erb b/app/views/layouts/application.html.erb deleted file mode 100644 index ce68ec8..0000000 --- a/app/views/layouts/application.html.erb +++ /dev/null @@ -1,14 +0,0 @@ -<!DOCTYPE html> -<html> -<head> -  <title>LeapWeb</title> -  <%= stylesheet_link_tag    "application", :media => "all" %> -  <%= javascript_include_tag "application" %> -  <%= csrf_meta_tags %> -</head> -<body> - -<%= yield %> - -</body> -</html> diff --git a/app/views/layouts/application.html.haml b/app/views/layouts/application.html.haml new file mode 100644 index 0000000..a57d65e --- /dev/null +++ b/app/views/layouts/application.html.haml @@ -0,0 +1,23 @@ +!!! +%html +  %head +    %meta{:content => "width=device-width, initial-scale=1.0", :name => "viewport"} +      %title= content_for?(:title) ? yield(:title) : "Leap Web" +      %meta{:content => content_for?(:description) ? yield(:description) : "Leap Web", :name => "description"} +        = stylesheet_link_tag "application", :media => "all" +        = javascript_include_tag "application" +        = csrf_meta_tags +        = yield(:head) +  %body +    %header.navbar.navbar-fixed-top +      %nav.navbar-inner +        .container +          = render 'layouts/navigation' +    #main{:role => "main"} +      .container +        .content +          .row +            .span12 +              //= render 'layouts/messages' +              = yield +          %footer diff --git a/core/config/initializers/simple_form.rb b/core/config/initializers/simple_form.rb index b346dfa..e3f8d09 100644 --- a/core/config/initializers/simple_form.rb +++ b/core/config/initializers/simple_form.rb @@ -1,181 +1,142 @@  # Use this setup block to configure all options available in SimpleForm. +SimpleForm.setup do |config| +  # Wrappers are used by the form builder to generate a +  # complete input. You can remove any component from the +  # wrapper, change the order or even add your own to the +  # stack. The options given below are used to wrap the +  # whole input. +  config.wrappers :default, :class => :input, +    :hint_class => :field_with_hint, :error_class => :field_with_errors do |b| +    ## Extensions enabled by default +    # Any of these extensions can be disabled for a +    # given input by passing: `f.input EXTENSION_NAME => false`. +    # You can make any of these extensions optional by +    # renaming `b.use` to `b.optional`. + +    # Determines whether to use HTML5 (:email, :url, ...) +    # and required attributes +    b.use :html5 + +    # Calculates placeholders automatically from I18n +    # You can also pass a string as f.input :placeholder => "Placeholder" +    b.use :placeholder + +    ## Optional extensions +    # They are disabled unless you pass `f.input EXTENSION_NAME => :lookup` +    # to the input. If so, they will retrieve the values from the model +    # if any exists. If you want to enable the lookup for any of those +    # extensions by default, you can change `b.optional` to `b.use`. + +    # Calculates maxlength from length validations for string inputs +    b.optional :maxlength + +    # Calculates pattern from format validations for string inputs +    b.optional :pattern + +    # Calculates min and max from length validations for numeric inputs +    b.optional :min_max + +    # Calculates readonly automatically from readonly attributes +    b.optional :readonly + +    ## Inputs +    b.use :label_input +    b.use :hint,  :wrap_with => { :tag => :span, :class => :hint } +    b.use :error, :wrap_with => { :tag => :span, :class => :error } +  end -if defined? SimpleForm -  SimpleForm.setup do |config| -    # Wrappers are used by the form builder to generate a -    # complete input. You can remove any component from the -    # wrapper, change the order or even add your own to the -    # stack. The options given below are used to wrap the -    # whole input. -    config.wrappers :default, :class => :input, -      :hint_class => :field_with_hint, :error_class => :field_with_errors do |b| -      ## Extensions enabled by default -      # Any of these extensions can be disabled for a -      # given input by passing: `f.input EXTENSION_NAME => false`. -      # You can make any of these extensions optional by -      # renaming `b.use` to `b.optional`. - -      # Determines whether to use HTML5 (:email, :url, ...) -      # and required attributes -      b.use :html5 - -      # Calculates placeholders automatically from I18n -      # You can also pass a string as f.input :placeholder => "Placeholder" -      b.use :placeholder - -      ## Optional extensions -      # They are disabled unless you pass `f.input EXTENSION_NAME => :lookup` -      # to the input. If so, they will retrieve the values from the model -      # if any exists. If you want to enable the lookup for any of those -      # extensions by default, you can change `b.optional` to `b.use`. - -      # Calculates maxlength from length validations for string inputs -      b.optional :maxlength - -      # Calculates pattern from format validations for string inputs -      b.optional :pattern - -      # Calculates min and max from length validations for numeric inputs -      b.optional :min_max - -      # Calculates readonly automatically from readonly attributes -      b.optional :readonly - -      ## Inputs -      b.use :label_input -      b.use :hint,  :wrap_with => { :tag => :span, :class => :hint } -      b.use :error, :wrap_with => { :tag => :span, :class => :error } -      end - -    config.wrappers :bootstrap, :tag => 'div', :class => 'control-group', :error_class => 'error' do |b| -      b.use :html5 -      b.use :placeholder -      b.use :label -      b.wrapper :tag => 'div', :class => 'controls' do |ba| -        ba.use :input -        ba.use :error, :wrap_with => { :tag => 'span', :class => 'help-inline' } -        ba.use :hint,  :wrap_with => { :tag => 'p', :class => 'help-block' } -      end -    end - -    config.wrappers :prepend, :tag => 'div', :class => "control-group", :error_class => 'error' do |b| -      b.use :html5 -      b.use :placeholder -      b.use :label -      b.wrapper :tag => 'div', :class => 'controls' do |input| -        input.wrapper :tag => 'div', :class => 'input-prepend' do |prepend| -          prepend.use :input -        end -        input.use :hint,  :wrap_with => { :tag => 'span', :class => 'help-block' } -        input.use :error, :wrap_with => { :tag => 'span', :class => 'help-inline' } -      end -    end - -    config.wrappers :append, :tag => 'div', :class => "control-group", :error_class => 'error' do |b| -      b.use :html5 -      b.use :placeholder -      b.use :label -      b.wrapper :tag => 'div', :class => 'controls' do |input| -        input.wrapper :tag => 'div', :class => 'input-append' do |append| -          append.use :input -        end -        input.use :hint,  :wrap_with => { :tag => 'span', :class => 'help-block' } -        input.use :error, :wrap_with => { :tag => 'span', :class => 'help-inline' } -      end -    end - -    # Wrappers for forms and inputs using the Twitter Bootstrap toolkit. -    # Check the Bootstrap docs (http://twitter.github.com/bootstrap) -    # to learn about the different styles for forms and inputs, -    # buttons and other elements. -    config.default_wrapper = :bootstrap - -    # Define the way to render check boxes / radio buttons with labels. -    # Defaults to :nested for bootstrap config. -    #   :inline => input + label -    #   :nested => label > input -    config.boolean_style = :nested - -    # Default class for buttons -    config.button_class = 'btn' - -    # Method used to tidy up errors. Specify any Rails Array method. -    # :first lists the first message for each field. -    # Use :to_sentence to list all errors for each field. -    # config.error_method = :first - -    # Default tag used for error notification helper. -    config.error_notification_tag = :div - -    # CSS class to add for error notification helper. -    config.error_notification_class = 'alert alert-error' - -    # ID to add for error notification helper. -    # config.error_notification_id = nil - -    # Series of attempts to detect a default label method for collection. -    # config.collection_label_methods = [ :to_label, :name, :title, :to_s ] - -    # Series of attempts to detect a default value method for collection. -    # config.collection_value_methods = [ :id, :to_s ] - -    # You can wrap a collection of radio/check boxes in a pre-defined tag, defaulting to none. -    # config.collection_wrapper_tag = nil - -    # You can define the class to use on all collection wrappers. Defaulting to none. -    # config.collection_wrapper_class = nil - -    # You can wrap each item in a collection of radio/check boxes with a tag, -    # defaulting to :span. Please note that when using :boolean_style = :nested, -    # SimpleForm will force this option to be a label. -    # config.item_wrapper_tag = :span - -    # You can define a class to use in all item wrappers. Defaulting to none. -    # config.item_wrapper_class = nil - -    # How the label text should be generated altogether with the required text. -    # config.label_text = lambda { |label, required| "#{required} #{label}" } - -    # You can define the class to use on all labels. Default is nil. -    config.label_class = 'control-label' - -    # You can define the class to use on all forms. Default is simple_form. -    config.form_class = 'form-horizontal' - -    # You can define which elements should obtain additional classes -    # config.generate_additional_classes_for = [:wrapper, :label, :input] - -    # Whether attributes are required by default (or not). Default is true. -    # config.required_by_default = true - -    # Tell browsers whether to use default HTML5 validations (novalidate option). -    # Default is enabled. -    config.browser_validations = true - -    # Collection of methods to detect if a file type was given. -    # config.file_methods = [ :mounted_as, :file?, :public_filename ] - -    # Custom mappings for input types. This should be a hash containing a regexp -    # to match as key, and the input type that will be used when the field name -    # matches the regexp as value. -    # config.input_mappings = { /count/ => :integer } - -    # Default priority for time_zone inputs. -    # config.time_zone_priority = nil +  # The default wrapper to be used by the FormBuilder. +  config.default_wrapper = :default -    # Default priority for country inputs. -    # config.country_priority = nil +  # Define the way to render check boxes / radio buttons with labels. +  # Defaults to :nested for bootstrap config. +  #   :inline => input + label +  #   :nested => label > input +  config.boolean_style = :nested -    # Default size for text inputs. -    # config.default_input_size = 50 +  # Default class for buttons +  config.button_class = 'btn' -    # When false, do not use translations for labels. -    # config.translate_labels = true +  # Method used to tidy up errors. Specify any Rails Array method. +  # :first lists the first message for each field. +  # Use :to_sentence to list all errors for each field. +  # config.error_method = :first -    # Automatically discover new inputs in Rails' autoload path. -    # config.inputs_discovery = true +  # Default tag used for error notification helper. +  config.error_notification_tag = :div -    # Cache SimpleForm inputs discovery -    # config.cache_discovery = !Rails.env.development? -  end +  # CSS class to add for error notification helper. +  config.error_notification_class = 'alert alert-error' + +  # ID to add for error notification helper. +  # config.error_notification_id = nil + +  # Series of attempts to detect a default label method for collection. +  # config.collection_label_methods = [ :to_label, :name, :title, :to_s ] + +  # Series of attempts to detect a default value method for collection. +  # config.collection_value_methods = [ :id, :to_s ] + +  # You can wrap a collection of radio/check boxes in a pre-defined tag, defaulting to none. +  # config.collection_wrapper_tag = nil + +  # You can define the class to use on all collection wrappers. Defaulting to none. +  # config.collection_wrapper_class = nil + +  # You can wrap each item in a collection of radio/check boxes with a tag, +  # defaulting to :span. Please note that when using :boolean_style = :nested, +  # SimpleForm will force this option to be a label. +  # config.item_wrapper_tag = :span + +  # You can define a class to use in all item wrappers. Defaulting to none. +  # config.item_wrapper_class = nil + +  # How the label text should be generated altogether with the required text. +  # config.label_text = lambda { |label, required| "#{required} #{label}" } + +  # You can define the class to use on all labels. Default is nil. +  config.label_class = 'control-label' + +  # You can define the class to use on all forms. Default is simple_form. +  # config.form_class = :simple_form + +  # You can define which elements should obtain additional classes +  # config.generate_additional_classes_for = [:wrapper, :label, :input] + +  # Whether attributes are required by default (or not). Default is true. +  # config.required_by_default = true + +  # Tell browsers whether to use default HTML5 validations (novalidate option). +  # Default is enabled. +  config.browser_validations = false + +  # Collection of methods to detect if a file type was given. +  # config.file_methods = [ :mounted_as, :file?, :public_filename ] + +  # Custom mappings for input types. This should be a hash containing a regexp +  # to match as key, and the input type that will be used when the field name +  # matches the regexp as value. +  # config.input_mappings = { /count/ => :integer } + +  # Custom wrappers for input types. This should be a hash containing an input +  # type as key and the wrapper that will be used for all inputs with specified type. +  # config.wrapper_mappings = { :string => :prepend } + +  # Default priority for time_zone inputs. +  # config.time_zone_priority = nil + +  # Default priority for country inputs. +  # config.country_priority = nil + +  # Default size for text inputs. +  # config.default_input_size = 50 + +  # When false, do not use translations for labels. +  # config.translate_labels = true + +  # Automatically discover new inputs in Rails' autoload path. +  # config.inputs_discovery = true + +  # Cache SimpleForm inputs discovery +  # config.cache_discovery = !Rails.env.development?  end diff --git a/core/config/initializers/simple_form_bootstrap.rb b/core/config/initializers/simple_form_bootstrap.rb new file mode 100644 index 0000000..1a22967 --- /dev/null +++ b/core/config/initializers/simple_form_bootstrap.rb @@ -0,0 +1,45 @@ +# Use this setup block to configure all options available in SimpleForm. +SimpleForm.setup do |config| +  config.wrappers :bootstrap, :tag => 'div', :class => 'control-group', :error_class => 'error' do |b| +    b.use :html5 +    b.use :placeholder +    b.use :label +    b.wrapper :tag => 'div', :class => 'controls' do |ba| +      ba.use :input +      ba.use :error, :wrap_with => { :tag => 'span', :class => 'help-inline' } +      ba.use :hint,  :wrap_with => { :tag => 'p', :class => 'help-block' } +    end +  end + +  config.wrappers :prepend, :tag => 'div', :class => "control-group", :error_class => 'error' do |b| +    b.use :html5 +    b.use :placeholder +    b.use :label +    b.wrapper :tag => 'div', :class => 'controls' do |input| +      input.wrapper :tag => 'div', :class => 'input-prepend' do |prepend| +        prepend.use :input +      end +      input.use :hint,  :wrap_with => { :tag => 'span', :class => 'help-block' } +      input.use :error, :wrap_with => { :tag => 'span', :class => 'help-inline' } +    end +  end + +  config.wrappers :append, :tag => 'div', :class => "control-group", :error_class => 'error' do |b| +    b.use :html5 +    b.use :placeholder +    b.use :label +    b.wrapper :tag => 'div', :class => 'controls' do |input| +      input.wrapper :tag => 'div', :class => 'input-append' do |append| +        append.use :input +      end +      input.use :hint,  :wrap_with => { :tag => 'span', :class => 'help-block' } +      input.use :error, :wrap_with => { :tag => 'span', :class => 'help-inline' } +    end +  end + +  # Wrappers for forms and inputs using the Twitter Bootstrap toolkit. +  # Check the Bootstrap docs (http://twitter.github.com/bootstrap) +  # to learn about the different styles for forms and inputs, +  # buttons and other elements. +  config.default_wrapper = :bootstrap +end diff --git a/core/config/locales/simple_form.en.yml b/core/config/locales/simple_form.en.yml new file mode 100644 index 0000000..0df11fe --- /dev/null +++ b/core/config/locales/simple_form.en.yml @@ -0,0 +1,26 @@ +en: +  simple_form: +    "yes": 'Yes' +    "no": 'No' +    required: +      text: 'required' +      mark: '*' +      # You can uncomment the line below if you need to overwrite the whole required html. +      # When using html, text and mark won't be used. +      # html: '<abbr title="required">*</abbr>' +    error_notification: +      default_message: "Please review the problems below:" +    # Labels and hints examples +    # labels: +    #   defaults: +    #     password: 'Password' +    #   user: +    #     new: +    #       email: 'E-mail to sign in.' +    #     edit: +    #       email: 'E-mail.' +    # hints: +    #   defaults: +    #     username: 'User name to sign in.' +    #     password: 'No special characters, please.' + diff --git a/ui_dependencies.rb b/ui_dependencies.rb index 21de1c6..9b9f853 100644 --- a/ui_dependencies.rb +++ b/ui_dependencies.rb @@ -1,5 +1,5 @@  gem "haml", "~> 3.1.7" -gem "bootstrap-sass", "~> 2.0.4" +gem "bootstrap-sass", "~> 2.1.0"  gem "jquery-rails"  gem "simple_form" diff --git a/users/app/views/sessions/new.html.haml b/users/app/views/sessions/new.html.haml index 39ee7bf..c91d3f2 100644 --- a/users/app/views/sessions/new.html.haml +++ b/users/app/views/sessions/new.html.haml @@ -1,7 +1,8 @@ -%h2=t :login -= simple_form_for :session, :url => sessions_path, :html => { :id => :new_session } do |f| -  %legend=t :login_message -  = f.input :login, :input_html => { :id => :srp_username } -  = f.input :password, :required => true, :input_html => { :id => :srp_password } -  = f.button :submit, :value => t(:login), :class => 'btn-primary'  -  = link_to t(:cancel), root_url, :class => :btn +.span8.offset2 +  %h2=t :login +  = simple_form_for :session, :url => sessions_path, :html => { :id => :new_session, :class => 'form-horizontal' } do |f| +    %legend=t :login_message +    = f.input :login, :input_html => { :id => :srp_username } +    = f.input :password, :required => true, :input_html => { :id => :srp_password } +    = f.button :submit, :value => t(:login), :class => 'btn-primary'  +    = link_to t(:cancel), root_url, :class => :btn diff --git a/users/app/views/users/new.html.haml b/users/app/views/users/new.html.haml index af53331..835e99a 100644 --- a/users/app/views/users/new.html.haml +++ b/users/app/views/users/new.html.haml @@ -1,8 +1,9 @@ -%h2=t :signup -= simple_form_for @user do |f| -  %legend=t :signup_message -  = f.input :login, :input_html => { :id => :srp_username } -  = f.input :password, :required => true, :input_html => { :id => :srp_password } -  = f.input :password_confirmation, :required => true, :input_html => { :id => :srp_password_confirmation } -  = f.button :submit, :value => t(:signup), :class => 'btn-primary'  -  = link_to t(:cancel), root_url, :class => :btn +.span8.offset2 +  %h2=t :signup +  = simple_form_for @user, :html => {:class => 'form-horizontal'} do |f| +    %legend=t :signup_message +    = f.input :login, :input_html => { :id => :srp_username } +    = f.input :password, :required => true, :input_html => { :id => :srp_password } +    = f.input :password_confirmation, :required => true, :input_html => { :id => :srp_password_confirmation } +    = f.button :submit, :value => t(:signup), :class => 'btn-primary'  +    = link_to t(:cancel), root_url, :class => :btn diff --git a/users/config/locales/en.yml b/users/config/locales/en.yml new file mode 100644 index 0000000..172b85f --- /dev/null +++ b/users/config/locales/en.yml @@ -0,0 +1,6 @@ +en: +  signup: "Sign up" +  signup_message: "Please create an account." +  cancel: "Cancel" +  login: "Login" +  login_message: "Please login with your account." | 
