class OrganisationsController < ApplicationController include Pagy::Backend include Modules::CaseLogsFilter include Modules::SearchFilter before_action :authenticate_user!, except: [:index] before_action :find_resource, except: [:index] before_action :authenticate_scope! def index redirect_to organisation_path(current_user.organisation) unless current_user.support? all_organisations = Organisation.all @pagy, @organisations = pagy(filtered_collection(all_organisations, search_term)) @searched = search_term.presence @total_count = all_organisations.size end def show redirect_to details_organisation_path(@organisation) end def users @pagy, @users = pagy(filtered_users(@organisation.users, search_term)) @searched = search_term.presence @total_count = @organisation.users.size render "users/index" end def details render "show" end def edit if current_user.data_coordinator? || current_user.support? render "edit", layout: "application" else head :unauthorized end end def update if current_user.data_coordinator? || current_user.support? if @organisation.update(org_params) flash[:notice] = I18n.t("organisation.updated") redirect_to details_organisation_path(@organisation) end else head :unauthorized end end def logs if current_user.support? set_session_filters(specific_org: true) organisation_logs = CaseLog.all.where(owning_organisation_id: @organisation.id) @pagy, @case_logs = pagy(filtered_case_logs(organisation_logs)) render "logs", layout: "application" else redirect_to(case_logs_path) end end private def org_params params.require(:organisation).permit(:name, :address_line1, :address_line2, :postcode, :phone) end def search_term params["search"] end def authenticate_scope! render_not_found if current_user.organisation != @organisation && !current_user.support? end def find_resource @organisation = Organisation.find(params[:id]) end end