diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
index 8a5af6ace..0548842b6 100644
--- a/app/helpers/application_helper.rb
+++ b/app/helpers/application_helper.rb
@@ -10,6 +10,11 @@ module ApplicationHelper
render "diff_list", diff: diff, ul_class: ul_class, li_class: li_class
end
+ def diff_name_html(this_name, prev_name)
+ pattern = Regexp.new('.')
+ DiffBuilder.new(this_name, prev_name, pattern).build
+ end
+
def diff_body_html(record, previous, field)
return h(record[field]).gsub(/\r?\n/, '¶
').html_safe if previous.blank?
diff --git a/app/helpers/artist_versions_helper.rb b/app/helpers/artist_versions_helper.rb
index 1f55b471e..b9cf1269e 100644
--- a/app/helpers/artist_versions_helper.rb
+++ b/app/helpers/artist_versions_helper.rb
@@ -14,4 +14,24 @@ module ArtistVersionsHelper
diff_list_html(new_urls, old_urls, latest_urls)
end
+
+ def artist_version_name_diff(artist_version)
+ previous = artist_version.previous
+ if previous.present? && (artist_version.name != previous.name)
+ name_diff = diff_name_html(artist_version.name, previous.name)
+ %(
Rename:
#{name_diff}
).html_safe
+ else
+ ""
+ end
+ end
+
+ def artist_version_group_name_diff(artist_version)
+ previous = artist_version.previous
+ if artist_version.group_name.present? || (previous.present? && previous.group_name.present?)
+ group_name_diff = diff_name_html(artist_version.group_name, previous.group_name)
+ %(Group:
#{group_name_diff}
).html_safe
+ else
+ ""
+ end
+ end
end
diff --git a/app/helpers/pool_versions_helper.rb b/app/helpers/pool_versions_helper.rb
new file mode 100644
index 000000000..c12e56a2c
--- /dev/null
+++ b/app/helpers/pool_versions_helper.rb
@@ -0,0 +1,31 @@
+module PoolVersionsHelper
+ def pool_version_show_diff(pool_version)
+ previous = pool_version.previous
+ previous.present? && pool_version.description != previous.description
+ end
+
+ def pool_version_name_diff(pool_version)
+ previous = pool_version.previous
+ if previous.present? && (pool_version.name != previous.name)
+ name_diff = diff_name_html(pool_version.pretty_name, previous.pretty_name)
+ %(
Rename:
#{name_diff}).html_safe
+ else
+ ""
+ end
+ end
+
+ def pool_version_post_diff(pool_version)
+ previous = pool_version.previous
+ diff = {}
+
+ if previous.present?
+ diff[:added_post_ids] = pool_version.post_ids - previous.post_ids
+ diff[:removed_post_ids] = previous.post_ids - pool_version.post_ids
+ else
+ diff[:added_post_ids] = pool_version.added_post_ids
+ diff[:removed_post_ids] = pool_version.removed_post_ids
+ end
+
+ render "pool_versions/diff", diff: diff
+ end
+end
diff --git a/app/helpers/post_versions_helper.rb b/app/helpers/post_versions_helper.rb
index 062deebf4..c2994004d 100644
--- a/app/helpers/post_versions_helper.rb
+++ b/app/helpers/post_versions_helper.rb
@@ -1,19 +1,48 @@
module PostVersionsHelper
def post_version_diff(post_version)
- diff = post_version.diff(post_version.previous)
+ previous = post_version.previous
+ post = post_version.post
+
+ if post.nil?
+ latest_tags = post_version.tag_array
+ else
+ latest_tags = post.tag_array
+ latest_tags << "rating:#{post.rating}" if post.rating.present?
+ latest_tags << "parent:#{post.parent_id}" if post.parent_id.present?
+ latest_tags << "source:#{post.source}" if post.source.present?
+ end
+
+ new_tags = post_version.tag_array
+ new_tags << "rating:#{post_version.rating}" if post_version.rating.present?
+ new_tags << "parent:#{post_version.parent_id}" if post_version.parent_id.present?
+ new_tags << "source:#{post_version.source}" if post_version.source.present?
+
+ old_tags = previous.present? ? previous.tag_array : []
+ if previous.present?
+ old_tags << "rating:#{previous.rating}" if previous.rating.present?
+ old_tags << "parent:#{previous.parent_id}" if previous.parent_id.present?
+ old_tags << "source:#{previous.source}" if previous.source.present?
+ end
+
+ added_tags = new_tags - old_tags
+ removed_tags = old_tags - new_tags
+ obsolete_added_tags = added_tags - latest_tags,
+ obsolete_removed_tags = removed_tags & latest_tags,
+ unchanged_tags = new_tags & old_tags
+
html = ''
- diff[:added_tags].each do |tag|
- prefix = diff[:obsolete_added_tags].include?(tag) ? '+' : '+'
+ added_tags.each do |tag|
+ prefix = obsolete_added_tags.include?(tag) ? '+' : '+'
html << prefix + link_to(wordbreakify(tag), posts_path(:tags => tag)) + ''
html << " "
end
- diff[:removed_tags].each do |tag|
- prefix = diff[:obsolete_removed_tags].include?(tag) ? '-' : '-'
+ removed_tags.each do |tag|
+ prefix = obsolete_removed_tags.include?(tag) ? '-' : '-'
html << prefix + link_to(wordbreakify(tag), posts_path(:tags => tag)) + ''
html << " "
end
- diff[:unchanged_tags].each do |tag|
+ unchanged_tags.each do |tag|
html << '' + link_to(wordbreakify(tag), posts_path(:tags => tag)) + ''
html << " "
end
diff --git a/app/helpers/wiki_page_versions_helper.rb b/app/helpers/wiki_page_versions_helper.rb
index 0dd614045..6c8fb9b39 100644
--- a/app/helpers/wiki_page_versions_helper.rb
+++ b/app/helpers/wiki_page_versions_helper.rb
@@ -1,9 +1,28 @@
module WikiPageVersionsHelper
- def wiki_other_names_diff(new_version, old_version)
+ def wiki_version_show_diff(wiki_page_version)
+ previous = wiki_page_version.previous
+ previous.present? && ((wiki_page_version.body != previous.body) || wiki_page_version.other_names_changed)
+ end
+
+ def wiki_version_show_other_names(new_version, old_version)
+ ((new_version.other_names - old_version.other_names) | (old_version.other_names - new_version.other_names)).length > 0
+ end
+
+ def wiki_version_other_names_diff(new_version, old_version)
new_names = new_version.other_names
old_names = old_version.other_names
latest_names = new_version.wiki_page.other_names
diff_list_html(new_names, old_names, latest_names, ul_class: ["wiki-other-names-diff-list list-inline"], li_class: ["wiki-other-name"])
end
+
+ def wiki_version_title_diff(wiki_page_version)
+ previous = wiki_page_version.previous
+ if previous.present? && (wiki_page_version.title != previous.title)
+ name_diff = diff_name_html(wiki_page_version.title, previous.title)
+ %((Rename: #{name_diff})).html_safe
+ else
+ ""
+ end
+ end
end
diff --git a/app/models/pool_version.rb b/app/models/pool_version.rb
index 5e9f18342..b8e0e64d0 100644
--- a/app/models/pool_version.rb
+++ b/app/models/pool_version.rb
@@ -89,23 +89,6 @@ class PoolVersion < ApplicationRecord
normalize_name(name).mb_chars.downcase
end
- def build_diff(other = previous)
- diff = {}
-
- if other.nil?
- diff[:added_post_ids] = added_post_ids
- diff[:removed_post_ids] = removed_post_ids
- diff[:added_desc] = description
- else
- diff[:added_post_ids] = post_ids - other.post_ids
- diff[:removed_post_ids] = other.post_ids - post_ids
- diff[:added_desc] = description
- diff[:removed_desc] = other.description
- end
-
- diff
- end
-
def previous
@previous ||= begin
PoolVersion.where("pool_id = ? and version < ?", pool_id, version).order("version desc").limit(1).to_a
@@ -115,6 +98,7 @@ class PoolVersion < ApplicationRecord
def self.status_fields
{
+ posts_changed: "Posts",
name: "Renamed",
description: "Description",
was_deleted: "Deleted",
@@ -124,6 +108,10 @@ class PoolVersion < ApplicationRecord
}
end
+ def posts_changed
+ ((post_ids - previous.post_ids) | (previous.post_ids - post_ids)).length > 0
+ end
+
def was_deleted
is_deleted && !previous.is_deleted
end
@@ -140,10 +128,6 @@ class PoolVersion < ApplicationRecord
!is_active && previous.is_active
end
- def text_field_changed
- previous.present? && (name_changed || description_changed)
- end
-
def pretty_name
name.tr("_", " ")
end
diff --git a/app/models/post_version.rb b/app/models/post_version.rb
index fe73e2641..869fa2140 100644
--- a/app/models/post_version.rb
+++ b/app/models/post_version.rb
@@ -112,40 +112,6 @@ class PostVersion < ApplicationRecord
}
end
- def diff(version = nil)
- if post.nil?
- latest_tags = tag_array
- else
- latest_tags = post.tag_array
- latest_tags << "rating:#{post.rating}" if post.rating.present?
- latest_tags << "parent:#{post.parent_id}" if post.parent_id.present?
- latest_tags << "source:#{post.source}" if post.source.present?
- end
-
- new_tags = tag_array
- new_tags << "rating:#{rating}" if rating.present?
- new_tags << "parent:#{parent_id}" if parent_id.present?
- new_tags << "source:#{source}" if source.present?
-
- old_tags = version.present? ? version.tag_array : []
- if version.present?
- old_tags << "rating:#{version.rating}" if version.rating.present?
- old_tags << "parent:#{version.parent_id}" if version.parent_id.present?
- old_tags << "source:#{version.source}" if version.source.present?
- end
-
- added_tags = new_tags - old_tags
- removed_tags = old_tags - new_tags
-
- return {
- :added_tags => added_tags,
- :removed_tags => removed_tags,
- :obsolete_added_tags => added_tags - latest_tags,
- :obsolete_removed_tags => removed_tags & latest_tags,
- :unchanged_tags => new_tags & old_tags
- }
- end
-
def changes
delta = {
:added_tags => added_tags,
diff --git a/app/views/artist_commentary_versions/index.html.erb b/app/views/artist_commentary_versions/index.html.erb
index 573722507..fac35c5af 100644
--- a/app/views/artist_commentary_versions/index.html.erb
+++ b/app/views/artist_commentary_versions/index.html.erb
@@ -1,6 +1,6 @@