From 14127a5eb46b2dd60dfacf87e301c7629f3c5946 Mon Sep 17 00:00:00 2001 From: Ryan Wold <64987852+ryanwoldatwork@users.noreply.github.com> Date: Tue, 12 Nov 2024 08:55:50 -0800 Subject: [PATCH] Deprecate v1 cx collections --- app/assets/javascripts/performance-charts.js | 142 ----- .../admin/collections_controller.rb | 168 ------ .../admin/cx_collection_details_controller.rb | 3 + .../admin/cx_collections_controller.rb | 29 +- ...omb_cx_reporting_collections_controller.rb | 142 ----- .../admin/organizations_controller.rb | 3 +- .../admin/performance_controller.rb | 6 +- app/controllers/admin/reporting_controller.rb | 306 ---------- app/controllers/admin/services_controller.rb | 4 - app/controllers/admin/site_controller.rb | 2 - app/controllers/admin/users_controller.rb | 2 +- .../api/v1/collections_controller.rb | 19 - app/controllers/application_controller.rb | 16 - app/mailers/user_mailer.rb | 23 +- app/models/collection.rb | 213 ------- app/models/cx_collection.rb | 2 +- app/models/omb_cx_reporting_collection.rb | 385 ------------- app/models/organization.rb | 1 - app/models/service.rb | 3 - app/models/service_provider.rb | 4 +- app/models/user.rb | 1 - app/serializers/collection_serializer.rb | 23 - .../collections/_csv_detail_row.html.erb | 1 - app/views/admin/collections/_form.html.erb | 114 ---- .../collections/_hisps_csv_details.html.erb | 72 --- .../_omb_a11_cx_quarterly_reporting.html.erb | 350 ------------ app/views/admin/collections/edit.html.erb | 26 - app/views/admin/collections/events.html.erb | 46 -- app/views/admin/collections/index.html.erb | 150 ----- app/views/admin/collections/new.html.erb | 12 - app/views/admin/collections/show.html.erb | 203 ------- .../performancegov/_cx_summary_chart.html.erb | 249 --------- .../cx_collection_details/_form.html.erb | 2 +- .../forms/_form_manager_options.html.erb | 2 +- .../_csv_data.html.erb | 50 -- .../_form.html.erb | 374 ------------- .../edit.html.erb | 22 - .../index.html.erb | 42 -- .../omb_cx_reporting_collections/new.html.erb | 11 - .../show.html.erb | 526 ------------------ .../admin/organizations/_results.html.erb | 4 +- app/views/admin/organizations/show.html.erb | 50 +- app/views/admin/performance/index.html.erb | 8 - app/views/admin/reporting/index.html.erb | 45 -- .../admin/service_providers/show.html.erb | 22 +- app/views/admin/services/_results.html.erb | 4 +- .../admin/services/omb_cx_reporting.html.erb | 56 -- app/views/admin/services/show.html.erb | 53 -- app/views/admin/site/a11.html.erb | 4 - app/views/admin/site/index.html.erb | 9 +- app/views/admin/site/integrations.html.erb | 24 +- app/views/admin/site/management.html.erb | 199 ------- app/views/admin/users/show.html.erb | 14 +- .../components/_performance_charts.html.erb | 122 ---- app/views/components/_weekly_metrics.html.erb | 6 +- .../_cx_summary_data_detail_row.html.erb | 1 - .../collection_notification.html.erb | 6 +- .../collection_notification.text.erb | 2 +- ...crm_data_collection2_notification.html.erb | 6 +- ...crm_data_collection2_notification.text.erb | 4 +- ...scrm_data_collection_notification.html.erb | 6 +- ...scrm_data_collection_notification.text.erb | 4 +- ...uarterly_performance_notification.html.erb | 6 +- ...uarterly_performance_notification.text.erb | 4 +- .../user_mailer/user_welcome_email.html.erb | 2 +- .../user_mailer/user_welcome_email.text.erb | 2 +- config/initializers/us_timezones.rb | 7 + config/routes.rb | 17 - db/seeds.rb | 139 ++--- docs/models/collections.md | 31 -- .../admin/collections_controller_spec.rb | 66 --- .../admin/cx_collections_controller_spec.rb | 15 +- .../api/v1/collections_controller_spec.rb | 67 --- .../cx_collection_details_controller_spec.rb | 2 +- ...x_reporting_collections_controller_spec.rb | 69 --- .../api/v1/websites_controller_spec.rb | 2 +- spec/factories/collection.rb | 15 - spec/factories/cx_collection_detail_upload.rb | 2 +- spec/features/admin/collections_spec.rb | 219 -------- spec/features/admin/dashboard_spec.rb | 17 - spec/features/admin/forms_spec.rb | 19 +- .../omb_cx_reporting_collections_spec.rb | 95 ---- spec/features/admin/organizations_spec.rb | 22 + spec/features/admin/users_spec.rb | 2 +- spec/features/site_spec.rb | 2 +- spec/mailers/user_mailer_spec.rb | 9 +- spec/models/collection_spec.rb | 71 --- .../omb_cx_reporting_collection_spec.rb | 7 - 88 files changed, 256 insertions(+), 5051 deletions(-) delete mode 100644 app/assets/javascripts/performance-charts.js delete mode 100644 app/controllers/admin/collections_controller.rb delete mode 100644 app/controllers/admin/omb_cx_reporting_collections_controller.rb delete mode 100644 app/controllers/api/v1/collections_controller.rb delete mode 100644 app/models/collection.rb delete mode 100644 app/models/omb_cx_reporting_collection.rb delete mode 100644 app/serializers/collection_serializer.rb delete mode 100644 app/views/admin/collections/_csv_detail_row.html.erb delete mode 100644 app/views/admin/collections/_form.html.erb delete mode 100644 app/views/admin/collections/_hisps_csv_details.html.erb delete mode 100644 app/views/admin/collections/_omb_a11_cx_quarterly_reporting.html.erb delete mode 100644 app/views/admin/collections/edit.html.erb delete mode 100644 app/views/admin/collections/events.html.erb delete mode 100644 app/views/admin/collections/index.html.erb delete mode 100644 app/views/admin/collections/new.html.erb delete mode 100644 app/views/admin/collections/show.html.erb delete mode 100644 app/views/admin/components/performancegov/_cx_summary_chart.html.erb delete mode 100644 app/views/admin/omb_cx_reporting_collections/_csv_data.html.erb delete mode 100644 app/views/admin/omb_cx_reporting_collections/_form.html.erb delete mode 100644 app/views/admin/omb_cx_reporting_collections/edit.html.erb delete mode 100644 app/views/admin/omb_cx_reporting_collections/index.html.erb delete mode 100644 app/views/admin/omb_cx_reporting_collections/new.html.erb delete mode 100644 app/views/admin/omb_cx_reporting_collections/show.html.erb delete mode 100644 app/views/admin/services/omb_cx_reporting.html.erb delete mode 100644 app/views/admin/site/a11.html.erb delete mode 100644 app/views/components/_performance_charts.html.erb delete mode 100644 app/views/components/reporting/_cx_summary_data_detail_row.html.erb create mode 100644 config/initializers/us_timezones.rb delete mode 100644 docs/models/collections.md delete mode 100644 spec/controllers/admin/collections_controller_spec.rb delete mode 100644 spec/controllers/api/v1/collections_controller_spec.rb delete mode 100644 spec/controllers/api/v1/omb_cx_reporting_collections_controller_spec.rb delete mode 100644 spec/factories/collection.rb delete mode 100644 spec/features/admin/collections_spec.rb delete mode 100644 spec/features/admin/omb_cx_reporting_collections_spec.rb delete mode 100644 spec/models/collection_spec.rb delete mode 100644 spec/models/omb_cx_reporting_collection_spec.rb diff --git a/app/assets/javascripts/performance-charts.js b/app/assets/javascripts/performance-charts.js deleted file mode 100644 index d38b3ce4f..000000000 --- a/app/assets/javascripts/performance-charts.js +++ /dev/null @@ -1,142 +0,0 @@ -'use strict'; - -var chartConfigs = {}; -var cxCharts = {}; - -window.chartjsColors = { - blue: '#73b3e7', - vividRed: '#e41d3d', - darkBlue: '#1a4480', - orange: '#ffbc78', - blue2: '#73b3e7', - vividRed2: '#e41d3d', - darkBlue2: '#1a4480', - orange2: '#ffbc78', - blue3: '#73b3e7', - vividRed3: '#e41d3d', - darkBlue3: '#1a4480', - orange3: '#ffbc78' -}; - -(function(global) { - var MONTHS = [ - 'January', - 'February', - 'March', - 'April', - 'May', - 'June', - 'July', - 'August', - 'September', - 'October', - 'November', - 'December' - ]; - - var COLORS = [ - '#4dc9f6', - '#f67019', - '#f53794', - '#537bc4', - '#acc236', - '#166a8f', - '#00a950', - '#58595b', - '#8549ba' - ]; - - var Samples = global.Samples || (global.Samples = {}); - var Color = global.Color; - - Samples.utils = { - // Adapted from http://indiegamr.com/generate-repeatable-random-numbers-in-js/ - srand: function(seed) { - this._seed = seed; - }, - - rand: function(min, max) { - var seed = this._seed; - min = min === undefined ? 0 : min; - max = max === undefined ? 1 : max; - this._seed = (seed * 9301 + 49297) % 233280; - return min + (this._seed / 233280) * (max - min); - }, - - numbers: function(config) { - var cfg = config || {}; - var min = cfg.min || 0; - var max = cfg.max || 1; - var from = cfg.from || []; - var count = cfg.count || 8; - var decimals = cfg.decimals || 8; - var continuity = cfg.continuity || 1; - var dfactor = Math.pow(10, decimals) || 0; - var data = []; - var i, value; - - for (i = 0; i < count; ++i) { - value = (from[i] || 0) + this.rand(min, max); - if (this.rand() <= continuity) { - data.push(Math.round(dfactor * value) / dfactor); - } else { - data.push(null); - } - } - - return data; - }, - - labels: function(config) { - var cfg = config || {}; - var min = cfg.min || 0; - var max = cfg.max || 100; - var count = cfg.count || 8; - var step = (max - min) / count; - var decimals = cfg.decimals || 8; - var dfactor = Math.pow(10, decimals) || 0; - var prefix = cfg.prefix || ''; - var values = []; - var i; - - for (i = min; i < max; i += step) { - values.push(prefix + Math.round(dfactor * i) / dfactor); - } - - return values; - }, - - months: function(config) { - var cfg = config || {}; - var count = cfg.count || 12; - var section = cfg.section; - var values = []; - var i, value; - - for (i = 0; i < count; ++i) { - value = MONTHS[Math.ceil(i) % 12]; - values.push(value.substring(0, section)); - } - - return values; - }, - - color: function(index) { - return COLORS[index % COLORS.length]; - }, - - transparentize: function(color, opacity) { - var alpha = opacity === undefined ? 0.5 : 1 - opacity; - return Color(color).alpha(alpha).rgbString(); - } - }; - - // DEPRECATED - window.randomScalingFactor = function() { - return Math.round(Samples.utils.rand(1, 5)); - }; - - // INITIALIZATION - - Samples.utils.srand(Date.now()); -}(this)); diff --git a/app/controllers/admin/collections_controller.rb b/app/controllers/admin/collections_controller.rb deleted file mode 100644 index 579370c60..000000000 --- a/app/controllers/admin/collections_controller.rb +++ /dev/null @@ -1,168 +0,0 @@ -# frozen_string_literal: true - -module Admin - class CollectionsController < AdminController - before_action :set_collection, only: %i[show edit copy - submit publish - update destroy - events] - - def index - @quarter = params[:quarter].present? ? params[:quarter].to_i : nil - @year = params[:year].present? ? params[:year].to_i : nil - - if performance_manager_permissions? - if @quarter && @year - @collections = Collection.where(quarter: @quarter, year: @year) - .order('organizations.name', :year, :quarter, 'service_providers.name') - .includes(:organization, :service_provider) - elsif @quarter - @collections = Collection.where(quarter: @quarter) - .order('organizations.name', :year, :quarter, 'service_providers.name') - .includes(:organization, :service_provider) - else - @collections = Collection - .order('organizations.name', :year, :quarter, 'service_providers.name') - .includes(:organization, :service_provider) - end - elsif @quarter && @year - @collections = current_user.collections.where(quarter: @quarter, year: @year) - .order('organizations.name', :year, :quarter, 'service_providers.name') - .includes(:organization, :service_provider) - elsif @quarter - @collections = current_user.collections.where(quarter: @quarter) - .order('organizations.name', :year, :quarter, 'service_providers.name') - .includes(:organization, :service_provider) - else - @collections = current_user.collections - .order('organizations.name', :year, :quarter, 'service_providers.name') - .includes(:organization, :service_provider) - end - end - - def show - ensure_collection_owner(collection: @collection) - end - - def new - @collection = Collection.new - @collection.user = current_user - @collection.organization_id = params[:organization_id] - @collection.service_provider_id = params[:service_provider_id] - @collection.year = fiscal_year(Date.today) - @collection.quarter = fiscal_quarter(Date.today) - end - - def edit - ensure_collection_owner(collection: @collection) - end - - def submit - @collection.submit! - Event.log_event(Event.names[:collection_submitted], 'Collection', @collection.id, "Collection #{@collection.name} submitted at #{DateTime.now}", current_user.id) - UserMailer.collection_notification(collection_id: @collection.id).deliver_later - redirect_to admin_collection_path(@collection), notice: 'Collection has been submitted successfully.' - end - - def publish - @collection.publish! - Event.log_event(Event.names[:collection_published], 'Collection', @collection.id, "Collection #{@collection.name} published at #{DateTime.now}", current_user.id) - redirect_to admin_collection_path(@collection), notice: 'Collection has been published successfully.' - end - - def copy - ensure_collection_owner(collection: @collection) - - respond_to do |format| - new_collection = @collection.duplicate!(new_user: current_user) - - if new_collection.valid? - Event.log_event(Event.names[:collection_copied], 'Collection', @collection.id, "Collection #{@collection.name} copied at #{DateTime.now}", current_user.id) - - format.html { redirect_to admin_collection_path(new_collection), notice: 'Collection was successfully copied.' } - format.json { render :show, status: :created, location: new_collection } - else - format.html { render :new } - format.json { render json: new_collection.errors, status: :unprocessable_entity } - end - end - end - - def create - @collection = Collection.new(collection_params) - - @collection.user = current_user - if @collection.save - Event.log_event(Event.names[:collection_created], 'Collection', @collection.id, "Collection #{@collection.name} created at #{DateTime.now}", current_user.id) - redirect_to admin_collection_path(@collection), notice: 'Collection was successfully created.' - else - render :new - end - end - - def update - ensure_collection_owner(collection: @collection) - - if @collection.update(collection_params) - Event.log_event(Event.names[:collection_updated], 'Collection', @collection.id, "Collection #{@collection.name} updated at #{DateTime.now}", current_user.id) - redirect_to admin_collection_path(@collection), notice: 'Collection was successfully updated.' - else - render :edit - end - end - - def destroy - ensure_collection_owner(collection: @collection) - @collection.destroy - Event.log_event(Event.names[:collection_deleted], 'Collection', @collection.id, "Collection #{@collection.name} deleted at #{DateTime.now}", current_user.id) - redirect_to admin_collections_url, notice: 'Collection was successfully destroyed.' - end - - def events - @events = Event.where(object_type: 'Collection', object_uuid: @collection.id).order(:created_at) - end - - def export_csv - if performance_manager_permissions? - @collections = Collection.all - else - @collections = current_user.collections - end - send_data @collections.to_csv, filename: "touchpoints-data-collections-#{Date.today}.csv" - end - - def export_omb_cx_reporting_collections_csv - ensure_performance_manager_permissions - - @omb_cx_reporting_collections = OmbCxReportingCollection.to_csv - send_data @omb_cx_reporting_collections, filename: "touchpoints-omb-cx-reporting-data-collections-#{Date.today}.csv" - end - - private - - def set_collection - if performance_manager_permissions? - @collection = Collection.find(params[:id]) - else - @collection = current_user.collections.find(params[:id]) - end - end - - def collection_params - params.require(:collection).permit( - :name, - :start_date, - :end_date, - :organization_id, - :service_provider_id, - :year, - :quarter, - :user_id, - :reflection, - :integrity_hash, - :aasm_state, - :rating, - ) - end - end -end diff --git a/app/controllers/admin/cx_collection_details_controller.rb b/app/controllers/admin/cx_collection_details_controller.rb index 482636c17..4a907e2bc 100644 --- a/app/controllers/admin/cx_collection_details_controller.rb +++ b/app/controllers/admin/cx_collection_details_controller.rb @@ -101,6 +101,9 @@ def upload_csv "negative_other", "question_4" ].sort + rescue CSV::MalformedCSVError => e + flash[:alert] = "There was an error processing the CSV file: #{e.message}" + @valid_file_headers = false rescue @valid_file_headers = false end diff --git a/app/controllers/admin/cx_collections_controller.rb b/app/controllers/admin/cx_collections_controller.rb index 65dd8d73c..15d175ad9 100644 --- a/app/controllers/admin/cx_collections_controller.rb +++ b/app/controllers/admin/cx_collections_controller.rb @@ -17,6 +17,8 @@ def index end def show + ensure_cx_collection_owner(cx_collection: @cx_collection) + @events = Event .where(object_type: "CxCollection", object_uuid: @cx_collection.id) .order("created_at DESC") @@ -27,6 +29,7 @@ def new end def edit + ensure_cx_collection_owner(cx_collection: @cx_collection) end def export_cx_responses_csv @@ -67,6 +70,8 @@ def create end def submit + ensure_cx_collection_owner(cx_collection: @cx_collection) + @cx_collection.submit! Event.log_event(Event.names[:cx_collection_submitted], @cx_collection.class.to_s, @cx_collection.id, "Collection #{@cx_collection.name} submitted at #{DateTime.now}", current_user.id) UserMailer.cx_collection_notification(cx_collection_id: @cx_collection.id).deliver_later @@ -74,12 +79,16 @@ def submit end def publish + ensure_performance_manager_permissions + @cx_collection.publish! Event.log_event(Event.names[:cx_collection_published], @cx_collection.class.to_s, @cx_collection.id, "Collection #{@cx_collection.name} published at #{DateTime.now}", current_user.id) redirect_to admin_cx_collection_path(@cx_collection), notice: 'CX Data Collection has been published successfully.' end def no_report + ensure_performance_manager_permissions + @cx_collection.submitted_at = nil @cx_collection.no_report! Event.log_event(Event.names[:cx_collection_not_reported], @cx_collection.class.to_s, @cx_collection.id, "Collection #{@cx_collection.name} reset at #{DateTime.now}", current_user.id) @@ -87,18 +96,22 @@ def no_report end def reset + ensure_performance_manager_permissions + @cx_collection.reset! Event.log_event(Event.names[:cx_collection_reset], @cx_collection.class.to_s, @cx_collection.id, "Collection #{@cx_collection.name} reset at #{DateTime.now}", current_user.id) redirect_to admin_cx_collection_path(@cx_collection), notice: 'CX Data Collection has been reset successfully.' end def export_csv + ensure_cx_collection_owner(cx_collection: @cx_collection) + if performance_manager_permissions? - @collections = CxCollection.all + @cx_collections = CxCollection.all else - @collections = current_user.cx_collections + @cx_collections = current_user.cx_collections end - send_data @collections.to_csv, filename: "touchpoints-data-cx-collections-#{Date.today}.csv" + send_data @cx_collections.to_csv, filename: "touchpoints-data-cx-collections-#{Date.today}.csv" end def copy @@ -120,6 +133,8 @@ def copy end def update + ensure_cx_collection_owner(cx_collection: @cx_collection) + respond_to do |format| if @cx_collection.update(cx_collection_params) Event.log_event(Event.names[:collection_cx_updated], @cx_collection.class.to_s, @cx_collection.id, "Collection #{@cx_collection.name} updated at #{DateTime.now}", current_user.id) @@ -133,6 +148,8 @@ def update end def destroy + ensure_cx_collection_owner(cx_collection: @cx_collection) + @cx_collection.destroy respond_to do |format| @@ -144,7 +161,11 @@ def destroy private def set_cx_collection - @cx_collection = CxCollection.find(params[:id]) + if performance_manager_permissions? + @cx_collection = CxCollection.find(params[:id]) + else + @cx_collection = current_user.cx_collections.find(params[:id]) + end end def cx_collection_params diff --git a/app/controllers/admin/omb_cx_reporting_collections_controller.rb b/app/controllers/admin/omb_cx_reporting_collections_controller.rb deleted file mode 100644 index bdb5685ea..000000000 --- a/app/controllers/admin/omb_cx_reporting_collections_controller.rb +++ /dev/null @@ -1,142 +0,0 @@ -# frozen_string_literal: true - -module Admin - class OmbCxReportingCollectionsController < AdminController - before_action :set_omb_cx_reporting_collection, only: %i[show edit update destroy] - before_action :set_collections, only: %i[new create edit update] - - def index - ensure_admin - @omb_cx_reporting_collections = OmbCxReportingCollection.all - end - - def show; end - - def new - @omb_cx_reporting_collection = OmbCxReportingCollection.new - - @omb_cx_reporting_collection.collection_id = params[:collection_id] if params[:collection_id] && @collection = Collection.find(params[:collection_id]) - end - - def edit; end - - def create - @omb_cx_reporting_collection = OmbCxReportingCollection.new(omb_cx_reporting_collection_params) - - if @omb_cx_reporting_collection.save - redirect_to admin_omb_cx_reporting_collection_path(@omb_cx_reporting_collection), notice: 'Omb cx reporting collection was successfully created.' - else - render :new - end - end - - def update - if @omb_cx_reporting_collection.update(omb_cx_reporting_collection_params) - redirect_to admin_omb_cx_reporting_collection_path(@omb_cx_reporting_collection), notice: 'Omb cx reporting collection was successfully updated.' - else - render :edit - end - end - - def destroy - @omb_cx_reporting_collection.destroy - redirect_to admin_collection_url(@omb_cx_reporting_collection.collection), notice: 'Omb cx reporting collection was successfully destroyed.' - end - - private - - def set_omb_cx_reporting_collection - @omb_cx_reporting_collection = OmbCxReportingCollection.find(params[:id]) - end - - def set_collections - if performance_manager_permissions? - @collections = Collection.order('organizations.name').includes(:organization) - else - @collections = current_user.collections.order('organizations.name').includes(:organization) - end - end - - def omb_cx_reporting_collection_params - params.require(:omb_cx_reporting_collection).permit( - :collection_id, - :service_id, - :service_provided, - :transaction_point, - :channel, - :volume_of_customers, - :volume_of_customers_provided_survey_opportunity, - :volume_of_respondents, - :omb_control_number, - :federal_register_url, - :operational_metrics, - :q1_text, - :q1_1, - :q1_2, - :q1_3, - :q1_4, - :q1_5, - :q2_text, - :q2_1, - :q2_2, - :q2_3, - :q2_4, - :q2_5, - :q3_text, - :q3_1, - :q3_2, - :q3_3, - :q3_4, - :q3_5, - :q4_text, - :q4_1, - :q4_2, - :q4_3, - :q4_4, - :q4_5, - :q5_text, - :q5_1, - :q5_2, - :q5_3, - :q5_4, - :q5_5, - :q6_text, - :q6_1, - :q6_2, - :q6_3, - :q6_4, - :q6_5, - :q7_text, - :q7_1, - :q7_2, - :q7_3, - :q7_4, - :q7_5, - :q8_text, - :q8_1, - :q8_2, - :q8_3, - :q8_4, - :q8_5, - :q9_text, - :q9_1, - :q9_2, - :q9_3, - :q9_4, - :q9_5, - :q10_text, - :q10_1, - :q10_2, - :q10_3, - :q10_4, - :q10_5, - :q11_text, - :q11_1, - :q11_2, - :q11_3, - :q11_4, - :q11_5, - ) - end - end -end diff --git a/app/controllers/admin/organizations_controller.rb b/app/controllers/admin/organizations_controller.rb index 2d68fbc87..0e36a141b 100644 --- a/app/controllers/admin/organizations_controller.rb +++ b/app/controllers/admin/organizations_controller.rb @@ -26,7 +26,8 @@ def index def show @forms = @organization.forms - @collections = @organization.collections + @cx_collections = @organization.cx_collections + .order(:fiscal_year, :quarter) @users = @organization.users.active.order(:email) end diff --git a/app/controllers/admin/performance_controller.rb b/app/controllers/admin/performance_controller.rb index 98713c112..18c4a27c7 100644 --- a/app/controllers/admin/performance_controller.rb +++ b/app/controllers/admin/performance_controller.rb @@ -20,12 +20,12 @@ def quarterly_performance_notification year = params[:year] quarter = params[:quarter] - Collection.where(aasm_state: 'draft', year:, quarter:).find_each do |collection| - UserMailer.quarterly_performance_notification(collection_id: collection.id).deliver_later + CxCollection.where(aasm_state: 'draft', year:, quarter:).find_each do |cx_collection| + UserMailer.quarterly_performance_notification(cx_collection_id: cx_collection.id).deliver_later end redirect_to admin_performance_path, - notice: 'Quarterly performance email notication sent successfully.' + notice: 'Quarterly performance email notication sent successfully.' end private diff --git a/app/controllers/admin/reporting_controller.rb b/app/controllers/admin/reporting_controller.rb index bf5ee4c60..245040166 100644 --- a/app/controllers/admin/reporting_controller.rb +++ b/app/controllers/admin/reporting_controller.rb @@ -8,312 +8,6 @@ def hisps send_data ServiceProvider.to_csv, filename: "touchpoints-service-providers-#{Date.today}.csv" end - def hisp_services - row = [] - header_fields = %i[ - organization_name - organization_abbreviation - organization_id - service_provider_name - service_provider_slug - year - quarter - service_provided - transaction_point - channel - total_volume - surveys_offered_count - response_count - satisfied - trust - effective - easy - efficient - transparent - employee - ] - - row << header_fields.join(',') - - ServiceProvider.includes(:organization).order('organizations.name', :name).each do |service_provider| - service_provider.services.order(:name).each do |service| - service.omb_cx_reporting_collections.includes(:service, :collection).order('collections.year', 'collections.quarter', 'services.name').each do |omb_cx_reporting_collection| - row_fields = [ - omb_cx_reporting_collection.organization_abbreviation, - "\"#{omb_cx_reporting_collection.organization_name}\"", - omb_cx_reporting_collection.organization_id, - "\"#{omb_cx_reporting_collection.collection.service_provider.name}\"", - omb_cx_reporting_collection.collection.service_provider.slug, - omb_cx_reporting_collection.collection.year, - omb_cx_reporting_collection.collection.quarter, - "\"#{omb_cx_reporting_collection.service_provided}\"", - "\"#{omb_cx_reporting_collection.transaction_point}\"", - "\"#{omb_cx_reporting_collection.channel}\"", - omb_cx_reporting_collection.volume_of_customers, - omb_cx_reporting_collection.volume_of_customers_provided_survey_opportunity, - omb_cx_reporting_collection.volume_of_respondents, - omb_cx_reporting_collection.q1_point_scale, - omb_cx_reporting_collection.q2_point_scale, - omb_cx_reporting_collection.q3_point_scale, - omb_cx_reporting_collection.q4_point_scale, - omb_cx_reporting_collection.q5_point_scale, - omb_cx_reporting_collection.q6_point_scale, - omb_cx_reporting_collection.q7_point_scale, - ] - row << row_fields.join(',') - end - end - end - - render plain: row.join("\n") - end - - def hisp_service_cx_data_collections - rows = [] - header_fields = %i[ - organization_abbreviation - organization_name - organization_id - collection_name - collection_id - year - quarter - service_provider_name - service_provider_slug - service_provider_id - service_name - service_slug - service_id - service_provided - transaction_point - channel - volume_of_customers - volume_of_customers_provided_survey_opportunity - volume_of_customers - volume_of_respondents - omb_control_number - federal_register_url - operational_metrics - start_date - end_date - ] - - rows << header_fields.join(',') - - ServiceProvider.active.includes(:organization).order('organizations.name', :name).each do |service_provider| - service_provider.services.includes(:organization).order('organizations.name', :name).each do |service| - if params[:quarter] - @collections = service.collections.where(quarter: params[:quarter]) - else - @collections = service.collections - end - - @collections.each do |collection| - collection.omb_cx_reporting_collections.includes(:collection).order('collections.year', 'collections.quarter', 'omb_cx_reporting_collections.service_provided', 'omb_cx_reporting_collections.channel').each do |omb_cx_reporting_collection| - row_fields = [ - omb_cx_reporting_collection.organization_abbreviation, - "\"#{omb_cx_reporting_collection.organization_name}\"", - omb_cx_reporting_collection.organization_id, - "\"#{omb_cx_reporting_collection.collection.name}\"", - omb_cx_reporting_collection.collection.id, - omb_cx_reporting_collection.collection.year, - omb_cx_reporting_collection.collection.quarter, - "\"#{omb_cx_reporting_collection.collection.service_provider.name}\"", - omb_cx_reporting_collection.collection.service_provider.slug, - omb_cx_reporting_collection.collection.service_provider.id, - omb_cx_reporting_collection.service.name, - omb_cx_reporting_collection.service.service_slug, - omb_cx_reporting_collection.service.id, - "\"#{omb_cx_reporting_collection.service_provided}\"", - "\"#{omb_cx_reporting_collection.transaction_point}\"", - "\"#{omb_cx_reporting_collection.channel}\"", - omb_cx_reporting_collection.volume_of_customers, - omb_cx_reporting_collection.volume_of_customers_provided_survey_opportunity, - omb_cx_reporting_collection.volume_of_customers, - omb_cx_reporting_collection.volume_of_respondents, - omb_cx_reporting_collection.omb_control_number, - omb_cx_reporting_collection.federal_register_url, - omb_cx_reporting_collection.operational_metrics, - omb_cx_reporting_collection.collection.start_date, - omb_cx_reporting_collection.collection.end_date, - ] - rows << row_fields.join(',') - end - end - end - end - - render plain: rows.join("\n") - end - - def hisp_service_cx_data_collections_summary - rows = [] - header_fields = %i[ - organization_abbreviation - organization_name - organization_id - service_provider_name - service_provider_id - service_id - year - quarter - service_provided - transaction_point - channel - standardized_question_number - standardized_question_identifier - customized_question_text - likert_scale_1 - likert_scale_2 - likert_scale_3 - likert_scale_4 - likert_scale_5 - point_scale - response_volume - notes - question_total - start_date - end_date - ] - - rows << header_fields.join(',') - - ServiceProvider.active.includes(:organization).order('organizations.name', :name).each do |service_provider| - service_provider.services.includes(:organization).order('organizations.name', :name).each do |service| - if params[:quarter] - @collections = service.collections.where(quarter: params[:quarter]) - else - @collections = service.collections - end - - @collections.each do |collection| - collection.omb_cx_reporting_collections.includes(:collection).order('collections.year', 'collections.quarter', 'omb_cx_reporting_collections.service_provided', 'omb_cx_reporting_collections.channel').each do |omb_cx_reporting_collection| - # WRITE A CSV LINE FOR EACH OF THE 7 STANDARD QUESTIONS - (1..7).each do |question_number| - next if params[:question] && (question_number.to_s != params[:question]) - - row_fields = [ - omb_cx_reporting_collection.organization_abbreviation, - "\"#{omb_cx_reporting_collection.organization_name}\"", - omb_cx_reporting_collection.organization_id, - "\"#{omb_cx_reporting_collection.collection.service_provider.name}\"", - omb_cx_reporting_collection.collection.service_provider.slug, - omb_cx_reporting_collection.service.service_slug, - omb_cx_reporting_collection.collection.year, - omb_cx_reporting_collection.collection.quarter, - "\"#{omb_cx_reporting_collection.service_provided}\"", - "\"#{omb_cx_reporting_collection.transaction_point}\"", - "\"#{omb_cx_reporting_collection.channel}\"", - question_number, - hisp_questions_key[question_number.to_s], - "\"#{omb_cx_reporting_collection.send("q#{question_number}_text")}\"", - omb_cx_reporting_collection.send("q#{question_number}_1"), - omb_cx_reporting_collection.send("q#{question_number}_2"), - omb_cx_reporting_collection.send("q#{question_number}_3"), - omb_cx_reporting_collection.send("q#{question_number}_4"), - omb_cx_reporting_collection.send("q#{question_number}_5"), - omb_cx_reporting_collection.send("q#{question_number}_point_scale"), - omb_cx_reporting_collection.question_total(question: "q#{question_number}"), - '', - omb_cx_reporting_collection.collection.start_date, - omb_cx_reporting_collection.collection.end_date, - ] - rows << row_fields.join(',') - end - end - end - end - end - - render plain: rows.join("\n") - end - - def hisp_service_questions - rows = [] - header_fields = %i[ - organization_abbreviation - organization_name - organization_id - service_provider_name - service_provider_id - service_name - service_id - year - quarter - service_provided - transaction_point - channel - standardized_question_number - standardized_question_identifier - customized_question_text - likert_scale_1 - likert_scale_2 - likert_scale_3 - likert_scale_4 - likert_scale_5 - point_scale - response_volume - notes - question_total - start_date - end_date - ] - - header_fields.join(',') - - rows << header_fields.join(',') - - ServiceProvider.active.includes(:organization).order('organizations.name', :name).each do |service_provider| - service_provider.services.includes(:organization).order('organizations.name', :name).each do |service| - if params[:quarter] - @collections = service.collections.where(quarter: params[:quarter]) - else - @collections = service.collections - end - - @collections.each do |collection| - collection.omb_cx_reporting_collections.includes(:collection).order('collections.year', 'collections.quarter', 'omb_cx_reporting_collections.service_provided', 'omb_cx_reporting_collections.channel').each do |omb_cx_reporting_collection| - # WRITE A CSV LINE FOR EACH OF THE 7 STANDARD QUESTIONS - (1..7).each do |question_number| - next if params[:question] && (question_number.to_s != params[:question]) - - row_fields = [ - omb_cx_reporting_collection.organization_abbreviation, - "\"#{omb_cx_reporting_collection.organization_name}\"", - omb_cx_reporting_collection.organization_id, - "\"#{omb_cx_reporting_collection.collection.service_provider.name}\"", - omb_cx_reporting_collection.collection.service_provider.slug, - omb_cx_reporting_collection.service.name, - omb_cx_reporting_collection.service.service_slug, - omb_cx_reporting_collection.collection.year, - omb_cx_reporting_collection.collection.quarter, - "\"#{omb_cx_reporting_collection.service_provided}\"", - omb_cx_reporting_collection.transaction_point, - omb_cx_reporting_collection.channel, - question_number, - hisp_questions_key[question_number.to_s], - "\"#{omb_cx_reporting_collection.send("q#{question_number}_text")}\"", - omb_cx_reporting_collection.send("q#{question_number}_1"), - omb_cx_reporting_collection.send("q#{question_number}_2"), - omb_cx_reporting_collection.send("q#{question_number}_3"), - omb_cx_reporting_collection.send("q#{question_number}_4"), - omb_cx_reporting_collection.send("q#{question_number}_5"), - omb_cx_reporting_collection.send("q#{question_number}_point_scale"), - omb_cx_reporting_collection.question_total(question: "q#{question_number}"), - omb_cx_reporting_collection.collection.start_date, - omb_cx_reporting_collection.collection.end_date, - ] - - rows << row_fields.join(',') - end - end - end - end - end - - render plain: rows.join("\n") - end - def lifespan @form_lifespans = Submission.select('form_id, count(*) as num_submissions, (max(submissions.created_at) - min(submissions.created_at)) as lifespan').group(:form_id) @forms = Form.select(:id, :name, :organization_id, :uuid).where('exists (select id, uuid from submissions where submissions.form_id = forms.id)') diff --git a/app/controllers/admin/services_controller.rb b/app/controllers/admin/services_controller.rb index 7b85fc0f2..4b568acfe 100644 --- a/app/controllers/admin/services_controller.rb +++ b/app/controllers/admin/services_controller.rb @@ -8,7 +8,6 @@ class ServicesController < AdminController submit approve verify archive reset destroy equity_assessment - omb_cx_reporting add_tag remove_tag add_service_manager @@ -85,7 +84,6 @@ def export_csv end def show - @omb_cx_reporting_collections = @service.omb_cx_reporting_collections.includes(:collection).order('collections.year', 'collections.quarter') @cx_collections = @service.cx_collections end @@ -217,8 +215,6 @@ def remove_service_manager def equity_assessment; end - def omb_cx_reporting; end - private def set_service diff --git a/app/controllers/admin/site_controller.rb b/app/controllers/admin/site_controller.rb index d5f2598dd..6334cc44b 100644 --- a/app/controllers/admin/site_controller.rb +++ b/app/controllers/admin/site_controller.rb @@ -28,8 +28,6 @@ def index @recent_forms = Form.includes(:organization).find(form_ids) end - def a11; end - def a11_v2_collections; end def heartbeat diff --git a/app/controllers/admin/users_controller.rb b/app/controllers/admin/users_controller.rb index f01e34612..85e526891 100644 --- a/app/controllers/admin/users_controller.rb +++ b/app/controllers/admin/users_controller.rb @@ -50,7 +50,7 @@ def reactivate def show @forms = @user.forms.order(:status, :name) @websites = Website.where(site_owner_email: @user.email) - @collections = @user.collections.order(:year, :quarter) + @cx_collections = @user.cx_collections.order(:fiscal_year, :quarter) @user_events = Event.limit(100).where(object_type: 'User', object_uuid: @user.id).order('created_at DESC') @service_providers = ServiceProvider.with_role(:service_provider_manager, @user) @services = Service.with_role(:service_manager, @user) diff --git a/app/controllers/api/v1/collections_controller.rb b/app/controllers/api/v1/collections_controller.rb deleted file mode 100644 index 14a26ae55..000000000 --- a/app/controllers/api/v1/collections_controller.rb +++ /dev/null @@ -1,19 +0,0 @@ -# frozen_string_literal: true - -module Api - module V1 - class CollectionsController < ::ApiController - def index - respond_to do |format| - format.json do - if params[:all].present? && params[:all].to_s == '1' - render json: Collection.order(:id), each_serializer: CollectionSerializer - else - render json: Collection.published.order(:id), each_serializer: CollectionSerializer - end - end - end - end - end - end -end diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb index ea1238c87..1437263ef 100644 --- a/app/controllers/application_controller.rb +++ b/app/controllers/application_controller.rb @@ -68,14 +68,6 @@ def ensure_performance_manager_permissions redirect_to(index_path, notice: 'Authorization is Required') end - def ensure_collection_owner(collection:) - return false if collection.blank? - return true if admin_permissions? - return true if collection_permissions?(collection:) - - redirect_to(index_path, notice: 'Authorization is Required') - end - def ensure_cx_collection_owner(cx_collection:) return false if cx_collection.blank? return true if admin_permissions? @@ -176,14 +168,6 @@ def cscrm_manager_permissions? current_user.cscrm_data_collection_manager? end - helper_method :collection_permissions? - def collection_permissions?(collection:) - return false if collection.blank? - return true if performance_manager_permissions? - - collection.organization == current_user.organization - end - helper_method :cx_collection_permissions? def cx_collection_permissions?(cx_collection:) return false if cx_collection.blank? diff --git a/app/mailers/user_mailer.rb b/app/mailers/user_mailer.rb index c286fd71e..0c1ad890c 100644 --- a/app/mailers/user_mailer.rb +++ b/app/mailers/user_mailer.rb @@ -72,13 +72,6 @@ def service_event_notification(subject:, service:, event:, link: '') to: (UserMailer.touchpoints_admin_emails + User.service_managers.collect(&:email)).uniq end - def collection_notification(collection_id:) - set_logo - @collection = Collection.find(collection_id) - mail subject: "Data Collection notification to #{@collection.name}", - to: (UserMailer.touchpoints_admin_emails + User.performance_managers.collect(&:email)).uniq - end - def cx_collection_notification(cx_collection_id:) set_logo @cx_collection = CxCollection.find(cx_collection_id) @@ -88,23 +81,23 @@ def cx_collection_notification(cx_collection_id:) def cscrm_data_collection_notification(collection_id:) set_logo - @collection = CscrmDataCollection.find(collection_id) - mail subject: "CSCRM Data Collection notification to #{@collection.id}", + @cscrm_data_collection = CscrmDataCollection.find(collection_id) + mail subject: "CSCRM Data Collection notification to #{@cscrm_data_collection.id}", to: (UserMailer.touchpoints_admin_emails + User.where(cscrm_data_collection_manager: true).collect(&:email)).uniq end def cscrm_data_collection2_notification(collection_id:) set_logo - @collection = CscrmDataCollection2.find(collection_id) - mail subject: "CSCRM Data Collection 2 notification to #{@collection.id}", + @cscrm_data_collection = CscrmDataCollection2.find(collection_id) + mail subject: "CSCRM Data Collection 2 notification to #{@cscrm_data_collection.id}", to: (UserMailer.touchpoints_admin_emails + User.where(cscrm_data_collection_manager: true).collect(&:email)).uniq end - def quarterly_performance_notification(collection_id:) + def quarterly_performance_notification(cx_collection_id:) set_logo - @collection = Collection.find(collection_id) - mail subject: "Quarterly Performance Data Collection Ready: #{@collection.name}", - to: @collection.user.email, + @cx_collection = CxCollection.find(cx_collection_id) + mail subject: "Quarterly Performance Data Collection Ready: #{@cx_collection.name}", + to: @cx_collection.user.email, cc: User.performance_managers.collect(&:email).uniq end diff --git a/app/models/collection.rb b/app/models/collection.rb deleted file mode 100644 index d7a887cf0..000000000 --- a/app/models/collection.rb +++ /dev/null @@ -1,213 +0,0 @@ -# frozen_string_literal: true - -class Collection < ApplicationRecord - include AASM - - belongs_to :organization - belongs_to :service_provider - belongs_to :user - has_many :omb_cx_reporting_collections, dependent: :delete_all - - validates :year, presence: true - validates :quarter, presence: true - - validates :name, presence: true - validates :reflection, length: { maximum: 5000 } - - scope :published, -> { where(aasm_state: 'published') } - - def omb_control_number - 'omb_control_number' - end - - aasm do - state :draft, initial: true - state :submitted - state :published - state :change_requested - state :archived - - event :submit do - transitions from: %i[draft change_requested], to: :submitted - end - - event :publish do - transitions from: :submitted, to: :published - end - - event :request_change do - transitions from: [:submitted], to: :change_requested - end - - event :archive do - transitions from: [:published], to: :archived - end - - event :reset do - transitions to: :draft - end - end - - def duplicate!(new_user:) - new_collection = dup - new_collection.user = new_user - new_collection.name = "Copy of #{name}" - new_collection.start_date = nil - new_collection.end_date = nil - new_collection.reflection = nil - new_collection.rating = nil - new_collection.aasm_state = :draft - new_collection.save - - # Loop OMB CX Reporting Collections to create them for new_collection - omb_cx_reporting_collections.each do |omb_cx_reporting_collection| - new_omb_cx_reporting_collection = omb_cx_reporting_collection.dup - new_omb_cx_reporting_collection.collection = new_collection - new_omb_cx_reporting_collection.volume_of_customers = 0 - new_omb_cx_reporting_collection.volume_of_customers_provided_survey_opportunity = 0 - new_omb_cx_reporting_collection.volume_of_respondents = 0 - new_omb_cx_reporting_collection.q1_1 = 0 - new_omb_cx_reporting_collection.q1_2 = 0 - new_omb_cx_reporting_collection.q1_3 = 0 - new_omb_cx_reporting_collection.q1_4 = 0 - new_omb_cx_reporting_collection.q1_5 = 0 - new_omb_cx_reporting_collection.q2_1 = 0 - new_omb_cx_reporting_collection.q2_2 = 0 - new_omb_cx_reporting_collection.q2_3 = 0 - new_omb_cx_reporting_collection.q2_4 = 0 - new_omb_cx_reporting_collection.q2_5 = 0 - new_omb_cx_reporting_collection.q3_1 = 0 - new_omb_cx_reporting_collection.q3_2 = 0 - new_omb_cx_reporting_collection.q3_3 = 0 - new_omb_cx_reporting_collection.q3_4 = 0 - new_omb_cx_reporting_collection.q3_5 = 0 - new_omb_cx_reporting_collection.q4_1 = 0 - new_omb_cx_reporting_collection.q4_2 = 0 - new_omb_cx_reporting_collection.q4_3 = 0 - new_omb_cx_reporting_collection.q4_4 = 0 - new_omb_cx_reporting_collection.q4_5 = 0 - new_omb_cx_reporting_collection.q5_1 = 0 - new_omb_cx_reporting_collection.q5_2 = 0 - new_omb_cx_reporting_collection.q5_3 = 0 - new_omb_cx_reporting_collection.q5_4 = 0 - new_omb_cx_reporting_collection.q5_5 = 0 - new_omb_cx_reporting_collection.q6_1 = 0 - new_omb_cx_reporting_collection.q6_2 = 0 - new_omb_cx_reporting_collection.q6_3 = 0 - new_omb_cx_reporting_collection.q6_4 = 0 - new_omb_cx_reporting_collection.q6_5 = 0 - new_omb_cx_reporting_collection.q7_1 = 0 - new_omb_cx_reporting_collection.q7_2 = 0 - new_omb_cx_reporting_collection.q7_3 = 0 - new_omb_cx_reporting_collection.q7_4 = 0 - new_omb_cx_reporting_collection.q7_5 = 0 - new_omb_cx_reporting_collection.q8_1 = 0 - new_omb_cx_reporting_collection.q8_2 = 0 - new_omb_cx_reporting_collection.q8_3 = 0 - new_omb_cx_reporting_collection.q8_4 = 0 - new_omb_cx_reporting_collection.q8_5 = 0 - new_omb_cx_reporting_collection.q9_1 = 0 - new_omb_cx_reporting_collection.q9_2 = 0 - new_omb_cx_reporting_collection.q9_3 = 0 - new_omb_cx_reporting_collection.q9_4 = 0 - new_omb_cx_reporting_collection.q9_5 = 0 - new_omb_cx_reporting_collection.q10_1 = 0 - new_omb_cx_reporting_collection.q10_2 = 0 - new_omb_cx_reporting_collection.q10_3 = 0 - new_omb_cx_reporting_collection.q10_4 = 0 - new_omb_cx_reporting_collection.q10_5 = 0 - new_omb_cx_reporting_collection.q11_1 = 0 - new_omb_cx_reporting_collection.q11_2 = 0 - new_omb_cx_reporting_collection.q11_3 = 0 - new_omb_cx_reporting_collection.q11_4 = 0 - new_omb_cx_reporting_collection.q11_5 = 0 - new_omb_cx_reporting_collection.save! - end - - new_collection - end - - def totals - @volume_of_customers = 0 - @volume_of_customers_provided_survey_opportunity = 0 - @volume_of_respondents = 0 - - omb_cx_reporting_collections.each do |omb_cx_reporting_collection| - @volume_of_customers += omb_cx_reporting_collection.volume_of_customers.to_i - @volume_of_customers_provided_survey_opportunity += omb_cx_reporting_collection.volume_of_customers_provided_survey_opportunity.to_i - @volume_of_respondents += omb_cx_reporting_collection.volume_of_respondents.to_i - end - - { - volume_of_customers: @volume_of_customers, - volume_of_customers_provided_survey_opportunity: @volume_of_customers_provided_survey_opportunity, - volume_of_respondents: @volume_of_respondents, - } - end - - def self.to_csv - collections = Collection.order(:year, :quarter, 'organizations.name').includes(:organization) - - attributes = %i[ - id - name - start_date - end_date - service_provider_id - service_provider_name - service_provider_organization_id - service_provider_organization_name - service_provider_organization_abbreviation - organization_id - organization_name - organization_abbreviation - user_email - year - quarter - reflection - created_at - updated_at - rating - aasm_state - integrity_hash - omb_cx_reporting_collections_count - ] - - CSV.generate(headers: true) do |csv| - csv << attributes - - collections.each do |collection| - csv << attributes = [ - collection.id, - collection.name, - collection.start_date, - collection.end_date, - collection.service_provider_id, - collection.service_provider.name, - collection.service_provider.organization_id, - collection.service_provider.organization_name, - collection.service_provider.organization_abbreviation, - collection.organization_id, - collection.organization.name, - collection.organization.abbreviation, - collection.user.email, - collection.year, - collection.quarter, - collection.reflection, - collection.created_at, - collection.updated_at, - collection.rating, - collection.aasm_state, - collection.integrity_hash, - collection.omb_cx_reporting_collections.size, - ] - end - end - end - - delegate :name, to: :organization, prefix: true - - delegate :abbreviation, to: :organization, prefix: true - - delegate :name, to: :service_provider, prefix: true -end diff --git a/app/models/cx_collection.rb b/app/models/cx_collection.rb index 5429b9f49..face78d7c 100644 --- a/app/models/cx_collection.rb +++ b/app/models/cx_collection.rb @@ -110,7 +110,7 @@ def self.to_csv rating aasm_state integrity_hash - omb_cx_reporting_collections_count + cx_collection_details_count ] CSV.generate(headers: true) do |csv| diff --git a/app/models/omb_cx_reporting_collection.rb b/app/models/omb_cx_reporting_collection.rb deleted file mode 100644 index ebeef41e5..000000000 --- a/app/models/omb_cx_reporting_collection.rb +++ /dev/null @@ -1,385 +0,0 @@ -# frozen_string_literal: true - -class OmbCxReportingCollection < ApplicationRecord - belongs_to :collection - belongs_to :service - - validates :service_provided, presence: true - - scope :published, lambda { - joins(:collection).where("collections.aasm_state = 'published'") - } - - (1..11).each do |q| - (1..5).each do |a| - validates :"q#{q}_#{a}", numericality: true - end - end - - def answer_points(question:) - (send("#{question}_1") * 1.0) + - (send("#{question}_2") * 2.0) + - (send("#{question}_3") * 3.0) + - (send("#{question}_4") * 4.0) + - (send("#{question}_5") * 5.0) - end - - def omb_control_number - super || 'OMB Control Number' - end - - def federal_register_url - super || 'https:///www.reginfo.gov/...' - end - - def q1_point_scale - ( - answer_points(question: :q1) / - q1_total - ).round(2) - end - - def q2_point_scale - ( - answer_points(question: :q2) / - q2_total - ).round(2) - end - - def q3_point_scale - ( - answer_points(question: :q3) / - q3_total - ).round(2) - end - - def q4_point_scale - ( - answer_points(question: :q4) / - q4_total - ).round(2) - end - - def q5_point_scale - ( - answer_points(question: :q5) / - q5_total - ).round(2) - end - - def q6_point_scale - ( - answer_points(question: :q6) / - q6_total - ).round(2) - end - - def q7_point_scale - ( - answer_points(question: :q7) / - q7_total - ).round(2) - end - - def q8_point_scale - ( - answer_points(question: :q8) / - q8_total - ).round(2) - end - - def q9_point_scale - ( - answer_points(question: :q9) / - q9_total - ).round(2) - end - - def q10_point_scale - ( - answer_points(question: :q10) / - q10_total - ).round(2) - end - - def q11_point_scale - ( - answer_points(question: :q11) / - q11_total - ).round(2) - end - - def question_total(question: nil) - send("#{question}_1") + - send("#{question}_2") + - send("#{question}_3") + - send("#{question}_4") + - send("#{question}_5") - end - - def q1_total - question_total(question: :q1) - end - - def q2_total - question_total(question: :q2) - end - - def q3_total - question_total(question: :q3) - end - - def q4_total - question_total(question: :q4) - end - - def q5_total - question_total(question: :q5) - end - - def q6_total - question_total(question: :q6) - end - - def q7_total - question_total(question: :q7) - end - - def q8_total - question_total(question: :q8) - end - - def q9_total - question_total(question: :q9) - end - - def q10_total - question_total(question: :q10) - end - - def q11_total - question_total(question: :q11) - end - - def volume_total - q1_total + q2_total + q3_total + q4_total + q5_total + q6_total + q7_total + q8_total + q9_total + q10_total + q11_total - end - - def self.to_csv - omb_cx_reporting_collections = OmbCxReportingCollection.all - - attributes = %i[ - id - collection_id - collection_year - collection_quarter - collection_name - collection_organization_id - collection_organization_name - collection_organization_abbreviation - service_provider_id - service_provider_name - service_provider_organization_id - service_provider_organization_name - service_provider_organization_abbreviation - service_provided - service_id - service_name - transaction_point - channel - volume_of_customers - volume_of_customers_provided_survey_opportunity - volume_of_respondents - omb_control_number - federal_register_url - q1_text - q1_1 - q1_2 - q1_3 - q1_4 - q1_5 - q2_text - q2_1 - q2_2 - q2_3 - q2_4 - q2_5 - q3_text - q3_1 - q3_2 - q3_3 - q3_4 - q3_5 - q4_text - q4_1 - q4_2 - q4_3 - q4_4 - q4_5 - q5_text - q5_1 - q5_2 - q5_3 - q5_4 - q5_5 - q6_text - q6_1 - q6_2 - q6_3 - q6_4 - q6_5 - q7_text - q7_1 - q7_2 - q7_3 - q7_4 - q7_5 - q8_text - q8_1 - q8_2 - q8_3 - q8_4 - q8_5 - q9_text - q9_1 - q9_2 - q9_3 - q9_4 - q9_5 - q10_text - q10_1 - q10_2 - q10_3 - q10_4 - q10_5 - q11_text - q11_1 - q11_2 - q11_3 - q11_4 - q11_5 - created_at - updated_at - operational_metrics - ] - - CSV.generate(headers: true) do |csv| - csv << attributes - - omb_cx_reporting_collections.each do |omb_cx_reporting_collection| - csv << attributes = [ - omb_cx_reporting_collection.id, - omb_cx_reporting_collection.collection_id, - omb_cx_reporting_collection.collection.year, - omb_cx_reporting_collection.collection.quarter, - omb_cx_reporting_collection.collection.name, - omb_cx_reporting_collection.collection.organization_id, - omb_cx_reporting_collection.collection.organization.abbreviation, - omb_cx_reporting_collection.collection.organization.name, - omb_cx_reporting_collection.collection.service_provider_id, - omb_cx_reporting_collection.collection.service_provider.name, - omb_cx_reporting_collection.collection.service_provider.organization_id, - omb_cx_reporting_collection.collection.service_provider.organization_name, - omb_cx_reporting_collection.collection.service_provider.organization_abbreviation, - omb_cx_reporting_collection.service_provided, - omb_cx_reporting_collection.service_id, - omb_cx_reporting_collection.service.name, - omb_cx_reporting_collection.transaction_point, - omb_cx_reporting_collection.channel, - omb_cx_reporting_collection.volume_of_customers, - omb_cx_reporting_collection.volume_of_customers_provided_survey_opportunity, - omb_cx_reporting_collection.volume_of_respondents, - omb_cx_reporting_collection.omb_control_number, - omb_cx_reporting_collection.federal_register_url, - omb_cx_reporting_collection.q1_text, - omb_cx_reporting_collection.q1_1, - omb_cx_reporting_collection.q1_2, - omb_cx_reporting_collection.q1_3, - omb_cx_reporting_collection.q1_4, - omb_cx_reporting_collection.q1_5, - omb_cx_reporting_collection.q2_text, - omb_cx_reporting_collection.q2_1, - omb_cx_reporting_collection.q2_2, - omb_cx_reporting_collection.q2_3, - omb_cx_reporting_collection.q2_4, - omb_cx_reporting_collection.q2_5, - omb_cx_reporting_collection.q3_text, - omb_cx_reporting_collection.q3_1, - omb_cx_reporting_collection.q3_2, - omb_cx_reporting_collection.q3_3, - omb_cx_reporting_collection.q3_4, - omb_cx_reporting_collection.q3_5, - omb_cx_reporting_collection.q4_text, - omb_cx_reporting_collection.q4_1, - omb_cx_reporting_collection.q4_2, - omb_cx_reporting_collection.q4_3, - omb_cx_reporting_collection.q4_4, - omb_cx_reporting_collection.q4_5, - omb_cx_reporting_collection.q5_text, - omb_cx_reporting_collection.q5_1, - omb_cx_reporting_collection.q5_2, - omb_cx_reporting_collection.q5_3, - omb_cx_reporting_collection.q5_4, - omb_cx_reporting_collection.q5_5, - omb_cx_reporting_collection.q6_text, - omb_cx_reporting_collection.q6_1, - omb_cx_reporting_collection.q6_2, - omb_cx_reporting_collection.q6_3, - omb_cx_reporting_collection.q6_4, - omb_cx_reporting_collection.q6_5, - omb_cx_reporting_collection.q7_text, - omb_cx_reporting_collection.q7_1, - omb_cx_reporting_collection.q7_2, - omb_cx_reporting_collection.q7_3, - omb_cx_reporting_collection.q7_4, - omb_cx_reporting_collection.q7_5, - omb_cx_reporting_collection.q8_text, - omb_cx_reporting_collection.q8_1, - omb_cx_reporting_collection.q8_2, - omb_cx_reporting_collection.q8_3, - omb_cx_reporting_collection.q8_4, - omb_cx_reporting_collection.q8_5, - omb_cx_reporting_collection.q9_text, - omb_cx_reporting_collection.q9_1, - omb_cx_reporting_collection.q9_2, - omb_cx_reporting_collection.q9_3, - omb_cx_reporting_collection.q9_4, - omb_cx_reporting_collection.q9_5, - omb_cx_reporting_collection.q10_text, - omb_cx_reporting_collection.q10_1, - omb_cx_reporting_collection.q10_2, - omb_cx_reporting_collection.q10_3, - omb_cx_reporting_collection.q10_4, - omb_cx_reporting_collection.q10_5, - omb_cx_reporting_collection.q11_text, - omb_cx_reporting_collection.q11_1, - omb_cx_reporting_collection.q11_2, - omb_cx_reporting_collection.q11_3, - omb_cx_reporting_collection.q11_4, - omb_cx_reporting_collection.q11_5, - omb_cx_reporting_collection.created_at, - omb_cx_reporting_collection.updated_at, - omb_cx_reporting_collection.operational_metrics, - ] - end - end - end - - delegate :organization, to: :collection - - delegate :id, to: :organization, prefix: true - - delegate :name, to: :organization, prefix: true - - delegate :abbreviation, to: :organization, prefix: true - - delegate :name, to: :collection, prefix: true - - delegate :year, to: :collection, prefix: true - - delegate :quarter, to: :collection, prefix: true - - delegate :name, to: :service, prefix: true - - delegate :service_slug, to: :service -end diff --git a/app/models/organization.rb b/app/models/organization.rb index 274bba434..d8f384ca9 100644 --- a/app/models/organization.rb +++ b/app/models/organization.rb @@ -7,7 +7,6 @@ class Organization < ApplicationRecord has_many :service_providers has_many :services has_many :websites - has_many :collections has_many :cx_collections has_many :cscrm_data_collections has_many :cscrm_data_collections2, class_name: "CscrmDataCollection2" diff --git a/app/models/service.rb b/app/models/service.rb index f8c6f25f6..8bbbedf51 100644 --- a/app/models/service.rb +++ b/app/models/service.rb @@ -11,9 +11,6 @@ class Service < ApplicationRecord belongs_to :service_provider, optional: true, counter_cache: true has_many :service_stages, dependent: :delete_all - has_many :omb_cx_reporting_collections - has_many :collections, through: :omb_cx_reporting_collections - has_many :cx_collections has_many :cx_collection_details, through: :cx_collections diff --git a/app/models/service_provider.rb b/app/models/service_provider.rb index 47e8c0542..4c35b2f1b 100644 --- a/app/models/service_provider.rb +++ b/app/models/service_provider.rb @@ -4,8 +4,8 @@ class ServiceProvider < ApplicationRecord resourcify belongs_to :organization has_many :services - has_many :collections, through: :services - has_many :omb_cx_reporting_collections, through: :collections + has_many :cx_collections, through: :services + has_many :cx_collection_details, through: :cx_collections acts_as_taggable_on :tags validates :name, presence: true diff --git a/app/models/user.rb b/app/models/user.rb index 3d46d1591..ed142280c 100644 --- a/app/models/user.rb +++ b/app/models/user.rb @@ -16,7 +16,6 @@ class User < ApplicationRecord belongs_to :organization, optional: true has_many :user_roles, dependent: :destroy has_many :forms, through: :user_roles, primary_key: 'form_id' - has_many :collections, through: :organization def cx_collections user_org = organization diff --git a/app/serializers/collection_serializer.rb b/app/serializers/collection_serializer.rb deleted file mode 100644 index 7a59ebafa..000000000 --- a/app/serializers/collection_serializer.rb +++ /dev/null @@ -1,23 +0,0 @@ -# frozen_string_literal: true - -class CollectionSerializer < ActiveModel::Serializer - attributes :id, - :name, - :start_date, - :end_date, - :organization_id, - :organization_name, - :organization_abbreviation, - :year, - :quarter, - :service_provider_id, - :service_provider_name, - :integrity_hash, - :aasm_state, - :reflection, - :rating, - :user_id, - :updated_at - - has_many :omb_cx_reporting_collections -end diff --git a/app/views/admin/collections/_csv_detail_row.html.erb b/app/views/admin/collections/_csv_detail_row.html.erb deleted file mode 100644 index eb1bca21e..000000000 --- a/app/views/admin/collections/_csv_detail_row.html.erb +++ /dev/null @@ -1 +0,0 @@ -<%= omb_cx_reporting_collection.collection.service_provider.slug %>,<%= omb_cx_reporting_collection.service.service_slug %>,<%= omb_cx_reporting_collection.collection.year %>,<%= omb_cx_reporting_collection.collection.quarter %>,"<%= omb_cx_reporting_collection.service_provided %>","<%= omb_cx_reporting_collection.transaction_point %>",<%= omb_cx_reporting_collection.channel %>,<%= question_number %>,<%= hisp_questions_key[question_number.to_s] %>,"<%= omb_cx_reporting_collection.send("q#{question_number}_text") %>",<%= omb_cx_reporting_collection.send("q#{question_number}_1") %>,<%= omb_cx_reporting_collection.send("q#{question_number}_2") %>,<%= omb_cx_reporting_collection.send("q#{question_number}_3") %>,<%= omb_cx_reporting_collection.send("q#{question_number}_4") %>,<%= omb_cx_reporting_collection.send("q#{question_number}_5") %>,<%= omb_cx_reporting_collection.send("q#{question_number}_point_scale") %>,<%= omb_cx_reporting_collection.question_total(question: "q#{question_number}") %>,"",<%= omb_cx_reporting_collection.collection.start_date %>,<%= omb_cx_reporting_collection.collection.end_date %> diff --git a/app/views/admin/collections/_form.html.erb b/app/views/admin/collections/_form.html.erb deleted file mode 100644 index 9a8c65803..000000000 --- a/app/views/admin/collections/_form.html.erb +++ /dev/null @@ -1,114 +0,0 @@ -<%= form_with(model: collection, url: collection.persisted? ? admin_collection_path(collection) : admin_collections_path, local: true, data: { turbo: false }) do |f| %> - <%- if collection.errors.any? %> -
-

<%= pluralize(collection.errors.count, "error") %> prohibited this collection from being saved:

- - -
- <% end %> - - <%- if performance_manager_permissions? %> -
- <%= f.label :user_id, class: "usa-label" %> - <%= f.select :user_id, options_for_select(User.all.collect { |u| [u.email, u.id] }, collection.user_id), { prompt: "Which User?", include_blank: true }, { class: "usa-select" } %> -
- <% else %> - <%= f.hidden_field :user_id, value: current_user.id %> - <% end %> - - <%- if performance_manager_permissions? %> -
- <%= f.label :organization_id, class: "usa-label" %> - <%= f.select :organization_id, options_for_select(organization_dropdown_options, collection.organization_id), { prompt: "Which Organization?" }, { class: "usa-select" } %> -
- <% else %> - <%= f.hidden_field :organization_id, value: current_user.organization_id %> - <% end %> - -
- <%= f.label :service_provider_id, "HISP Service Provider", class: "usa-label" %> - <%= f.select :service_provider_id, ServiceProvider.all.map { |h| ["#{h.organization.abbreviation} - #{h.organization.name} - #{h.name}", h.id] }, { include_blank: true }, class: "usa-select" %> -
- -
- <%= f.label :name, class: "usa-label" %> - <%= f.select :name, ["CX Quarterly Reporting"], {}, class: "usa-select" %> -
- - <%- if performance_manager_permissions? && collection.persisted? %> -
- <%= f.label :aasm_state, class: "usa-label" %> - <%= f.select :aasm_state, [:draft, :submitted, :published, :change_requested], {}, class: "usa-select" %> -
- <% else %> - <%= f.hidden_field :aasm_state, value: :draft %> - <% end %> - - <%- if performance_manager_permissions? && collection.persisted? %> - <% rating_options = [ - ["🟢 Reporting within A-11 guidelines", "TRUE"], - ["🔴 Not submitting data", "FALSE"], - ["🟡 Reporting partially within A-11 guidelines", "PARTIAL"] - ] %> -
- <%= f.label :rating, class: "usa-label" %> - <%= f.select :rating, rating_options, { include_blank: true }, { class: "usa-select" } %> -
- <% end %> - - <%- if collection.persisted? %> -
- <%= f.label :start_date, class: "usa-label", id: "expiration-date-label" %> -
- <%= f.text_field :start_date, placeholder: "YYYY-MM-DD", class: "usa-input" %> -
-
- -
- <%= f.label :end_date, class: "usa-label", id: "expiration-date-label" %> -
- <%= f.text_field :end_date, placeholder: "YYYY-MM-DD", class: "usa-input" %> -
-
- <% end %> - -
- <%= f.label :year, "Fiscal year", class: "usa-label" %> - <%= f.text_field :year, class: "usa-input" %> -
- - <%= f.label :quarter, "Fiscal quarter", class: "usa-label" %> -
- Quarter -
- <% (1..4).each do |i| %> -
- <%= f.radio_button(:quarter, i.to_s, { id: i.to_s, class: "usa-radio__input usa-radio__input--tile" }) %> - <%= label_tag(i, nil, class: "usa-radio__label") do %> - <%= i.to_s %> - <% end %> -
- <% end %> -
-
- - <%= f.label :reflection, class: "usa-label" %> - - What did your agency learn from this quarter / past pull's data? What seems to matter to your customers? Where might there be a pain point? - - - <%= f.text_area :reflection, class: "usa-textarea", rows: 8, maxlength: 5000 %> - -

- <%= f.submit class: "usa-button" %> -

-<% end %> - diff --git a/app/views/admin/collections/_hisps_csv_details.html.erb b/app/views/admin/collections/_hisps_csv_details.html.erb deleted file mode 100644 index 02638c409..000000000 --- a/app/views/admin/collections/_hisps_csv_details.html.erb +++ /dev/null @@ -1,72 +0,0 @@ -
-

- -

-
-
-

- This .csv data is used to populate the individual Services of each HISP on performance.gov. -

-

- Filter by Question: - <%= link_to "Question 1", admin_collections_path(question: 1) %> - <%= link_to "Question 2", admin_collections_path(question: 2) %> - <%= link_to "Question 3", admin_collections_path(question: 3) %> - <%= link_to "Question 4", admin_collections_path(question: 4) %> - <%= link_to "Question 5", admin_collections_path(question: 5) %> - <%= link_to "Question 6", admin_collections_path(question: 6) %> - <%= link_to "Question 7", admin_collections_path(question: 7) %> -

-
- <% header_fields = [ - :service_provider_id, - :service_id, - :year, - :quarter, - :service_provided, - :transaction_point, - :channel, - :standardized_question_number, - :standardized_question_identifier, - :customized_question_text, - :likert_scale_1, - :likert_scale_2, - :likert_scale_3, - :likert_scale_4, - :likert_scale_5, - :point_scale, - :response_volume, - :notes, - :question_total, - :start_date, - :end_date - ] %> - <%= header_fields.join(",") %> -
- <% ServiceProvider.active.includes(:organization).order("organizations.name", :name).each do |service_provider| %> - <% service_provider.services.includes(:organization, :collections, :omb_cx_reporting_collections).order("organizations.name", :name).each do |service| %> - <%- if params[:quarter] %> - <% @collections = service.collections.where(quarter: params[:quarter]) %> - <% else %> - <% @collections = service.collections %> - <% end %> - <% @collections.each do |collection| %> - <% collection.omb_cx_reporting_collections.includes(:collection).order("collections.year", "collections.quarter", "omb_cx_reporting_collections.service_provided", "omb_cx_reporting_collections.channel").each do |omb_cx_reporting_collection| %> - <%# WRITE A CSV LINE FOR EACH OF THE 7 STANDARD QUESTIONS %> - <% (1..7).each do |question_number| %> - <% next if params[:question] && (question_number.to_s != params[:question]) %> - <%= render 'admin/collections/csv_detail_row', omb_cx_reporting_collection: omb_cx_reporting_collection, question_number: question_number %> -
- <% end %> - <% end %> - <% end %> - <% end %> - <% end %> -
-
-
diff --git a/app/views/admin/collections/_omb_a11_cx_quarterly_reporting.html.erb b/app/views/admin/collections/_omb_a11_cx_quarterly_reporting.html.erb deleted file mode 100644 index cfa145071..000000000 --- a/app/views/admin/collections/_omb_a11_cx_quarterly_reporting.html.erb +++ /dev/null @@ -1,350 +0,0 @@ - -<%= form_with(model: Form.collection, url: (collection.persisted? ? admin_collection_path(collection) : admin_organizations_path), local: true, data: { turbo: false }) do |form| %> - <%- if collection.errors.any? %> -
-

- <%= pluralize(collection.errors.count, "error") %> prohibited this collection from being saved: -

- -
- <% end %> - -
-
- <%= form.label :service_provided, class: "usa-label" %> - <%= form.text_field :service_provided, class: "usa-input", placeholder: "Description of the service provided" %> -
-
- <%= form.label :transaction_point, class: "usa-label" %> - <%= form.text_field :transaction_point, class: "usa-input", placeholder: "Transaction point at which survey is provided" %> -
-
- <%= form.label :channel, class: "usa-label" %> - <%= form.select :channel, [:computer, :mobile, :paper, :in_person], { prompt: "What type of response channel?" }, class: "usa-select" %> -
-
- <%= form.label :volume_of_customers, class: "usa-label" %> - <%= form.text_field :volume_of_customers, class: "usa-input", placeholder: "# of customers (total volume)" %> -
-
- <%= form.label :volume_of_customers_provided_survey_opportunity, class: "usa-label" %> - <%= form.text_field :volume_of_customers_provided_survey_opportunity, class: "usa-input", placeholder: "# of customers shown this prompt" %> -
-
- <%= form.label :volume_of_respondents, class: "usa-label" %> - <%= form.text_field :volume_of_respondents, class: "usa-input", placeholder: "# of respondents" %> -
-
- <%= form.label :omb_control_number, class: "usa-label" %> - <%= form.text_field :omb_control_number, class: "usa-input", placeholder: "OMB Control #{}" %> -
-
- <%= form.label :federal_register_url, class: "usa-label" %> - <%= form.url_field :federal_register_url, class: "usa-input", placeholder: "https://federalregister.gov/..." %> -
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - Question text - - 1 - - 2 - - 3 - - 4 - - 5 -
- Satisfaction - - <%= form.text_field :q1_text, class: "usa-input" %> - - <%= form.text_field :q1_1, class: "usa-input" %> - - <%= form.text_field :q1_2, class: "usa-input" %> - - <%= form.text_field :q1_3, class: "usa-input" %> - - <%= form.text_field :q1_4, class: "usa-input" %> - - <%= form.text_field :q1_5, class: "usa-input" %> -
- Trust or Confidence - - <%= form.text_field :q2_text, class: "usa-input" %> - - <%= form.text_field :q2_1, class: "usa-input" %> - - <%= form.text_field :q2_2, class: "usa-input" %> - - <%= form.text_field :q2_3, class: "usa-input" %> - - <%= form.text_field :q2_4, class: "usa-input" %> - - <%= form.text_field :q2_5, class: "usa-input" %> -
- Effectiveness (Service) - - <%= form.text_field :q3_text, class: "usa-input" %> - - <%= form.text_field :q3_1, class: "usa-input" %> - - <%= form.text_field :q3_2, class: "usa-input" %> - - <%= form.text_field :q3_3, class: "usa-input" %> - - <%= form.text_field :q3_4, class: "usa-input" %> - - <%= form.text_field :q3_5, class: "usa-input" %> -
- Ease (Process) - - <%= form.text_field :q4_text, class: "usa-input" %> - - <%= form.text_field :q4_1, class: "usa-input" %> - - <%= form.text_field :q4_2, class: "usa-input" %> - - <%= form.text_field :q4_3, class: "usa-input" %> - - <%= form.text_field :q4_4, class: "usa-input" %> - - <%= form.text_field :q4_5, class: "usa-input" %> -
- Efficiency (Process) - - <%= form.text_field :q5_text, class: "usa-input" %> - - <%= form.text_field :q5_1, class: "usa-input" %> - - <%= form.text_field :q5_2, class: "usa-input" %> - - <%= form.text_field :q5_3, class: "usa-input" %> - - <%= form.text_field :q5_4, class: "usa-input" %> - - <%= form.text_field :q5_5, class: "usa-input" %> -
- Transparency (Process) - - <%= form.text_field :q6_text, class: "usa-input" %> - - <%= form.text_field :q6_1, class: "usa-input" %> - - <%= form.text_field :q6_2, class: "usa-input" %> - - <%= form.text_field :q6_3, class: "usa-input" %> - - <%= form.text_field :q6_4, class: "usa-input" %> - - <%= form.text_field :q6_5, class: "usa-input" %> -
- Employee (People) - - <%= form.text_field :q7_text, class: "usa-input" %> - - <%= form.text_field :q7_1, class: "usa-input" %> - - <%= form.text_field :q7_2, class: "usa-input" %> - - <%= form.text_field :q7_3, class: "usa-input" %> - - <%= form.text_field :q7_4, class: "usa-input" %> - - <%= form.text_field :q7_5, class: "usa-input" %> -
- Question 8 - - <%= form.text_field :q8_text, class: "usa-input" %> - - <%= form.text_field :q8_1, class: "usa-input" %> - - <%= form.text_field :q8_2, class: "usa-input" %> - - <%= form.text_field :q8_3, class: "usa-input" %> - - <%= form.text_field :q8_4, class: "usa-input" %> - - <%= form.text_field :q8_5, class: "usa-input" %> -
- Question 9 - - <%= form.text_field :q9_text, class: "usa-input" %> - - <%= form.text_field :q9_1, class: "usa-input" %> - - <%= form.text_field :q9_2, class: "usa-input" %> - - <%= form.text_field :q9_3, class: "usa-input" %> - - <%= form.text_field :q9_4, class: "usa-input" %> - - <%= form.text_field :q9_5, class: "usa-input" %> -
- Question 10 - - <%= form.text_field :q10_text, class: "usa-input" %> - - <%= form.text_field :q10_1, class: "usa-input" %> - - <%= form.text_field :q10_2, class: "usa-input" %> - - <%= form.text_field :q10_3, class: "usa-input" %> - - <%= form.text_field :q10_4, class: "usa-input" %> - - <%= form.text_field :q10_5, class: "usa-input" %> -
- Question 11 - - <%= form.text_field :q11_text, class: "usa-input" %> - - <%= form.text_field :q11_1, class: "usa-input" %> - - <%= form.text_field :q11_2, class: "usa-input" %> - - <%= form.text_field :q11_3, class: "usa-input" %> - - <%= form.text_field :q11_4, class: "usa-input" %> - - <%= form.text_field :q11_5, class: "usa-input" %> -
- - - - What did your agency learn from this quarter / past pull's data? What seems to matter to your customers? Where might there be a pain point? - - - -

- <%= form.submit class: "usa-button width-full" %> -

-<% end %> - diff --git a/app/views/admin/collections/edit.html.erb b/app/views/admin/collections/edit.html.erb deleted file mode 100644 index 331b4a27d..000000000 --- a/app/views/admin/collections/edit.html.erb +++ /dev/null @@ -1,26 +0,0 @@ -<% content_for :navigation_title do %> - Editing Data Collection -<% end %> - -

- <%= link_to admin_collection_path(@collection) do %> - - Back to Data Collection - <% end %> -

- -<%= render 'form', collection: @collection %> - -
- -

- <%= link_to admin_collection_path(@collection), method: :delete, data: { confirm: 'Are you sure?' }, class: "usa-button usa-button--secondary" do %> - - Delete - <% end %> - - <%= link_to copy_admin_collection_path(@collection), method: :post, class: "usa-button usa-button--outline float-right", data: { confirm: 'Are you sure?' } do %> - - Copy this collection - <% end %> -

diff --git a/app/views/admin/collections/events.html.erb b/app/views/admin/collections/events.html.erb deleted file mode 100644 index c1eeeb9bd..000000000 --- a/app/views/admin/collections/events.html.erb +++ /dev/null @@ -1,46 +0,0 @@ -<% content_for :navigation_title do %> - Event Log for <%= @collection.name %> -<% end %> -

- <%= link_to admin_collection_path(@collection) do %> - - Back to Data Collection - <% end %> -

- - -
diff --git a/app/views/admin/collections/index.html.erb b/app/views/admin/collections/index.html.erb deleted file mode 100644 index 25e9ce4ef..000000000 --- a/app/views/admin/collections/index.html.erb +++ /dev/null @@ -1,150 +0,0 @@ -<% content_for :navigation_title do %> - Data Collections - <%= link_to new_admin_collection_path, class: "usa-button usa-button-inverted float-right" do %> - - New Data Collection - <% end %> -<% end %> - -
-
-

- Managing Data Collections in Touchpoints -

-
-

- Data Collections are a common user experience in federal government. - These Data Collections feature were created for - 1. staff who create Data Collections and - 2. staff who respond to Data Collections. - Requesting updates for specific data, by creating a Data Collection, should be easy. - Responding to Data Collections should also be easy. - The lifecycle of the data should be transparent and valuable as well. -

-

- Touchpoints currently facilitates 2 - Data Collections: -

-
    -
  • - OMB CX Data Collection (quarterly) -
  • -
  • - GSA Website Data Collection (annually) -
  • -
-
-
-
- -
-
-
-
- Filter by fiscal year and quarter - <%- if params[:year] || params[:quarter] %> - - <%= link_to "View All Collections", admin_collections_path %> - - <% end %> - -
-

- 2024 -

-
- <%= link_to "Q1", admin_collections_path(quarter: 1, year: 2024), class: "usa-button #{params[:quarter] == "1" && params[:year] == "2024" ? nil : 'usa-button--outline'}" %> -
-
- -
-

- 2023 -

-
- <%= link_to "Q1", admin_collections_path(quarter: 1, year: 2023), class: "usa-button #{params[:quarter] == "1" && params[:year] == "2023" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q2", admin_collections_path(quarter: 2, year: 2023), class: "usa-button #{params[:quarter] == "2" && params[:year] == "2023" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q3", admin_collections_path(quarter: 3, year: 2023), class: "usa-button #{params[:quarter] == "3" && params[:year] == "2023" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q4", admin_collections_path(quarter: 4, year: 2023), class: "usa-button #{params[:quarter] == "4" && params[:year] == "2023" ? nil : 'usa-button--outline'}" %> -
-
- -
-

- 2022 -

-
- <%= link_to "Q1", admin_collections_path(quarter: 1, year: 2022), class: "usa-button #{params[:quarter] == "1" && params[:year] == "2022" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q2", admin_collections_path(quarter: 2, year: 2022), class: "usa-button #{params[:quarter] == "2" && params[:year] == "2022" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q3", admin_collections_path(quarter: 3, year: 2022), class: "usa-button #{params[:quarter] == "3" && params[:year] == "2022" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q4", admin_collections_path(quarter: 4, year: 2022), class: "usa-button #{params[:quarter] == "4" && params[:year] == "2022" ? nil : 'usa-button--outline'}" %> -
-
- -
-

- 2021 -

-
- <%= link_to "Q1", admin_collections_path(quarter: 1, year: 2021), class: "usa-button #{params[:quarter] == "1" && params[:year] == "2021" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q2", admin_collections_path(quarter: 2, year: 2021), class: "usa-button #{params[:quarter] == "2" && params[:year] == "2021" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q3", admin_collections_path(quarter: 3, year: 2021), class: "usa-button #{params[:quarter] == "3" && params[:year] == "2021" ? nil : 'usa-button--outline'}" %> - <%= link_to "Q4", admin_collections_path(quarter: 4, year: 2021), class: "usa-button #{params[:quarter] == "4" && params[:year] == "2021" ? nil : 'usa-button--outline'}" %> -
-
- -
-
-
-
- - - - - - - - - - - - - - - - - <% @collections.each do |collection| %> - - - - - - - - - - - <% end %> - -
OrganizationService Provider (HISP)Collection nameDetail report countYearQuarterStatusRating
<%= render "admin/organizations/badge", organization: collection.organization %><%= collection.service_provider ? collection.service_provider.name : "SPECIFY THIS COLLECTION'S SERVICE PROVIDER" %><%= link_to collection.name, admin_collection_path(collection) %><%= collection.omb_cx_reporting_collections.size %><%= collection.year %><%= collection.quarter %> - <%= render 'components/collection_status_tag', collection: collection %> - - <%= collection_rating_label(rating: collection.rating) %> -
- -<%- if performance_manager_permissions? %> -

- <%= link_to "Download Collections as .csv", export_csv_admin_collections_path, class: "usa-button" %> -

-

- <%= link_to "Download OMB CX Data Reporting Collections as .csv", export_omb_cx_reporting_collections_csv_admin_collections_path, class: "usa-button" %> -

-<% end %> - -<%- if admin_permissions? %> - <%= render 'admin/collections/hisps_csv_details' %> - <%= render 'admin/components/performancegov/cx_summary_chart' %> -<% end %> diff --git a/app/views/admin/collections/new.html.erb b/app/views/admin/collections/new.html.erb deleted file mode 100644 index d26a8eadd..000000000 --- a/app/views/admin/collections/new.html.erb +++ /dev/null @@ -1,12 +0,0 @@ -<% content_for :navigation_title do %> - New Data Collection -<% end %> - -

- <%= link_to admin_collections_path do %> - - Back to Data Collections - <% end %> -

- -<%= render 'form', collection: @collection %> diff --git a/app/views/admin/collections/show.html.erb b/app/views/admin/collections/show.html.erb deleted file mode 100644 index 3ce7cdda0..000000000 --- a/app/views/admin/collections/show.html.erb +++ /dev/null @@ -1,203 +0,0 @@ -<%= javascript_include_tag "chartjs-2.9.3.bundle.js" %> -<%= javascript_include_tag "performance-charts.js" %> - -<% content_for :navigation_title do %> - Data Collection - <%- if @collection.draft? || performance_manager_permissions? %> - <%= link_to edit_admin_collection_path(@collection), class: "usa-button usa-button-inverted float-right" do %> - - Edit - <% end %> - <% end %> -<% end %> - -

- <%= link_to admin_collections_path do %> - - Back to Data Collections - <% end %> -

- -

- <%= @collection.name %> -

- -<%- if !@collection.submitted? && !@collection.published? %> -<% elsif !@collection.published? %> -<% else %> -
-
-

- This data collection has been published. -

-
-
-
-<% end %> - -

- About this data collection -

-
-
-

- CX Customer Experience reporting is described in - OMB Circular A-11, Section 280. -

-

- Each quarter, OMB coordinates this data collection from all HISPs. - This data will be summarized and reported on - performance.gov/cx. -

-
-
- -
-
-
- General information -
-
-
-

- <%= label_tag :organization, nil, class: "usa-label" %> - <%= link_to_if admin_permissions?, @collection.organization.name, admin_organization_path(@collection.organization) %> -

-

- <%= label_tag :service_provider, "Service Provider", class: "usa-label" %> - <%= link_to @collection.service_provider.name, admin_service_provider_path( @collection.service_provider) %> -

-

- <%= label_tag :user, nil, class: "usa-label" %> - <%= link_to_if performance_manager_permissions?, @collection.user.email, admin_user_path(@collection.user) %> -

-
-
-

- <%= label_tag :quarter_year, "Quarter and Fiscal year", class: "usa-label" %> - Q<%= @collection.quarter %> - FY<%= @collection.year %> -

- -

- <%= label_tag :date_range, "Date range", class: "usa-label" %> - <%= @collection.start_date %> - to -
- <%= @collection.end_date %> -

-
-
- -
-

- Services - - (<%= @collection.omb_cx_reporting_collections.size %>) - -

-
-
-

- Add a Service detail reporting page for each touchpoint available within a HISP service. -

-
-
-
    - <% @collection.omb_cx_reporting_collections.order(:service_provided, :channel).each do |cx_collection| %> -
  • - <%= link_to ("#{cx_collection.try(:service).try(:name)} - #{cx_collection.service_provided}"), admin_omb_cx_reporting_collection_path(cx_collection) %> -
  • - <% end %> -
- <%- if @collection.draft? %> -

- <%= link_to new_admin_omb_cx_reporting_collection_path(collection_id: @collection.id), class: "usa-button usa-button--outline" do %> - - Add a Service to report on - <% end %> -

- <% end %> - <%= render 'components/performance_charts', collection: @collection if @collection.omb_cx_reporting_collections.present? %> -
- -
- Reflection text -

- <%- if @collection.reflection? %> - <%= to_markdown(@collection.reflection) %> - <% else %> -

-
-

- <%= link_to 'Edit this Collection', edit_admin_collection_path(@collection) %> - to add Reflection Text prior to submitting. -

-
-
- <% end %> -

-
- - -
- -
-
-
- <%= render 'components/step_indicator', collection: @collection %> -

- <%= label_tag :collection_status, nil, class: "usa-label" %> -
- <%= render 'components/collection_status_tag', collection: @collection %> -

-

- <%= label_tag :rating, nil, class: "usa-label" %> -
- <%- if @collection.rating.present? %> - <%= collection_rating_label(rating: @collection.rating) %> - <% else %> -

-
-

- This Collection will receive a - rating - after - Submission. -

-
-
- <% end %> -

- -

- <%- if !@collection.submitted? && !@collection.published? %> -

-
-

- Submitting this Data Collection will send an email - to <%= ENV.fetch("TOUCHPOINTS_ADMIN_EMAILS").split(',').to_sentence %> - who will - 1. review the data, then - 2. contact you via email - prior to publishing data on performance.gov. -

-
-
-
- <%= link_to submit_admin_collection_path(@collection), class: "usa-button full-width", method: "post", data: { confirm: 'Are you sure?' } do %> - Submit this Data Collection - <% end %> - <% elsif !@collection.published? && performance_manager_permissions? %> - <%= link_to publish_admin_collection_path(@collection), class: "usa-button", method: "post" do %> - Publish this Data Collection - <% end %> - <% end %> -

-
-
diff --git a/app/views/admin/components/performancegov/_cx_summary_chart.html.erb b/app/views/admin/components/performancegov/_cx_summary_chart.html.erb deleted file mode 100644 index 78d924710..000000000 --- a/app/views/admin/components/performancegov/_cx_summary_chart.html.erb +++ /dev/null @@ -1,249 +0,0 @@ -<%= javascript_include_tag "chartjs-2.9.3.bundle.js" %> -<%= javascript_include_tag "performance-charts.js" %> - - - -
-
-
-

- Customer Feedback on Federal Service Performance -

-

- Q<%= @quarter %> FY<%= @year %> : - Jan 1 – - Mar 31, 2021 -
-

-
-
-
-
- - <% @collections = [] %> - - <% Service.hisp.each do |service| %> - <% collections = service.collections.where(quarter: @quarter) %> - <%- if collections.count > 0 %> - <% @collections += collections %> - <% end %> - <% end %> -
-
-
-
- - <%= @collections.size %> - of - <%= ServiceProvider.count %> - -
- - designated services collecting feedback - -
-
- - <%= @collections.collect(&:totals).map { |z| z[:volume_of_customers] }.sum %> -
-
- - service interactions with the American public - -
-
- - <%= @collections.collect(&:totals).map { |z| z[:volume_of_respondents] }.sum %> - - - total responses - -
-
-
-
-

- Responses by agency -

-
-   -
-
-
-

- Responses by channel -

-
-   -
-
-
-
-
-
- - diff --git a/app/views/admin/cx_collection_details/_form.html.erb b/app/views/admin/cx_collection_details/_form.html.erb index 72c3aaf30..7cd41dff1 100644 --- a/app/views/admin/cx_collection_details/_form.html.erb +++ b/app/views/admin/cx_collection_details/_form.html.erb @@ -16,7 +16,7 @@
<%= form.label :cx_collection_id, "CX Collection", class: "usa-label" %> <%= form.select :cx_collection_id, - cx_collections.map { |collection| ["#{collection.organization.abbreviation} - #{collection.organization.name} - #{collection.service.name}", collection.id]}, + cx_collections.map { |cx_collection| ["#{cx_collection.organization.abbreviation} - #{cx_collection.organization.name} - #{cx_collection.service.name}", cx_collection.id]}, { include_blank: true }, class: "usa-select" %>
diff --git a/app/views/admin/forms/_form_manager_options.html.erb b/app/views/admin/forms/_form_manager_options.html.erb index 4168e65ad..bb2f5e645 100644 --- a/app/views/admin/forms/_form_manager_options.html.erb +++ b/app/views/admin/forms/_form_manager_options.html.erb @@ -69,7 +69,7 @@
<%= f.label :time_zone, "Time zone", class: "usa-label" %> - <%= f.select :time_zone, options_for_select(us_timezones, selected: form.time_zone), { prompt: "Select a time zone" }, { class: "usa-select" } %> + <%= f.select :time_zone, options_for_select(US_TIMEZONES, selected: form.time_zone), { prompt: "Select a time zone" }, { class: "usa-select" } %>
diff --git a/app/views/admin/omb_cx_reporting_collections/_csv_data.html.erb b/app/views/admin/omb_cx_reporting_collections/_csv_data.html.erb deleted file mode 100644 index 9c15e08ab..000000000 --- a/app/views/admin/omb_cx_reporting_collections/_csv_data.html.erb +++ /dev/null @@ -1,50 +0,0 @@ -
-

- -

-
-

- cx-summary-data.csv -

-

- <%= render "components/reporting/cx_summary_data_detail_row", omb_cx_reporting_collection: @omb_cx_reporting_collection %> -

- -

- Service details -

- <% header_fields = [ - :service_provider_id, - :service_id, - :year, - :quarter, - :standardized_question_number, - :standardized_question_identifier, - :customized_question_text, - :likert_scale_1, - :likert_scale_2, - :likert_scale_3, - :likert_scale_4, - :likert_scale_5, - :point_scale, - :response_volume, - :notes, - :question_total, - :start_date, - :end_date - ] %> - <%= header_fields.join(",") %> -
- <%# WRITE A LINE FOR EACH OF THE 7 STANDARD QUESTIONS %> - <% (1..7).each do |question_number| %> - <%= render 'admin/collections/csv_detail_row', omb_cx_reporting_collection: omb_cx_reporting_collection, question_number: question_number %> -
- <% end %> -
-
-
diff --git a/app/views/admin/omb_cx_reporting_collections/_form.html.erb b/app/views/admin/omb_cx_reporting_collections/_form.html.erb deleted file mode 100644 index b97724522..000000000 --- a/app/views/admin/omb_cx_reporting_collections/_form.html.erb +++ /dev/null @@ -1,374 +0,0 @@ -<%= form_with(model: omb_cx_reporting_collection, url: (omb_cx_reporting_collection.persisted? ? admin_omb_cx_reporting_collection_path(omb_cx_reporting_collection) : admin_omb_cx_reporting_collections_path), local: true, data: { turbo: false }) do |form| %> -<%- if omb_cx_reporting_collection.errors.any? %> -
-

<%= pluralize(omb_cx_reporting_collection.errors.count, "error") %> prohibited this omb_cx_reporting_collection from being saved:

- - -
-<% end %> - -
-
- <%= form.label :collection_id, class: "usa-label" %> - <%= form.select :collection_id, options_for_select(@collections.map { |c| ["#{c.organization.abbreviation} - #{c.organization.name} - FY#{c.year}-Q#{c.quarter} #{c.name}", c.id]}, omb_cx_reporting_collection.collection_id), { include_blank: true }, class: "usa-select" %> -
-
- <%= form.label :service_id, class: "usa-label" %> -

- Services are available - <%= link_to "here", admin_services_path, target: "_blank", rel: "noopener" %>. -

- <%- if @collection %> - <%= form.select :service_id, @collection.organization.services.includes(:organization).order("organizations.name", :name).map { |h| ["#{h.organization.abbreviation} - #{h.organization.name} - #{h.name}", h.id] }, { prompt: "For which Service?" }, class: "usa-select" %> - <% else %> - <%= form.select :service_id, Service.all.includes(:organization).order("organizations.name", :name).map { |h| ["#{h.organization.abbreviation} - #{h.organization.name} - #{h.name}", h.id] }, { prompt: "For which Service?" }, class: "usa-select" %> - <% end %> -
-
- <%= form.label :service_provided, class: "usa-label" %> -

- Describe the service that is being measured. -

- <%= form.text_field :service_provided, class: "usa-input", placeholder: "Description of the service provided", required: true %> -
-
- <%= form.label :channel, class: "usa-label" %> - <%= form.select :channel, Service.channels, { prompt: "What type of response channel?" }, class: "usa-select" %> -
-
- <%= form.label :transaction_point, class: "usa-label" %> -

- Describe at what point in the user journey is the user prompted to complete the survey. -

- <%= form.text_field :transaction_point, class: "usa-input" %> -
-
- <%= form.label :volume_of_customers, class: "usa-label" %> - <%= form.number_field :volume_of_customers, class: "usa-input", placeholder: "# of customers (total volume)" %> -
-
- <%= form.label :volume_of_customers_provided_survey_opportunity, class: "usa-label" %> - <%= form.number_field :volume_of_customers_provided_survey_opportunity, class: "usa-input", placeholder: "# of customers shown this prompt" %> -
-
- <%= form.label :volume_of_respondents, class: "usa-label" %> - <%= form.number_field :volume_of_respondents, class: "usa-input", placeholder: "# of respondents" %> -
-
- <%= form.label :omb_control_number, class: "usa-label" %> - <%= form.text_field :omb_control_number, class: "usa-input", placeholder: "OMB Control #{}" %> -
-
- <%= form.label :federal_register_url, class: "usa-label" %> -

- Enter the reginfo.gov URL for the survey form. -

- <%= form.url_field :federal_register_url, class: "usa-input", placeholder: "https://www.reginfo.gov/..." %> -
-
- <%= form.label :operational_metrics, class: "usa-label" %> - <%= form.text_area :operational_metrics, class: "usa-textarea", placeholder: "Website use statistics, call center service levels, application processing times, etc." %> -
-
-
-

- Copy and paste the question text for at least questions 1-7. - And, enter the number of respondents for each of the likert scale options; 1-5. -

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - Question text - - 1 - - 2 - - 3 - - 4 - - 5 -
- Satisfaction - - <%= form.text_field :q1_text, class: "usa-input" %> - - <%= form.number_field :q1_1, class: "usa-input" %> - - <%= form.number_field :q1_2, class: "usa-input" %> - - <%= form.number_field :q1_3, class: "usa-input" %> - - <%= form.number_field :q1_4, class: "usa-input" %> - - <%= form.number_field :q1_5, class: "usa-input" %> -
- Trust or Confidence - - <%= form.text_field :q2_text, class: "usa-input" %> - - <%= form.number_field :q2_1, class: "usa-input" %> - - <%= form.number_field :q2_2, class: "usa-input" %> - - <%= form.number_field :q2_3, class: "usa-input" %> - - <%= form.number_field :q2_4, class: "usa-input" %> - - <%= form.number_field :q2_5, class: "usa-input" %> -
- Effectiveness (Service) - - <%= form.text_field :q3_text, class: "usa-input" %> - - <%= form.number_field :q3_1, class: "usa-input" %> - - <%= form.number_field :q3_2, class: "usa-input" %> - - <%= form.number_field :q3_3, class: "usa-input" %> - - <%= form.number_field :q3_4, class: "usa-input" %> - - <%= form.number_field :q3_5, class: "usa-input" %> -
- Ease (Process) - - <%= form.text_field :q4_text, class: "usa-input" %> - - <%= form.number_field :q4_1, class: "usa-input" %> - - <%= form.number_field :q4_2, class: "usa-input" %> - - <%= form.number_field :q4_3, class: "usa-input" %> - - <%= form.number_field :q4_4, class: "usa-input" %> - - <%= form.number_field :q4_5, class: "usa-input" %> -
- Efficiency (Process) - - <%= form.text_field :q5_text, class: "usa-input" %> - - <%= form.number_field :q5_1, class: "usa-input" %> - - <%= form.number_field :q5_2, class: "usa-input" %> - - <%= form.number_field :q5_3, class: "usa-input" %> - - <%= form.number_field :q5_4, class: "usa-input" %> - - <%= form.number_field :q5_5, class: "usa-input" %> -
- Transparency (Process) - - <%= form.text_field :q6_text, class: "usa-input" %> - - <%= form.number_field :q6_1, class: "usa-input" %> - - <%= form.number_field :q6_2, class: "usa-input" %> - - <%= form.number_field :q6_3, class: "usa-input" %> - - <%= form.number_field :q6_4, class: "usa-input" %> - - <%= form.number_field :q6_5, class: "usa-input" %> -
- Employee (People) - - <%= form.text_field :q7_text, class: "usa-input" %> - - <%= form.number_field :q7_1, class: "usa-input" %> - - <%= form.number_field :q7_2, class: "usa-input" %> - - <%= form.number_field :q7_3, class: "usa-input" %> - - <%= form.number_field :q7_4, class: "usa-input" %> - - <%= form.number_field :q7_5, class: "usa-input" %> -
- Question 8 - - <%= form.text_field :q8_text, class: "usa-input" %> - - <%= form.number_field :q8_1, class: "usa-input" %> - - <%= form.number_field :q8_2, class: "usa-input" %> - - <%= form.number_field :q8_3, class: "usa-input" %> - - <%= form.number_field :q8_4, class: "usa-input" %> - - <%= form.number_field :q8_5, class: "usa-input" %> -
- Question 9 - - <%= form.text_field :q9_text, class: "usa-input" %> - - <%= form.number_field :q9_1, class: "usa-input" %> - - <%= form.number_field :q9_2, class: "usa-input" %> - - <%= form.number_field :q9_3, class: "usa-input" %> - - <%= form.number_field :q9_4, class: "usa-input" %> - - <%= form.number_field :q9_5, class: "usa-input" %> -
- Question 10 - - <%= form.text_field :q10_text, class: "usa-input" %> - - <%= form.number_field :q10_1, class: "usa-input" %> - - <%= form.number_field :q10_2, class: "usa-input" %> - - <%= form.number_field :q10_3, class: "usa-input" %> - - <%= form.number_field :q10_4, class: "usa-input" %> - - <%= form.number_field :q10_5, class: "usa-input" %> -
- Question 11 - - <%= form.text_field :q11_text, class: "usa-input" %> - - <%= form.number_field :q11_1, class: "usa-input" %> - - <%= form.number_field :q11_2, class: "usa-input" %> - - <%= form.number_field :q11_3, class: "usa-input" %> - - <%= form.number_field :q11_4, class: "usa-input" %> - - <%= form.number_field :q11_5, class: "usa-input" %> -
- -

- <%= form.submit "Update CX Service Detail Report", class: "usa-button width-full" %> -

-<% end %> - diff --git a/app/views/admin/omb_cx_reporting_collections/edit.html.erb b/app/views/admin/omb_cx_reporting_collections/edit.html.erb deleted file mode 100644 index a21f17459..000000000 --- a/app/views/admin/omb_cx_reporting_collections/edit.html.erb +++ /dev/null @@ -1,22 +0,0 @@ -<% content_for :navigation_title do %> - Editing CX service reporting worksheet -<% end %> - -

- <%= link_to admin_omb_cx_reporting_collection_path(@omb_cx_reporting_collection) do %> - - Back to CX service reporting worksheet - <% end %> -

- -<%= render 'form', omb_cx_reporting_collection: @omb_cx_reporting_collection %> - -

- <%= link_to admin_omb_cx_reporting_collection_path(@omb_cx_reporting_collection), method: :delete, data: { confirm: 'Are you sure?' }, - class: "usa-button usa-button--secondary" do %> - - - Delete - - <% end %> -

diff --git a/app/views/admin/omb_cx_reporting_collections/index.html.erb b/app/views/admin/omb_cx_reporting_collections/index.html.erb deleted file mode 100644 index 3e053ea3a..000000000 --- a/app/views/admin/omb_cx_reporting_collections/index.html.erb +++ /dev/null @@ -1,42 +0,0 @@ -<% content_for :navigation_title do %> - Omb Cx Reporting Collections - - <%= link_to new_admin_omb_cx_reporting_collection_path, class: "usa-button usa-button-inverted float-right" do %> - - New Collection - <% end %> -<% end %> -

- <%= link_to admin_collections_path do %> - - Back to Data Collections - <% end %> -

- - - - - - - - - - - - <% @omb_cx_reporting_collections.each do |omb_cx_reporting_collection| %> - - - - - - <% end %> - -
CollectionServiceCX Reporting Collection name
- <%= omb_cx_reporting_collection.service.service_provider.name %> - - <%= omb_cx_reporting_collection.service.name %> - - <%= link_to omb_cx_reporting_collection.collection.name, admin_omb_cx_reporting_collection_path(omb_cx_reporting_collection) %> -
- -
diff --git a/app/views/admin/omb_cx_reporting_collections/new.html.erb b/app/views/admin/omb_cx_reporting_collections/new.html.erb deleted file mode 100644 index b8ac488f9..000000000 --- a/app/views/admin/omb_cx_reporting_collections/new.html.erb +++ /dev/null @@ -1,11 +0,0 @@ -<% content_for :navigation_title do %> - New Omb Cx Reporting Collection -<% end %> -

- <%= link_to admin_collections_path do %> - - Back to Data Collections - <% end %> -

- -<%= render 'form', omb_cx_reporting_collection: @omb_cx_reporting_collection %> diff --git a/app/views/admin/omb_cx_reporting_collections/show.html.erb b/app/views/admin/omb_cx_reporting_collections/show.html.erb deleted file mode 100644 index 22967c5ae..000000000 --- a/app/views/admin/omb_cx_reporting_collections/show.html.erb +++ /dev/null @@ -1,526 +0,0 @@ -<% content_for :navigation_title do %> - CX service reporting worksheet - - <%= link_to edit_admin_omb_cx_reporting_collection_path(@omb_cx_reporting_collection), class: "usa-button usa-button-inverted float-right" do %> - - Edit - <% end %> -<% end %> - -

- <%= link_to admin_collection_path(@omb_cx_reporting_collection.collection) do %> - - Back to - <%= @omb_cx_reporting_collection.collection.name %> - <% end %> -

- -
-
- General information -
-
-
-
-

-

- Collection -
- <%= link_to @omb_cx_reporting_collection.collection.name, admin_collection_path(@omb_cx_reporting_collection.collection) %> -
-

-

-

- - Organization - -
- <%= link_to @omb_cx_reporting_collection.collection.organization.name, admin_organization_path(@omb_cx_reporting_collection.collection.organization) %> -
-

-

-

- - Service Provider - -
- <%= link_to @omb_cx_reporting_collection.collection.service_provider.name, admin_service_provider_path(@omb_cx_reporting_collection.collection.service_provider) %> -
-

-

-

- - Service - -
- <%= link_to @omb_cx_reporting_collection.service.name, admin_service_path(@omb_cx_reporting_collection.service) %> -
-

-

-

- - Service provided - -
- <%= @omb_cx_reporting_collection.service_provided %> -
-

-
-
-

-

- - Transaction point - -
- <%= @omb_cx_reporting_collection.transaction_point %> -
-

-

-

- - Channel - -
- <%= @omb_cx_reporting_collection.channel %> -
-

-

-

- - OMB Control Number - -
- <%= @omb_cx_reporting_collection.omb_control_number %> -
-

-

-

- - Federal Register URL - -
- <%= @omb_cx_reporting_collection.federal_register_url %> -
-

-
-
-

-

- - Volume of customers - -
- <%= @omb_cx_reporting_collection.volume_of_customers %> -
-

-

-

- - Customers provided a feedback opportunity - -
- <%= @omb_cx_reporting_collection.volume_of_customers_provided_survey_opportunity %> -
-

-

-

- - Volume of respondents - -
- <%= @omb_cx_reporting_collection.volume_of_respondents %> -
-

-
-
-
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - Question text - - 1 - - 2 - - 3 - - 4 - - 5 - - Total - - 5-point scale -
- Satisfaction - - <%= @omb_cx_reporting_collection.q1_text %> - - <%= @omb_cx_reporting_collection.q1_1 %> - - <%= @omb_cx_reporting_collection.q1_2 %> - - <%= @omb_cx_reporting_collection.q1_3 %> - - <%= @omb_cx_reporting_collection.q1_4 %> - - <%= @omb_cx_reporting_collection.q1_5 %> - - <%= @omb_cx_reporting_collection.q1_total %> - - <%= @omb_cx_reporting_collection.q1_point_scale %> -
- Trust or Confidence - - <%= @omb_cx_reporting_collection.q2_text %> - - <%= @omb_cx_reporting_collection.q2_1 %> - - <%= @omb_cx_reporting_collection.q2_2 %> - - <%= @omb_cx_reporting_collection.q2_3 %> - - <%= @omb_cx_reporting_collection.q2_4 %> - - <%= @omb_cx_reporting_collection.q2_5 %> - - <%= @omb_cx_reporting_collection.q2_total %> - - <%= @omb_cx_reporting_collection.q2_point_scale %> -
- Effectiveness (Service) - - <%= @omb_cx_reporting_collection.q3_text %> - - <%= @omb_cx_reporting_collection.q3_1 %> - - <%= @omb_cx_reporting_collection.q3_2 %> - - <%= @omb_cx_reporting_collection.q3_3 %> - - <%= @omb_cx_reporting_collection.q3_4 %> - - <%= @omb_cx_reporting_collection.q3_5 %> - - <%= @omb_cx_reporting_collection.q3_total %> - - <%= @omb_cx_reporting_collection.q3_point_scale %> -
- Ease (Process) - - <%= @omb_cx_reporting_collection.q4_text %> - - <%= @omb_cx_reporting_collection.q4_1 %> - - <%= @omb_cx_reporting_collection.q4_2 %> - - <%= @omb_cx_reporting_collection.q4_3 %> - - <%= @omb_cx_reporting_collection.q4_4 %> - - <%= @omb_cx_reporting_collection.q4_5 %> - - <%= @omb_cx_reporting_collection.q4_total %> - - <%= @omb_cx_reporting_collection.q4_point_scale %> -
- Efficiency (Process) - - <%= @omb_cx_reporting_collection.q5_text %> - - <%= @omb_cx_reporting_collection.q5_1 %> - - <%= @omb_cx_reporting_collection.q5_2 %> - - <%= @omb_cx_reporting_collection.q5_3 %> - - <%= @omb_cx_reporting_collection.q5_4 %> - - <%= @omb_cx_reporting_collection.q5_5 %> - - <%= @omb_cx_reporting_collection.q5_total %> - - <%= @omb_cx_reporting_collection.q5_point_scale %> -
- Transparency (Process) - - <%= @omb_cx_reporting_collection.q6_text %> - - <%= @omb_cx_reporting_collection.q6_1 %> - - <%= @omb_cx_reporting_collection.q6_2 %> - - <%= @omb_cx_reporting_collection.q6_3 %> - - <%= @omb_cx_reporting_collection.q6_4 %> - - <%= @omb_cx_reporting_collection.q6_5 %> - - <%= @omb_cx_reporting_collection.q6_total %> - - <%= @omb_cx_reporting_collection.q6_point_scale %> -
- Employee (People) - - <%= @omb_cx_reporting_collection.q7_text %> - - <%= @omb_cx_reporting_collection.q7_1 %> - - <%= @omb_cx_reporting_collection.q7_2 %> - - <%= @omb_cx_reporting_collection.q7_3 %> - - <%= @omb_cx_reporting_collection.q7_4 %> - - <%= @omb_cx_reporting_collection.q7_5 %> - - <%= @omb_cx_reporting_collection.q7_total %> - - <%= @omb_cx_reporting_collection.q7_point_scale %> -
- Question 8 - - <%= @omb_cx_reporting_collection.q8_text %> - - <%= @omb_cx_reporting_collection.q8_1 %> - - <%= @omb_cx_reporting_collection.q8_2 %> - - <%= @omb_cx_reporting_collection.q8_3 %> - - <%= @omb_cx_reporting_collection.q8_4 %> - - <%= @omb_cx_reporting_collection.q8_5 %> - - <%= @omb_cx_reporting_collection.q8_total %> - - <%= @omb_cx_reporting_collection.q8_point_scale %> -
- Question 9 - - <%= @omb_cx_reporting_collection.q9_text %> - - <%= @omb_cx_reporting_collection.q9_1 %> - - <%= @omb_cx_reporting_collection.q9_2 %> - - <%= @omb_cx_reporting_collection.q9_3 %> - - <%= @omb_cx_reporting_collection.q9_4 %> - - <%= @omb_cx_reporting_collection.q9_5 %> - - <%= @omb_cx_reporting_collection.q9_total %> - - <%= @omb_cx_reporting_collection.q9_point_scale %> -
- Question 10 - - <%= @omb_cx_reporting_collection.q10_text %> - - <%= @omb_cx_reporting_collection.q10_1 %> - - <%= @omb_cx_reporting_collection.q10_2 %> - - <%= @omb_cx_reporting_collection.q10_3 %> - - <%= @omb_cx_reporting_collection.q10_4 %> - - <%= @omb_cx_reporting_collection.q10_5 %> - - <%= @omb_cx_reporting_collection.q10_total %> - - <%= @omb_cx_reporting_collection.q10_point_scale %> -
- Question 11 - - <%= @omb_cx_reporting_collection.q11_text %> - - <%= @omb_cx_reporting_collection.q11_1 %> - - <%= @omb_cx_reporting_collection.q11_2 %> - - <%= @omb_cx_reporting_collection.q11_3 %> - - <%= @omb_cx_reporting_collection.q11_4 %> - - <%= @omb_cx_reporting_collection.q11_5 %> - - <%= @omb_cx_reporting_collection.q11_total %> - - <%= @omb_cx_reporting_collection.q11_point_scale %> -
- Totals - - - - - - - - <%= @omb_cx_reporting_collection.volume_total %> - -
- -

- - Operational metrics - -
- <%= @omb_cx_reporting_collection.operational_metrics %> -

- -<%= render('admin/omb_cx_reporting_collections/csv_data', omb_cx_reporting_collection: @omb_cx_reporting_collection) if admin_permissions? %> diff --git a/app/views/admin/organizations/_results.html.erb b/app/views/admin/organizations/_results.html.erb index f92a986de..c9a035bfd 100644 --- a/app/views/admin/organizations/_results.html.erb +++ b/app/views/admin/organizations/_results.html.erb @@ -8,7 +8,7 @@ Forms Services Websites - Collections + CX Collections Tags @@ -35,7 +35,7 @@ <%= organization.websites.count %> - <%= organization.collections.count %> + <%= organization.cx_collections.count %> <%= organization.tag_list %> diff --git a/app/views/admin/organizations/show.html.erb b/app/views/admin/organizations/show.html.erb index de9513f6b..74f62b698 100644 --- a/app/views/admin/organizations/show.html.erb +++ b/app/views/admin/organizations/show.html.erb @@ -29,13 +29,15 @@
<%- if @organization.logo_url.present? %>
- <%= image_tag(@organization.logo.thumb.url) %> + <%= image_tag(@organization.logo.logo_square.url) %>
- <%= link_to "Thumbnail Size", @organization.logo.thumb.url, target: "_blank", rel: "noopener" %> + <%= link_to "Square size", @organization.logo.logo_square.url, target: "_blank", rel: "noopener" %> · - <%= link_to "Full Size", @organization.logo.url, target: "_blank", rel: "noopener" %> + <%= link_to "Thumbnail size", @organization.logo.thumb.url, target: "_blank", rel: "noopener" %> · - <%= link_to "Card Size", @organization.logo.card.url, target: "_blank", rel: "noopener" %> + <%= link_to "Full size", @organization.logo.url, target: "_blank", rel: "noopener" %> + · + <%= link_to "Tag size", @organization.logo.tag.url, target: "_blank", rel: "noopener" %> <% else %> <% end %> @@ -104,9 +106,9 @@
-

+

<%= pluralize(@organization.children.size, "Sub-agency") %> -

+ <%- if @organization.children.present? %>
<% end %> -

-

-

+

<%= pluralize(@users.size, "User") %> -

+ <%- if @users.present? %>