Browse Source

Registration form more-or-less working, workshop scaffold is up

development
Godwin 10 years ago
parent
commit
3d6ad3b432
  1. 5
      DB specs.txt
  2. 3
      app/assets/javascripts/workshops.js.coffee
  3. 3
      app/assets/stylesheets/workshops.css.scss
  4. 13
      app/controllers/conferences_controller.rb
  5. 58
      app/controllers/workshops_controller.rb
  6. 65
      app/helpers/application_helper.rb
  7. 2
      app/helpers/workshops_helper.rb
  8. 8
      app/models/registration_form_field.rb
  9. 2
      app/models/workshop.rb
  10. 5
      app/views/conferences/_registration_register.html.haml
  11. 40
      app/views/workshops/_form.html.haml
  12. 7
      app/views/workshops/edit.html.haml
  13. 37
      app/views/workshops/index.html.haml
  14. 5
      app/views/workshops/new.html.haml
  15. 36
      app/views/workshops/show.html.haml
  16. 2
      config/routes.rb
  17. 18
      db/migrate/20140314025647_create_workshops.rb
  18. 17
      db/schema.rb
  19. 49
      test/controllers/workshops_controller_test.rb
  20. 16
      test/factories/workshops.rb
  21. 4
      test/helpers/workshops_helper_test.rb
  22. 7
      test/models/workshop_test.rb

5
DB specs.txt

@ -106,4 +106,7 @@ workshop
- slug : string
- info : text
rails g scaffold
rails g scaffold workshop title:string slug:string info:text conference_id:integer workshop_stream_id:integer workshop_presentation_style:integer min_facilitators:integer location_id:integer start_time:datetime end_time:datetime
- requested_resources : NtoN[workshop_resource]
- facilitators : NtoN[user]

3
app/assets/javascripts/workshops.js.coffee

@ -0,0 +1,3 @@
# Place all the behaviors and hooks related to the matching controller here.
# All this logic will automatically be available in application.js.
# You can use CoffeeScript in this file: http://coffeescript.org/

3
app/assets/stylesheets/workshops.css.scss

@ -0,0 +1,3 @@
// Place all the styles related to the workshops controller here.
// They will automatically be included in application.css.
// You can use Sass (SCSS) here: http://sass-lang.com/

13
app/controllers/conferences_controller.rb

@ -37,6 +37,7 @@ class ConferencesController < ApplicationController
registration = ConferenceRegistration.find_by(:user_id => current_user.id, :conference_id => @conference.id)
if registration
registration.conference_registration_responses.destroy_all
registration.is_attending = params[:is_attending]
else
registration = ConferenceRegistration.new(user_id: current_user.id, conference_id: @conference.id, is_attending: params[:is_attending])
end
@ -53,7 +54,7 @@ class ConferencesController < ApplicationController
end
end
data.each do |key, value|
registration.conference_registration_responses << ConferenceRegistrationResponse.new(registration_form_field_id: key.to_i, data: value.to_json.to_s)
registration.conference_registration_responses << ConferenceRegistrationResponse.new(registration_form_field_id: key.to_i, data: value.to_json)
end
registration.save!
render action: 'show'
@ -134,6 +135,16 @@ class ConferencesController < ApplicationController
# Use callbacks to share common setup or constraints between actions.
def set_conference
@conference = Conference.find_by(slug: params[:slug] || params[:conference_slug])
set_conference_registration
end
def set_conference_registration
if !@conference || !current_user
@conference_registration = nil
return
end
@conference_registration = ConferenceRegistration.find_by(conference_id: @conference.id, user_id: current_user.id)
end
# Only allow a trusted parameter "white list" through.

58
app/controllers/workshops_controller.rb

@ -0,0 +1,58 @@
class WorkshopsController < ApplicationController
before_action :set_workshop, only: [:show, :edit, :update, :destroy]
# GET /workshops
def index
@workshops = Workshop.all
end
# GET /workshops/1
def show
end
# GET /workshops/new
def new
@workshop = Workshop.new
end
# GET /workshops/1/edit
def edit
end
# POST /workshops
def create
@workshop = Workshop.new(workshop_params)
if @workshop.save
redirect_to @workshop, notice: 'Workshop was successfully created.'
else
render action: 'new'
end
end
# PATCH/PUT /workshops/1
def update
if @workshop.update(workshop_params)
redirect_to @workshop, notice: 'Workshop was successfully updated.'
else
render action: 'edit'
end
end
# DELETE /workshops/1
def destroy
@workshop.destroy
redirect_to workshops_url, notice: 'Workshop was successfully destroyed.'
end
private
# Use callbacks to share common setup or constraints between actions.
def set_workshop
@workshop = Workshop.find(params[:id])
end
# Only allow a trusted parameter "white list" through.
def workshop_params
params.require(:workshop).permit(:title, :slug, :info, :conference_id, :workshop_stream_id, :workshop_presentation_style, :min_facilitators, :location_id, :start_time, :end_time)
end
end

