Class: Caboose::PageBlockFieldsController
- Inherits:
-
ApplicationController
- Object
- ActionController::Base
- ApplicationController
- Caboose::PageBlockFieldsController
- Defined in:
- app/controllers/caboose/page_block_fields_controller.rb
Instance Method Summary collapse
-
#admin_create ⇒ Object
POST /admin/page-block-types/:block_type_id.
-
#admin_delete ⇒ Object
DELETE /admin/page-block-types/:block_type_id/fields/:id.
-
#admin_edit ⇒ Object
GET /admin/page-block-types/:block_type_id/fields/:id/edit.
-
#admin_field_options ⇒ Object
GET /admin/page-block-fields/:id/options.
-
#admin_field_type_options ⇒ Object
GET /admin/page-block-fields/field-type-options.
-
#admin_index ⇒ Object
GET /admin/page-block-types/:block_type_id/fields.
-
#admin_new ⇒ Object
GET /admin/page-block-types/:block_type_id/fields/new.
-
#admin_update ⇒ Object
PUT /admin/page-block-types/:block_type_id/fields/:id.
Methods inherited from ApplicationController
#before_action, #before_before_action, #logged_in?, #logged_in_user, #login_user, #logout_user, #parse_url_params, #reject_param, #user_is_allowed, #user_is_allowed_to, #validate_cookie, #validate_token, #var, #verify_logged_in
Instance Method Details
#admin_create ⇒ Object
POST /admin/page-block-types/:block_type_id
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
# File 'app/controllers/caboose/page_block_fields_controller.rb', line 32 def admin_create return unless user_is_allowed('pages', 'add') resp = Caboose::StdClass.new({ 'error' => nil, 'redirect' => nil }) field = PageBlockField.new( :page_block_type_id => params[:block_type_id], :name => params[:name].downcase.gsub(' ', '_'), :nice_name => params[:name], :field_type => 'text' ) field.save # Send back the response resp.redirect = "/admin/page-block-types/#{params[:block_type_id]}/fields/#{field.id}/edit" render :json => resp end |
#admin_delete ⇒ Object
DELETE /admin/page-block-types/:block_type_id/fields/:id
103 104 105 106 107 108 109 110 |
# File 'app/controllers/caboose/page_block_fields_controller.rb', line 103 def admin_delete return unless user_is_allowed('pages', 'delete') PageBlockField.find(params[:id]).destroy resp = StdClass.new({ 'redirect' => "/admin/page-block-types/#{params[:block_type_id]}/edit" }) render :json => resp end |
#admin_edit ⇒ Object
GET /admin/page-block-types/:block_type_id/fields/:id/edit
25 26 27 28 29 |
# File 'app/controllers/caboose/page_block_fields_controller.rb', line 25 def admin_edit return unless user_is_allowed('pages', 'edit') @field = PageBlockField.find(params[:id]) render :layout => 'caboose/admin' end |
#admin_field_options ⇒ Object
GET /admin/page-block-fields/:id/options
129 130 131 132 133 134 135 136 137 |
# File 'app/controllers/caboose/page_block_fields_controller.rb', line 129 def return unless user_is_allowed('pages', 'edit') f = PageBlockField.find(params[:id]) = [] if f. = f..strip.split("\n").collect { |line| { 'value' => line, 'text' => line }} end render :json => end |
#admin_field_type_options ⇒ Object
GET /admin/page-block-fields/field-type-options
113 114 115 116 117 118 119 120 121 122 123 124 125 126 |
# File 'app/controllers/caboose/page_block_fields_controller.rb', line 113 def return unless user_is_allowed('pages', 'edit') = [ { 'value' => 'checkbox' , 'text' => 'checkbox' }, { 'value' => 'checkbox_multiple' , 'text' => 'checkbox_multiple' }, { 'value' => 'image' , 'text' => 'image' }, { 'value' => 'file' , 'text' => 'file' }, { 'value' => 'richtext' , 'text' => 'richtext' }, { 'value' => 'select' , 'text' => 'select' }, { 'value' => 'text' , 'text' => 'text' }, { 'value' => 'textarea' , 'text' => 'textarea' } ] render :json => end |
#admin_index ⇒ Object
GET /admin/page-block-types/:block_type_id/fields
10 11 12 13 14 |
# File 'app/controllers/caboose/page_block_fields_controller.rb', line 10 def admin_index return if !user_is_allowed('pages', 'view') fields = PageBlockField.where(:page_block_type_id => params[:block_type_id]).reorder(:name).all render :json => fields end |
#admin_new ⇒ Object
GET /admin/page-block-types/:block_type_id/fields/new
17 18 19 20 21 22 |
# File 'app/controllers/caboose/page_block_fields_controller.rb', line 17 def admin_new return unless user_is_allowed('pages', 'add') @block_type = PageBlockType.find(params[:block_type_id]) @field = PageBlockField.new render :layout => 'caboose/admin' end |
#admin_update ⇒ Object
PUT /admin/page-block-types/:block_type_id/fields/:id
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 |
# File 'app/controllers/caboose/page_block_fields_controller.rb', line 54 def admin_update return unless user_is_allowed('pages', 'edit') resp = StdClass.new({'attributes' => {}}) field = PageBlockField.find(params[:id]) save = true user = logged_in_user params.each do |k,v| case k when 'page_block_type_id' field.page_block_type_id = v break when 'name' field.name = v break when 'field_type' field.field_type = v break when 'nice_name' field.nice_name = v break when 'default' field.default = v break when 'width' field.width = v break when 'height' field.height = v break when 'fixed_placeholder' field.fixed_placeholder = v break when 'options' field. = v break when 'options_url' field. = v break end end resp.success = save && field.save render :json => resp end |