Registration form more-or-less working, workshop scaffold is up
This commit is contained in:
		
							parent
							
								
									4b79de7a24
								
							
						
					
					
						commit
						3d6ad3b432
					
				@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								app/assets/javascripts/workshops.js.coffee
									
									
									
									
									
										Normal file
									
								
							@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								app/assets/stylesheets/workshops.css.scss
									
									
									
									
									
										Normal file
									
								
							@ -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/
 | 
			
		||||
@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								app/controllers/workshops_controller.rb
									
									
									
									
									
										Normal file
									
								
							@ -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
 | 
			
		||||
@ -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
 | 
			
		||||
			placeholder = nil
 | 
			
		||||
			label_after = false
 | 
			
		||||
			if param && param.is_a?(Array)
 | 
			
		||||
				param = options_for_select(param)
 | 
			
		||||
			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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								app/helpers/workshops_helper.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,2 @@
 | 
			
		||||
module WorkshopsHelper
 | 
			
		||||
end
 | 
			
		||||
@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								app/models/workshop.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,2 @@
 | 
			
		||||
class Workshop < ActiveRecord::Base
 | 
			
		||||
end
 | 
			
		||||
@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								app/views/workshops/_form.html.haml
									
									
									
									
									
										Normal file
									
								
							@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								app/views/workshops/edit.html.haml
									
									
									
									
									
										Normal file
									
								
							@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								app/views/workshops/index.html.haml
									
									
									
									
									
										Normal file
									
								
							@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								app/views/workshops/new.html.haml
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,5 @@
 | 
			
		||||
%h1 New workshop
 | 
			
		||||
 | 
			
		||||
= render 'form'
 | 
			
		||||
 | 
			
		||||
= link_to 'Back', workshops_path
 | 
			
		||||
							
								
								
									
										36
									
								
								app/views/workshops/show.html.haml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								app/views/workshops/show.html.haml
									
									
									
									
									
										Normal file
									
								
							@ -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
 | 
			
		||||
@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								db/migrate/20140314025647_create_workshops.rb
									
									
									
									
									
										Normal file
									
								
							@ -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
									
									
									
									
									
								
							
							
						
						
									
										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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								test/controllers/workshops_controller_test.rb
									
									
									
									
									
										Normal file
									
								
							@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								test/factories/workshops.rb
									
									
									
									
									
										Normal file
									
								
							@ -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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								test/helpers/workshops_helper_test.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,4 @@
 | 
			
		||||
require 'test_helper'
 | 
			
		||||
 | 
			
		||||
class WorkshopsHelperTest < ActionView::TestCase
 | 
			
		||||
end
 | 
			
		||||
							
								
								
									
										7
									
								
								test/models/workshop_test.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								test/models/workshop_test.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,7 @@
 | 
			
		||||
require 'test_helper'
 | 
			
		||||
 | 
			
		||||
class WorkshopTest < ActiveSupport::TestCase
 | 
			
		||||
  # test "the truth" do
 | 
			
		||||
  #   assert true
 | 
			
		||||
  # end
 | 
			
		||||
end
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user