2013-04-03 2 views
0

Я знаю, что этот вопрос оштукатурен в сети, но, посмотрев на все ответы, я все еще не могу понять, в чем моя проблема.Rails Неинициализированная постоянная ошибка маршрутизации

Вот мой маршрут:

resources :applications do 
    resources :applicants do 
    collection {put '/archived'} 
    collection {put '/not_archived'} 
    end 
end 

Я тогда таблицу на этом пути: /applications/1/applicants который вызывает мой индексный метод.

В этой таблице перечислены все заявители, у меня есть флажок для каждой строки, и когда они устанавливают флажок, я хочу установить флаг «archived» в db для этой строки с помощью ajax.

Вот мой Аякса вызов:

$('.archive').on('click', function() { 
    if ($(this).is(':checked')) { 
     $.ajax({ 
      type: "PUT", 
      url: '/applications/<%= @application.id %>/applicants/archived', 
      data: {id: $(this).attr('id'), archived: true} 
     }); 
    } else { 
     $.ajax({ 
      type: "PUT", 
      url: '/applications/<%= @application.id %>/applicants/not_archived', 
      data: {id: $(this).attr('id'), archived: false} 
     }); 
    } 
}); 

Но каждый раз, когда я проверить флажок я получаю эту ошибку:

Started PUT "/applications/1/applicants/archived" for 127.0.0.1 at 2013-04-03 00:07:20 -0500 