65
app/helpers/application_helper.rb

@ -90,7 +90,7 @@ module ApplicationHelper
return nil
end
def _(key, behavior = nil, behavior_size = nil, fake: nil, vars: {}, html: nil, blockData: {}, &block)
def _(key, behavior = nil, behavior_size = nil, vars: {}, html: nil, blockData: {}, &block)
queued_keys = nil
result = nil
@ -201,7 +201,7 @@ module ApplicationHelper
end
end
def field(form, name, type = nil, param = nil, html: nil, help: false, attrs: [], classes: nil, label: nil, placeholder: nil)
def field(form, name, type = nil, param = nil, html: nil, help: false, attrs: [], classes: nil, label: nil, placeholder: nil, value: nil, checked: nil)
if form.is_a?(Symbol) || form.is_a?(String)
param = type
@ -228,18 +228,24 @@ module ApplicationHelper
select_prompt = nil
show_label = true
label_after = true
value_attribute = !form
if /select(_tag)?$/.match(type.to_s)
placeholder = nil
if !label
select_prompt = 'Select a ' + name.to_s
select_prompt = placeholder || (form ? 'Select a ' + name.to_s : 'Select one')
label_html = ''
show_label = false
end
label_after = false
if param && param.is_a?(Array)
param = options_for_select(param)
placeholder = nil
label_after = false
if param
if param.is_a?(Array)
param = options_for_select(param, value)
elsif param.is_a?(Hash)
param = options_from_collection_for_select(param, :first, :last, value)
end
end
value_attribute = false
elsif type.to_s == 'image_field' || type.to_s == 'user_select_field' || type.to_s == 'organization_select_field'
placeholder = nil
label_html = ''
@ -316,14 +322,29 @@ module ApplicationHelper
end
else
ph = ''
va = ''
if value_attribute
if /^(check_box|radio_button)/.match(type.to_s)
if checked === nil
checked = value == "on" || value.to_s == "1"
end
if /^(radio_button)/.match(type.to_s)
va = ', "' + value + '", checked'
else
va = ', "1", checked'
end
else
va = ', value'
end
end
if placeholder
if form
ph = ", :placeholder => '#{placeholder}'"
else
ph = ", nil, placeholder: '#{placeholder}'"
ph = ", placeholder: '#{placeholder}'"
end
end
form_html = (form ? "form.#{type} :#{name}" : "#{type} :#{name}") + ph + (param ? ', param' : '')
form_html = (form ? "form.#{type} :#{name}" : "#{type} :#{name}") + va + ph + (param ? ', param' : '')
attrs.each_index { |i| form_html += (i >= attrs_used ? ', attrs[' + i.to_s + ']' : '') }
if select_prompt
if form
@ -451,10 +472,11 @@ module ApplicationHelper
('<p>' + object.send(attribute.to_s).strip.gsub(/\s*\n+\s*/, '</p><p>') + '</p>').html_safe
end
def form_field(f)
def form_field(f, response = nil)
id = 'field_' + f.id.to_s
html = p(f, 'title')#'<label for="' + id + '">' + f.title + '</label>'
#options = ActiveSupport::JSON.decode(options)#JSON.parse(f.options)
options = JSON.parse(f.options)
if f.field_type == 'multiple'
if f.help
@ -466,12 +488,27 @@ module ApplicationHelper
kv = value.split(/\s*\|\s*/, 2)
opts[kv[0]] = kv[1]
end
opts.each do |key, value|
#html += self.send(options['selection_type'] + '_tag', 'field-' + id)
html += field((id + '_' + key), options['selection_type'] + '_tag', label: value)
val = response ? ActiveSupport::JSON.decode(response.data) : Hash.new
#val = nil
if f.repeats?
is_array = f.is_array?
opts.each do |key, value|
#html += self.send(options['selection_type'] + '_tag', 'field-' + id)
#ActiveSupport::JSON.decode(key)
if is_array
#x
end
html += field((id + (is_array ? ('_' + key) : '')).to_sym, options['selection_type'] + '_tag', label: value, value: is_array ? (val ? val[key] : nil) : key, checked: is_array ? (val[key] == "1" || val[key] == "on") : val.to_s == key.to_s)
end
else
html += field(id.to_sym, options['selection_type'] + '_tag', opts, value: val)
end
#html += collection_check_boxes nil, nil, opts, nil, :key
else
html += field(id.to_sym, options['input_type'] + '_tag', label: false, placeholder: f.help)
#x
html += field(id.to_sym, options['input_type'] + '_tag', label: false, placeholder: f.help, value: response ? ActiveSupport::JSON.decode(response.data) : nil)
end
html.html_safe

