[logaling-commit] logaling/logaling-server [enable-creating-user-glossary] Enable update term in user glossary

Back to archive index

SHIMADA Koji null+****@clear*****
Wed Sep 19 23:40:54 JST 2012


SHIMADA Koji	2012-09-19 23:40:54 +0900 (Wed, 19 Sep 2012)

  New Revision: 32fb084c7b2ed1169e0039f811bd22a9e0d96289
  https://github.com/logaling/logaling-server/commit/32fb084c7b2ed1169e0039f811bd22a9e0d96289

  Log:
    Enable update term in user glossary

  Modified files:
    app/controllers/terms_controller.rb
    app/models/user_glossary.rb
    app/views/terms/edit.html.haml
    app/views/user_glossaries/show.html.haml

  Modified: app/controllers/terms_controller.rb (+5 -0)
===================================================================
--- app/controllers/terms_controller.rb    2012-09-19 23:14:52 +0900 (6ace06b)
+++ app/controllers/terms_controller.rb    2012-09-19 23:40:54 +0900 (04fb83e)
@@ -17,9 +17,14 @@ class TermsController < ApplicationController
   end
 
   def edit
+    @term = Term.find(params[:id])
   end
 
   def update
+    @term = Term.find(params[:id])
+    new_term = Term.new(params[:term])
+    @user_glossary.update(@term, new_term)
+    redirect_to user_glossary_path(current_user, @user_glossary), notice: 'Term was successfully updated.'
   end
 
   def destroy

  Modified: app/models/user_glossary.rb (+15 -0)
===================================================================
--- app/models/user_glossary.rb    2012-09-19 23:14:52 +0900 (3eb2ca7)
+++ app/models/user_glossary.rb    2012-09-19 23:40:54 +0900 (b0d4921)
@@ -28,6 +28,21 @@ class UserGlossary < ActiveRecord::Base
     LogalingServer.repository.index
   end
 
+  def update(term, new_term)
+    project = LogalingServer.repository.find_project(glossary_name)
+    raise Logaling::ProjectNotFound unless project
+    raise Logaling::ProjectNotFound if project.class.name == 'Logaling::ImportedProject'
+
+    raise Logaling::TermError unless term.valid?
+    glossary = project.glossary(source_language, target_language)
+    unless glossary.bilingual_pair_exists?(term.source_term, term.target_term)
+      raise Logaling::TermError, "term '#{term.source_term}: #{term.target_term}' doesn't exist in '#{name}'"
+    end
+
+    glossary.update(term.source_term, term.target_term, new_term.target_term, new_term.note)
+    LogalingServer.repository.index
+  end
+
   def delete(term)
     project = LogalingServer.repository.find_project(glossary_name)
     raise Logaling::ProjectNotFound unless project

  Modified: app/views/terms/edit.html.haml (+20 -2)
===================================================================
--- app/views/terms/edit.html.haml    2012-09-19 23:14:52 +0900 (a06c814)
+++ app/views/terms/edit.html.haml    2012-09-19 23:40:54 +0900 (eaf491c)
@@ -1,2 +1,20 @@
-%h1 Terms#edit
-%p Find me in app/views/terms/edit.html.haml
\ No newline at end of file
+%h1 Edit Term
+= form_for @term, url: user_glossary_term_path(current_user, @user_glossary, @term.id), method: :put do |f|
+  -if****@term*****?
+    #error_explanation
+      %h2= "#{pluralize(@term.errors.count, "error")} prohibited this term from being saved:"
+      %ul
+        -****@term*****_messages.each do |msg|
+          %li= msg
+
+  .well
+    = f.label :source_term, "Source term:"
+    = f.text_field :source_term
+    = f.label :target_term, "Target term:"
+    = f.text_field :target_term
+    = f.label :note, "Note:"
+    = f.text_field :note
+
+  .actions
+    = f.submit 'Save', :class => 'btn btn-primary'
+

  Modified: app/views/user_glossaries/show.html.haml (+1 -0)
===================================================================
--- app/views/user_glossaries/show.html.haml    2012-09-19 23:14:52 +0900 (e827cac)
+++ app/views/user_glossaries/show.html.haml    2012-09-19 23:40:54 +0900 (8b530f2)
@@ -11,4 +11,5 @@
         = term.source_term
         = term.target_term
         = term.note
+        = link_to "Edit", edit_user_glossary_term_path(current_user, @user_glossary, term.id)
         = link_to "Delete", user_glossary_term_path(current_user, @user_glossary, term.id), method: :delete
-------------- next part --------------
An HTML attachment was scrubbed...
Download 



More information about the logaling-commit mailing list
Back to archive index