From 91f8dedb2d913234f357dbef3333d64cb3d13ebe Mon Sep 17 00:00:00 2001 From: Amy Boyer Date: Thu, 28 Feb 2019 10:54:30 -0600 Subject: [PATCH] Workflow index fix (#646) * add cached count columns * make UI consume cached counters --- app/models/extractor.rb | 2 +- app/models/reducer.rb | 2 +- app/models/subject_rule.rb | 2 +- app/models/user_rule.rb | 2 +- app/views/projects/index.html.erb | 14 +++++++------- app/views/projects/show.html.erb | 2 +- app/views/workflows/index.html.erb | 17 ++++++++--------- app/views/workflows/show.html.erb | 6 +++--- ...8155041_add_extractors_count_to_workflows.rb | 5 +++++ ...228155344_add_reducers_count_to_workflows.rb | 5 +++++ ...5359_add_subject_rules_count_to_workflows.rb | 5 +++++ ...8155430_add_user_rules_count_to_workflows.rb | 5 +++++ ...0228155456_add_reducers_count_to_projects.rb | 5 +++++ db/schema.rb | 7 ++++++- lib/tasks/project_counters.rake | 2 +- lib/tasks/workflow_counters.rake | 2 +- 16 files changed, 56 insertions(+), 27 deletions(-) create mode 100644 db/migrate/20190228155041_add_extractors_count_to_workflows.rb create mode 100644 db/migrate/20190228155344_add_reducers_count_to_workflows.rb create mode 100644 db/migrate/20190228155359_add_subject_rules_count_to_workflows.rb create mode 100644 db/migrate/20190228155430_add_user_rules_count_to_workflows.rb create mode 100644 db/migrate/20190228155456_add_reducers_count_to_projects.rb diff --git a/app/models/extractor.rb b/app/models/extractor.rb index 402ecfb98..29ef77b30 100644 --- a/app/models/extractor.rb +++ b/app/models/extractor.rb @@ -20,7 +20,7 @@ def self.of_type(type) end end - belongs_to :workflow + belongs_to :workflow, counter_cache: true validates :workflow, presence: true validates :key, presence: true, uniqueness: {scope: [:workflow_id]} diff --git a/app/models/reducer.rb b/app/models/reducer.rb index f4dd7b2bd..687080fd3 100644 --- a/app/models/reducer.rb +++ b/app/models/reducer.rb @@ -1,6 +1,6 @@ class Reducer < ApplicationRecord include Configurable - include BelongsToReducible + include BelongsToReducibleCached enum topic: { reduce_by_subject: 0, diff --git a/app/models/subject_rule.rb b/app/models/subject_rule.rb index 90b8397fe..d209f176c 100644 --- a/app/models/subject_rule.rb +++ b/app/models/subject_rule.rb @@ -2,7 +2,7 @@ class SubjectRule < ApplicationRecord include RankedModel ranks :row_order, with_same: :workflow_id - belongs_to :workflow + belongs_to :workflow, counter_cache: true has_many :subject_rule_effects, dependent: :destroy validate :valid_condition? diff --git a/app/models/user_rule.rb b/app/models/user_rule.rb index b9be11c62..df401362b 100644 --- a/app/models/user_rule.rb +++ b/app/models/user_rule.rb @@ -2,7 +2,7 @@ class UserRule < ApplicationRecord include RankedModel ranks :row_order, with_same: :workflow_id - belongs_to :workflow + belongs_to :workflow, counter_cache: true has_many :user_rule_effects, dependent: :destroy validate :valid_condition? diff --git a/app/views/projects/index.html.erb b/app/views/projects/index.html.erb index c4d679728..37b60e5d6 100644 --- a/app/views/projects/index.html.erb +++ b/app/views/projects/index.html.erb @@ -1,5 +1,11 @@
+
+ +
+

Projects

@@ -28,7 +34,7 @@ - + @@ -36,12 +42,6 @@
<%= project.id %> <%= link_to project.display_name || "No Name", project_path(project) %> N/A<%= project.reducers.count %><%= project.reducers_count %> N/A <%= project.updated_at %>
-
- -
-