2
app/helpers/workshops_helper.rb

@ -0,0 +1,2 @@
module WorkshopsHelper
end

8
app/models/registration_form_field.rb

@ -56,6 +56,14 @@ class RegistrationFormField < ActiveRecord::Base
o
end
def repeats?()
field_type.to_s == 'multiple' && selection_type.to_s != 'select'
end
def is_array?()
field_type.to_s == 'multiple' && selection_type.to_s != 'radio_button'
end
private
def get_from_options(key)
if options

2
app/models/workshop.rb

@ -0,0 +1,2 @@
class Workshop < ActiveRecord::Base
end

5
app/views/conferences/_registration_register.html.haml

@ -1,7 +1,8 @@
.columns.medium-8
= field :is_attending, :select_tag, ConferenceRegistration::AttendingOptions, label: 'Are you attending?'
= field :is_attending, :select_tag, ConferenceRegistration::AttendingOptions, label: 'Are you attending?', value: @conference_registration.try(:is_attending)
%ol
- @conference.registration_form_fields.each do |ff|
%li
= form_field ff
- response = @conference_registration ? ConferenceRegistrationResponse.find_by(conference_registration_id: @conference_registration.id, registration_form_field_id: ff.id) : nil
= form_field ff, response
= actions :register

40
app/views/workshops/_form.html.haml

@ -0,0 +1,40 @@
= form_for @workshop do |f|
- if @workshop.errors.any?
#error_explanation
%h2= "#{pluralize(@workshop.errors.count, "error")} prohibited this workshop from being saved:"
%ul
- @workshop.errors.full_messages.each do |msg|
%li= msg
.field
= f.label :title
= f.text_field :title
.field
= f.label :slug
= f.text_field :slug
.field
= f.label :info
= f.text_area :info
.field
= f.label :conference_id
= f.number_field :conference_id
.field
= f.label :workshop_stream_id
= f.number_field :workshop_stream_id
.field
= f.label :workshop_presentation_style
= f.number_field :workshop_presentation_style
.field
= f.label :min_facilitators
= f.number_field :min_facilitators
.field
= f.label :location_id
= f.number_field :location_id
.field
= f.label :start_time
= f.datetime_select :start_time
.field
= f.label :end_time
= f.datetime_select :end_time
.actions
= f.submit 'Save'

7
app/views/workshops/edit.html.haml

@ -0,0 +1,7 @@
%h1 Editing workshop
= render 'form'
= link_to 'Show', @workshop
\|
= link_to 'Back', workshops_path

37
app/views/workshops/index.html.haml

@ -0,0 +1,37 @@
%h1 Listing workshops
%table
%tr
%th Title
%th Slug
%th Info
%th Conference
%th Workshop stream
%th Workshop presentation style
%th Min facilitators
%th Location
%th Start time
%th End time
%th
%th
%th
- @workshops.each do |workshop|
%tr
%td= workshop.title
%td= workshop.slug
%td= workshop.info
%td= workshop.conference_id
%td= workshop.workshop_stream_id
%td= workshop.workshop_presentation_style
%td= workshop.min_facilitators
%td= workshop.location_id
%td= workshop.start_time
%td= workshop.end_time
%td= link_to 'Show', workshop
%td= link_to 'Edit', edit_workshop_path(workshop)
%td= link_to 'Destroy', workshop, :method => :delete, :data => { :confirm => 'Are you sure?' }
%br
= link_to 'New Workshop', new_workshop_path

5
app/views/workshops/new.html.haml

@ -0,0 +1,5 @@
%h1 New workshop
= render 'form'
= link_to 'Back', workshops_path

36
app/views/workshops/show.html.haml