ActionController::RoutingError (uninitialized constant Applications): 
    activesupport (3.2.6) lib/active_support/inflector/methods.rb:229:in `block in constantize' 
    activesupport (3.2.6) lib/active_support/inflector/methods.rb:228:in `each' 
    activesupport (3.2.6) lib/active_support/inflector/methods.rb:228:in `constantize' 
    actionpack (3.2.6) lib/action_dispatch/routing/route_set.rb:69:in `controller_reference' 
    actionpack (3.2.6) lib/action_dispatch/routing/route_set.rb:54:in `controller' 
    actionpack (3.2.6) lib/action_dispatch/routing/route_set.rb:32:in `call' 
    journey (1.0.4) lib/journey/router.rb:68:in `block in call' 
    journey (1.0.4) lib/journey/router.rb:56:in `each' 
    journey (1.0.4) lib/journey/router.rb:56:in `call' 
    actionpack (3.2.6) lib/action_dispatch/routing/route_set.rb:600:in `call' 
    warden (1.2.1) lib/warden/manager.rb:35:in `block in call' 
    warden (1.2.1) lib/warden/manager.rb:34:in `catch' 
    warden (1.2.1) lib/warden/manager.rb:34:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/best_standards_support.rb:17:in `call' 
    rack (1.4.1) lib/rack/etag.rb:23:in `call' 
    rack (1.4.1) lib/rack/conditionalget.rb:35:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/head.rb:14:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/params_parser.rb:21:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/flash.rb:242:in `call' 
    rack (1.4.1) lib/rack/session/abstract/id.rb:205:in `context' 
    rack (1.4.1) lib/rack/session/abstract/id.rb:200:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/cookies.rb:338:in `call' 
    activerecord (3.2.6) lib/active_record/query_cache.rb:64:in `call' 
    activerecord (3.2.6) lib/active_record/connection_adapters/abstract/connection_pool.rb:473:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/callbacks.rb:28:in `block in call' 
    activesupport (3.2.6) lib/active_support/callbacks.rb:405:in `_run__281193607366851886__call__1094349027316042218__callbacks' 
    activesupport (3.2.6) lib/active_support/callbacks.rb:405:in `__run_callback' 
    activesupport (3.2.6) lib/active_support/callbacks.rb:385:in `_run_call_callbacks' 
    activesupport (3.2.6) lib/active_support/callbacks.rb:81:in `run_callbacks' 
    actionpack (3.2.6) lib/action_dispatch/middleware/callbacks.rb:27:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/reloader.rb:65:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/remote_ip.rb:31:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/debug_exceptions.rb:16:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/show_exceptions.rb:56:in `call' 
    railties (3.2.6) lib/rails/rack/logger.rb:26:in `call_app' 
    railties (3.2.6) lib/rails/rack/logger.rb:16:in `call' 
    quiet_assets (1.0.1) lib/quiet_assets.rb:20:in `call_with_quiet_assets' 
    actionpack (3.2.6) lib/action_dispatch/middleware/request_id.rb:22:in `call' 
    rack (1.4.1) lib/rack/methodoverride.rb:21:in `call' 
    rack (1.4.1) lib/rack/runtime.rb:17:in `call' 
    activesupport (3.2.6) lib/active_support/cache/strategy/local_cache.rb:72:in `call' 
    rack (1.4.1) lib/rack/lock.rb:15:in `call' 
    actionpack (3.2.6) lib/action_dispatch/middleware/static.rb:62:in `call' 
    railties (3.2.6) lib/rails/engine.rb:479:in `call' 
    railties (3.2.6) lib/rails/application.rb:220:in `call' 
    rack (1.4.1) lib/rack/content_length.rb:14:in `call' 
    railties (3.2.6) lib/rails/rack/log_tailer.rb:17:in `call' 
    rack (1.4.1) lib/rack/handler/webrick.rb:59:in `service' 
    webrick (1.3.1) lib/webrick/httpserver.rb:138:in `service' 
    webrick (1.3.1) lib/webrick/httpserver.rb:94:in `run' 
    webrick (1.3.1) lib/webrick/server.rb:191:in `block in start_thread' 

Мой ApplicantsController имеет следующие методы:

# PUT /applicants/archived/1 
    def archived 
    p 'here?' 
    @applicant = Applicant.find(params[:id]) 
    @applicant.archived = params[:archived] 
    #@application = current_company.applications.find(params[:application_id]) 

    respond_to do |format| 
     if @applicant.save 
     format.js 
     #format.html { redirect_to @task, notice: 'Task was successfully updated.' } 
     #format.json { head :no_content } 
     else 
     format.html { render action: "index" } 
     format.json { render json: @applicant.errors, status: :unprocessable_entity } 
     end 
    end 
    end 

    # PUT /applicants/not_archived/1 
    def not_archived 
    @applicant = Applicant.find(params[:id]) 
    @applicant.archived = params[:archived] 
    #@application = current_company.applications.find(params[:application_id]) 

    respond_to do |format| 
     if @applicant.save 
     format.js 
     #format.html { redirect_to @task, notice: 'Task was successfully updated.' } 
     #format.json { head :no_content } 
     else 
     format.html { render action: "index" } 
     format.json { render json: @applicant.errors, status: :unprocessable_entity } 
     end 
    end 
    end 

Вот мои грабли маршрутов для этих маршрутов:

 archived_application_applicants PUT /applications/:application_id/applicants/archived(.:format)       applications/:application_id/applicants#archived 
    not_archived_application_applicants PUT /applications/:application_id/applicants/not_archived(.:format)      applications/:application_id/applicants#not_archived 
       application_applicants GET /applications/:application_id/applicants(.:format)          applicants#index 
             POST /applications/:application_id/applicants(.:format)          applicants#create 
       new_application_applicant GET /applications/:application_id/applicants/new(.:format)         applicants#new 
      edit_application_applicant GET /applications/:application_id/applicants/:id/edit(.:format)       applicants#edit 
        application_applicant GET /applications/:application_id/applicants/:id(.:format)         applicants#show 
             PUT /applications/:application_id/applicants/:id(.:format)         applicants#update 
             DELETE /applications/:application_id/applicants/:id(.:format)         applicants#destroy 

В чем причина моей ошибки? Я полностью в тупике.

+0

в контроллере PUT/заявителей/архивировать/1, кажется, вам нужно создать архивируются в качестве маршрута члена не коллекции. После этого вам необходимо передать идентификатор из вашего вызова ajax. А также вам необходимо перенастроить ваши пути ajax. – Mohanraj

+0

Вы используете один контроллер как для приложений, так и для заявителей? или есть 2 контроллера? где они размещены? выглядит как проблема с пространством имен – Abid

ответ

3

Я сделал демо-приложение, реплицирующее ваш контекст, и он отлично работает для меня. Вы можете это проверить здесь: https://github.com/Chipairon/so_applicants_route

Я очистил шум вокруг проблемы, надеясь, что он послужит вам отправной точкой.

Я не хватает репутации комментировать ваш вопрос, так что я положил его здесь :)

Я думаю, что проблема должна быть в вашем app/views/applicants/archived.js.erb, так как вы говорите, что проблема возникает, когда вы установите флажок. Не могли бы вы разместить содержимое этого файла?

На стороне примечания, я бы хотел, чтобы вы подумали о том, чтобы сделать «архивированное» действие действием члена.Вы делаете действительно действие над одного заявителя, а не по всем кандидатам:

resources :applications do 
    resources :applicants do 
    put :archived, on: :member 
    put :not_archived, on: :member 
    end 
end 
0

Попробуйте

$('.archive').on('click', function() { 
    if ($(this).is(':checked')){ 
     $.ajax({ 
      type: "PUT", 
      url: '<%= archived_application_applicants_path(:application_id => @application.id) %>', 
      data: {id: $(this).attr('id'), archived: true} 
    }); 
    }else { 
    $.ajax({ 
      type: "PUT", 
      url: '<%= not_archived_application_applicants_path(:application_id => @application.id) %>', 
      data: {id: $(this).attr('id'), archived: true} 
    }); 
    } 

}); 
+0

Это не работает. Это на самом деле тот же путь, что и я, но я все еще пробовал его, и он не работает. – Catfish

3

Я надеюсь, что этот код будет работать для вас:

$('.archive').on('click', function() {              

if ($(this).is(':checked')){ 
    $.ajax({ 
     type: "PUT", 
     url: '<%= archived_application_applicants_path(@application.id) %>', 
     data: {id: $(this).attr('id'), archived: true} 
    }); 
}else { 
    $.ajax({ 
     type: "PUT", 
     url: '<%= not_archived_application_applicants_path(@application.id) %>', 
     data: {id: $(this).attr('id'), archived: false} 
    }); 
} 

}); 
+0

Не работает .. – Catfish

0

Это, вероятно, не имеет ничего общего с JavaScript. Маршрутизатор не может найти правильный набор модулей/классов для разрешения того, на какой контроллер отправить запрос.

Я думаю, что ваш ApplicantsController это пространство имен, так как:

class Applications::ApplicantsController < Superclass; 
end 

Но applicants_controller.rb не в приложение/контроллеры/приложений, которые он будет необходимо сделать Rails автоматически создать модуль приложений. Переместите applicationants_controller.rb или удалите пространство имен, и все должно быть исправлено.

+0

Я не думаю, что это проблема. Вот мои объявления контроллеров: 'class ApplicationsController Catfish

+0

Но вы используете namespacing для контроллера Applicants в файле routes.rb, поэтому вам нужно сопоставить это с вашим кодом. Измените Заявителей на «классные приложения :: ApplicantsController

+0

И за немного незапрошенных советов я бы изменил название приложений в вашем модель данных. Слишком легко опечатать приложение ApplicationController и ApplicationController, чтобы погубить ваш день. –

Смежные вопросы