Class: ConfidencesController
- Inherits:
-
ApplicationController
- Object
- ActionController::Base
- ApplicationController
- ConfidencesController
- Defined in:
- app/controllers/confidences_controller.rb
Constant Summary
Constants included from ProjectsHelper
ProjectsHelper::CLASSIFIER, ProjectsHelper::CLASSIFIER_ANNOTATION
Instance Method Summary collapse
- #confidence_object ⇒ Object private
- #confidence_object_update ⇒ Object
- #confidence_params ⇒ Object private
- #confidences_params ⇒ Object private
-
#create ⇒ Object
POST /confidences POST /confidences.json.
-
#destroy ⇒ Object
DELETE /confidences/1 DELETE /confidences/1.json.
-
#download ⇒ Object
GET /confidences/download.
-
#edit ⇒ Object
GET /confidences/1/edit.
- #exists ⇒ Object
-
#index ⇒ Object
GET /confidences GET /confidences.json GET /<model>/:id/confidences.json.
- #list ⇒ Object
-
#new ⇒ Object
GET /confidences/new.
- #search ⇒ Object
- #set_confidence ⇒ Object private
-
#update ⇒ Object
PATCH/PUT /confidences/1 PATCH/PUT /confidences/1.json.
Methods included from DataControllerConfiguration::ProjectDataControllerConfiguration
Methods included from RedirectHelper
Methods included from RequestType
Methods included from LogRecent
Methods included from Cookies
#digest_cookie, #digested_cookie_exists?
Methods included from Whitelist
Methods included from ProjectsHelper
#cumulative_gb_per_year, #document_cumulative_gb_per_year, #document_gb_per_year, #gb_per_year, #image_cumulative_gb_per_year, #image_gb_per_year, #invalid_object, #project_classification, #project_link, #project_matches, #project_tag, #projects_list, #projects_search_form, #taxonworks_classification, #week_in_review_graphs
Methods included from Api::Intercept
Methods included from TokenAuthentication
#intercept_project, #intercept_user, #intercept_user_or_project, #project_token_authenticate, #token_authenticate
Instance Method Details
#confidence_object ⇒ Object (private)
124 125 126 127 128 129 130 131 132 |
# File 'app/controllers/confidences_controller.rb', line 124 def confidence_object a = params[:confidence_object_type] b = params[:confidence_object_id] if a && b && o = whitelist_constantize(a)&.find(b) o else redirect_to confidences_path, alert: 'Object paramaters confidence_object_type and confidence_object_id were not provided.' and return end end |
#confidence_object_update ⇒ Object
67 68 69 70 71 72 73 74 75 |
# File 'app/controllers/confidences_controller.rb', line 67 def confidence_object_update @confidence_object = confidence_object if @confidence_object.update(confidences_params) flash[:notice] = 'Successfully updated record.' else flash[:error] = "Error updating record: #{@confidence_object.errors..join('; ')}." end redirect_to new_confidence_path(confidence_object_type: @confidence_object.class.name, confidence_object_id: @confidence_object.id.to_s) end |
#confidence_params ⇒ Object (private)
116 117 118 119 120 121 122 |
# File 'app/controllers/confidences_controller.rb', line 116 def confidence_params params.require(:confidence).permit( :annotated_global_entity, :confidence_level_id, :confidence_object_id, :confidence_object_type, confidence_level_attributes: [:_destroy, :id, :name, :definition, :uri, :uri_relation] ) end |
#confidences_params ⇒ Object (private)
134 135 136 137 138 139 140 |
# File 'app/controllers/confidences_controller.rb', line 134 def confidences_params params.require(:confidence_object).permit( :annotated_global_entity, :confidence_level_id, confidence_level_attributes: [:_destroy, :id, :name, :definition, :uri, :uri_relation] ) end |
#create ⇒ Object
POST /confidences POST /confidences.json
38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
# File 'app/controllers/confidences_controller.rb', line 38 def create @confidence = Confidence.new(confidence_params) respond_to do |format| if @confidence.save format.html { redirect_to url_for(@confidence.confidence_object.), notice: 'Confidence was successfully created.' } format.json { render :show, status: :created, location: @confidence } else format.html { redirect_back(fallback_location: (request.referer || root_path), notice: 'Confidence was NOT successfully created.') } format.json { render json: @confidence.errors, status: :unprocessable_entity } end end end |
#destroy ⇒ Object
DELETE /confidences/1 DELETE /confidences/1.json
79 80 81 82 83 84 85 |
# File 'app/controllers/confidences_controller.rb', line 79 def destroy @confidence.destroy respond_to do |format| format.html { redirect_to confidences_url, notice: 'Confidence was successfully destroyed.' } format.json { head :no_content } end end |
#download ⇒ Object
GET /confidences/download
96 97 98 |
# File 'app/controllers/confidences_controller.rb', line 96 def download send_data Export::CSV.generate_csv(Confidence.where(project_id: sessions_current_project_id)), type: 'text', filename: "confidences_#{DateTime.now}.tsv" end |
#edit ⇒ Object
GET /confidences/1/edit
29 30 |
# File 'app/controllers/confidences_controller.rb', line 29 def edit end |
#exists ⇒ Object
100 101 102 103 104 105 106 107 108 |
# File 'app/controllers/confidences_controller.rb', line 100 def exists if @confidence = Confidence.exists?(params.require(:global_id), params.require(:confidence_level_id), sessions_current_project_id) render :show else render json: false end end |
#index ⇒ Object
GET /confidences GET /confidences.json GET /<model>/:id/confidences.json
10 11 12 13 14 15 16 17 18 19 20 21 |
# File 'app/controllers/confidences_controller.rb', line 10 def index respond_to do |format| format.html { @recent_objects = ::Confidence.recent_from_project_id(sessions_current_project_id).order(updated_at: :desc).limit(10) render '/shared/data/all/index' } format.json { @confidences = ::Queries::Confidence::Filter.new(params).all.where(project_id: sessions_current_project_id). page(params[:page]).per(params[:per] || 500) } end end |
#list ⇒ Object
32 33 34 |
# File 'app/controllers/confidences_controller.rb', line 32 def list @confidences = Confidence.with_project_id(sessions_current_project_id).page(params[:page]) end |
#new ⇒ Object
GET /confidences/new
24 25 26 |
# File 'app/controllers/confidences_controller.rb', line 24 def new @confidence_object = confidence_object end |
#search ⇒ Object
87 88 89 90 91 92 93 |
# File 'app/controllers/confidences_controller.rb', line 87 def search if params[:id].blank? redirect_to confidences_path, notice: 'You must select an item from the list with a click or tab press before clicking show' else redirect_to confidence_path(params[:id]) end end |
#set_confidence ⇒ Object (private)
112 113 114 |
# File 'app/controllers/confidences_controller.rb', line 112 def set_confidence @confidence = Confidence.where(project_id: sessions_current_project_id).find(params[:id]) end |
#update ⇒ Object
PATCH/PUT /confidences/1 PATCH/PUT /confidences/1.json
55 56 57 58 59 60 61 62 63 64 65 |
# File 'app/controllers/confidences_controller.rb', line 55 def update respond_to do |format| if @confidence.update(confidence_params) format.html { redirect_to @confidence, notice: 'Confidence was successfully updated.' } format.json { render :show, status: :ok, location: @confidence } else format.html { render :edit } format.json { render json: @confidence.errors, status: :unprocessable_entity } end end end |