@ -0,0 +1,36 @@
%p#notice= notice
%p
%b Title:
= @workshop.title
%p
%b Slug:
= @workshop.slug
%p
%b Info:
= @workshop.info
%p
%b Conference:
= @workshop.conference_id
%p
%b Workshop stream:
= @workshop.workshop_stream_id
%p
%b Workshop presentation style:
= @workshop.workshop_presentation_style
%p
%b Min facilitators:
= @workshop.min_facilitators
%p
%b Location:
= @workshop.location_id
%p
%b Start time:
= @workshop.start_time
%p
%b End time:
= @workshop.end_time
= link_to 'Edit', edit_workshop_path(@workshop)
\|
= link_to 'Back', workshops_path

2
config/routes.rb

@ -1,5 +1,7 @@
BikeBike::Application.routes.draw do
resources :workshops
#resources :conference_registration_responses
#resources :conference_registrations

18
db/migrate/20140314025647_create_workshops.rb

@ -0,0 +1,18 @@
class CreateWorkshops < ActiveRecord::Migration
def change
create_table :workshops do |t|
t.string :title
t.string :slug
t.text :info
t.integer :conference_id
t.integer :workshop_stream_id
t.integer :workshop_presentation_style
t.integer :min_facilitators
t.integer :location_id
t.datetime :start_time
t.datetime :end_time
t.timestamps
end
end
end

17
db/schema.rb

@ -11,7 +11,7 @@
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 20140308173325) do
ActiveRecord::Schema.define(version: 20140314025647) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
@ -228,4 +228,19 @@ ActiveRecord::Schema.define(version: 20140308173325) do
t.datetime "updated_at"
end
create_table "workshops", force: true do |t|
t.string "title"
t.string "slug"
t.text "info"
t.integer "conference_id"
t.integer "workshop_stream_id"
t.integer "workshop_presentation_style"
t.integer "min_facilitators"
t.integer "location_id"
t.datetime "start_time"
t.datetime "end_time"
t.datetime "created_at"
t.datetime "updated_at"
end
end

49
test/controllers/workshops_controller_test.rb

@ -0,0 +1,49 @@
require 'test_helper'
class WorkshopsControllerTest < ActionController::TestCase
setup do
@workshop = workshops(:one)
end
test "should get index" do
get :index
assert_response :success
assert_not_nil assigns(:workshops)
end
test "should get new" do
get :new
assert_response :success
end
test "should create workshop" do
assert_difference('Workshop.count') do
post :create, workshop: { conference_id: @workshop.conference_id, end_time: @workshop.end_time, info: @workshop.info, location_id: @workshop.location_id, min_facilitators: @workshop.min_facilitators, slug: @workshop.slug, start_time: @workshop.start_time, title: @workshop.title, workshop_presentation_style: @workshop.workshop_presentation_style, workshop_stream_id: @workshop.workshop_stream_id }
end
assert_redirected_to workshop_path(assigns(:workshop))
end
test "should show workshop" do
get :show, id: @workshop
assert_response :success
end
test "should get edit" do
get :edit, id: @workshop
assert_response :success
end
test "should update workshop" do
patch :update, id: @workshop, workshop: { conference_id: @workshop.conference_id, end_time: @workshop.end_time, info: @workshop.info, location_id: @workshop.location_id, min_facilitators: @workshop.min_facilitators, slug: @workshop.slug, start_time: @workshop.start_time, title: @workshop.title, workshop_presentation_style: @workshop.workshop_presentation_style, workshop_stream_id: @workshop.workshop_stream_id }
assert_redirected_to workshop_path(assigns(:workshop))
end
test "should destroy workshop" do
assert_difference('Workshop.count', -1) do
delete :destroy, id: @workshop
end
assert_redirected_to workshops_path
end
end

16
test/factories/workshops.rb

@ -0,0 +1,16 @@
# Read about factories at https://github.com/thoughtbot/factory_girl
FactoryGirl.define do
factory :workshop do
title "MyString"
slug "MyString"
info "MyText"
conference_id 1
workshop_stream_id 1
workshop_presentation_style 1
min_facilitators 1
location_id 1
start_time "2014-03-13 20:56:47"
end_time "2014-03-13 20:56:47"
end
end

4
test/helpers/workshops_helper_test.rb

@ -0,0 +1,4 @@
require 'test_helper'
class WorkshopsHelperTest < ActionView::TestCase
end

7
test/models/workshop_test.rb

@ -0,0 +1,7 @@
require 'test_helper'
class WorkshopTest < ActiveSupport::TestCase
# test "the truth" do
# assert true
# end
end
Loading…
Cancel
Save