Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .github/workflows/build-widget.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ on:

jobs:
build-widget:
permissions:
contents: read
runs-on: ubuntu-22.04
steps:
- name: Checkout
Expand Down
3 changes: 2 additions & 1 deletion Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -356,7 +356,8 @@ GEM
timeout
net-smtp (0.5.1)
net-protocol
newrelic_rpm (9.21.0)
newrelic_rpm (10.2.0)
logger
nio4r (2.7.4)
nokogiri (1.19.1-aarch64-linux-gnu)
racc (~> 1.4)
Expand Down
8 changes: 5 additions & 3 deletions app/controllers/admin/site_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ def index
@response_groups = Submission.group('date(created_at)').count.sort.last(@days_since.days)
@user_groups = User.group('date(created_at)').count.sort.last(@days_since.days)
@inactive_user_groups = User.where(inactive: true).group('date(updated_at)').count.sort.last(@days_since.days)
todays_submissions = Submission.where('created_at > ?', Time.zone.now - @days_since.days)

# Add in 0 count days to fetched analytics
@dates.each do |date|
Expand All @@ -24,8 +23,11 @@ def index
@inactive_user_groups = @inactive_user_groups.sort
@response_groups = @response_groups.sort

form_ids = todays_submissions.collect(&:form_id).uniq
@recent_forms = Form.includes(:organization).find(form_ids)
@recent_forms = Form.includes(:organization)
.joins(:submissions)
.where("submissions.created_at > ?", Time.zone.now - @days_since.days)
.select("forms.*", "count(distinct submissions.id) as recent_submissions_count")
.group("forms.id")
end

def a11_v2_collections; end
Expand Down
21 changes: 13 additions & 8 deletions app/controllers/admin/submissions_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -186,25 +186,30 @@ def unmark
def delete
ensure_form_manager(form: @form)

Event.log_event(Event.names[:response_deleted], 'Submission', @submission.id, "Submission #{@submission.id} undeleted at #{DateTime.now}", current_user.id)
@submission.update(deleted: true, deleted_at: Time.now)
if @submission.update(deleted: true, deleted_at: Time.now)
Event.log_event(Event.names[:response_deleted], 'Submission', @submission.id, "Submission #{@submission.id} deleted at #{DateTime.now}", current_user.id)
else
Rails.logger.warn("Failed to delete submission: #{@submission.errors.full_messages.join(', ')}")
end
end

def destroy
ensure_form_manager(form: @form)

Event.log_event(Event.names[:response_deleted], 'Submission', @submission.id, "Submission #{@submission.id} undeleted at #{DateTime.now}", current_user.id)
@submission.update(deleted: true, deleted_at: Time.now)

respond_to do |format|
format.js { render :destroy }
if @submission.update(deleted: true, deleted_at: Time.now)
Event.log_event(Event.names[:response_deleted], 'Submission', @submission.id, "Submission #{@submission.id} deleted at #{DateTime.now}", current_user.id)
respond_to do |format|
format.js { render :destroy }
end
else
Rails.logger.warn("Failed to delete submission: #{@submission.errors.full_messages.join(', ')}")
end
end

def undelete
ensure_form_manager(form: @form)

Event.log_event(Event.names[:response_undeleted], 'Submission', @submission.id, "Submission #{@submission.id} deleted at #{DateTime.now}", current_user.id)
Event.log_event(Event.names[:response_undeleted], 'Submission', @submission.id, "Submission #{@submission.id} undeleted at #{DateTime.now}", current_user.id)
@submission.update(deleted: false, deleted_at: nil)
end

Expand Down
2 changes: 1 addition & 1 deletion app/views/components/admin/_recent_responses.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
<td>
<%= link_to form.name, admin_form_path(form) %>
</td>
<td data-sort-value="<%= c = form.submissions.where("created_at > ?", Time.now - days_since.days).count %>">
<td data-sort-value="<%= c = form.recent_submissions_count %>">
<%= number_with_delimiter(c) %>
</td>
</tr>
Expand Down
1 change: 1 addition & 0 deletions config/newrelic.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ common: &default_settings

# Logging level for log/newrelic_agent.log
log_level: info
log_file_path: STDOUT

# Environment-specific settings are in this section.
# RAILS_ENV or RACK_ENV (as appropriate) is used to determine the environment.
Expand Down
6 changes: 3 additions & 3 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

30 changes: 30 additions & 0 deletions spec/features/admin/dashboard_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,36 @@
end
end
end

describe 'recent responses' do
let(:recent_form) { FactoryBot.create(:form, :open_ended_form, organization:) }
let(:older_form) { FactoryBot.create(:form, :recruiter, organization:) }
let!(:recent_form_responses) {
FactoryBot.create_list(:submission, 5, form: recent_form, created_at: 5.days.ago) do |submission, i|
submission.update(created_at: 1.days.ago) if i < 2
end
}
let!(:older_form_responses) {
FactoryBot.create_list(:submission, 3, form: older_form, created_at: 5.days.ago)
}

before do
visit admin_dashboard_path
end

it 'contains a "Data collected over past 3 days" table' do
expect(page).to have_content('Data collected over past 3 days')
table = page.find('#recent-responses table')
expect(table).to be_present

# 1 form with recent responses, 2 recent responses
rows = table.all('tbody tr')
expect(rows.count).to eq(1)
first_row_cells = rows.first.all('td')
expect(first_row_cells[1].text).to eq('Open-ended Test form')
expect(first_row_cells[2].text).to eq('2')
end
end
end

# Note:
Expand Down
Loading