|
|
|
class OrganisationsController < ApplicationController
|
|
|
|
include Pagy::Backend
|
|
|
|
include Modules::LogsFilter
|
|
|
|
include Modules::SearchFilter
|
|
|
|
|
|
|
|
before_action :authenticate_user!
|
|
|
|
before_action :find_resource, except: %i[index new create]
|
|
|
|
before_action :authenticate_scope!, except: [:index]
|
|
|
|
before_action -> { session_filters(specific_org: true) }, if: -> { current_user.support? }
|
|
|
|
before_action :set_session_filters, if: -> { current_user.support? }
|
|
|
|
|
|
|
|
def index
|
|
|
|
redirect_to organisation_path(current_user.organisation) unless current_user.support?
|
|
|
|
|
|
|
|
all_organisations = Organisation.order(:name)
|
|
|
|
@pagy, @organisations = pagy(filtered_collection(all_organisations, search_term))
|
|
|
|
@searched = search_term.presence
|
|
|
|
@total_count = all_organisations.size
|
|
|
|
end
|
|
|
|
|
|
|
|
def schemes
|
|
|
|
all_schemes = Scheme.where(owning_organisation: @organisation).order_by_completion.order_by_service_name
|
|
|
|
|
|
|
|
@pagy, @schemes = pagy(filtered_collection(all_schemes, search_term))
|
|
|
|
@searched = search_term.presence
|
|
|
|
@total_count = all_schemes.size
|
|
|
|
end
|
|
|
|
|
|
|
|
def show
|
|
|
|
redirect_to details_organisation_path(@organisation)
|
|
|
|
end
|
|
|
|
|
|
|
|
def users
|
|
|
|
organisation_users = @organisation.users.sorted_by_organisation_and_role
|
|
|
|
unpaginated_filtered_users = filtered_collection(organisation_users, search_term)
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html do
|
|
|
|
@pagy, @users = pagy(unpaginated_filtered_users)
|
|
|
|
@searched = search_term.presence
|
|
|
|
@total_count = @organisation.users.size
|
|
|
|
|
|
|
|
if current_user.support?
|
|
|
|
render "users", layout: "application"
|
|
|
|
else
|
|
|
|
render "users/index"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
format.csv do
|
|
|
|
send_data byte_order_mark + unpaginated_filtered_users.to_csv, filename: "users-#{@organisation.name}-#{Time.zone.now}.csv"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def details
|
|
|
|
render "show"
|
|
|
|
end
|
|
|
|
|
|
|
|
def new
|
|
|
|
@resource = Organisation.new
|
|
|
|
render "new", layout: "application"
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
@resource = Organisation.new(org_params)
|
|
|
|
if @resource.save
|
|
|
|
redirect_to organisations_path
|
|
|
|
else
|
|
|
|
render :new, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
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 lettings_logs
|
|
|
|
organisation_logs = LettingsLog.where(owning_organisation_id: @organisation.id)
|
|
|
|
unpaginated_filtered_logs = filtered_logs(organisation_logs, search_term, @session_filters)
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html do
|
|
|
|
@search_term = search_term
|
|
|
|
@pagy, @logs = pagy(unpaginated_filtered_logs)
|
|
|
|
@searched = search_term.presence
|
|
|
|
@total_count = organisation_logs.size
|
|
|
|
render "logs", layout: "application"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def download_csv
|
|
|
|
organisation_logs = LettingsLog.all.where(owning_organisation_id: @organisation.id)
|
|
|
|
unpaginated_filtered_logs = filtered_logs(organisation_logs, search_term, @session_filters)
|
|
|
|
|
|
|
|
render "logs/download_csv", locals: { search_term:, count: unpaginated_filtered_logs.size, post_path: logs_email_csv_organisation_path }
|
|
|
|
end
|
|
|
|
|
|
|
|
def email_csv
|
|
|
|
EmailCsvJob.perform_later(current_user, search_term, @session_filters, false, @organisation)
|
|
|
|
redirect_to logs_csv_confirmation_organisation_path
|
|
|
|
end
|
|
|
|
|
|
|
|
def sales_logs
|
|
|
|
organisation_logs = SalesLog.where(owning_organisation_id: @organisation.id)
|
|
|
|
unpaginated_filtered_logs = filtered_logs(organisation_logs, search_term, @session_filters)
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html do
|
|
|
|
@search_term = search_term
|
|
|
|
@pagy, @logs = pagy(unpaginated_filtered_logs)
|
|
|
|
@searched = search_term.presence
|
|
|
|
@total_count = organisation_logs.size
|
|
|
|
render "logs", layout: "application"
|
|
|
|
end
|
|
|
|
|
|
|
|
format.csv do
|
|
|
|
send_data byte_order_mark + unpaginated_filtered_logs.to_csv, filename: "sales-logs-#{@organisation.name}-#{Time.zone.now}.csv"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def org_params
|
|
|
|
params.require(:organisation).permit(:name, :address_line1, :address_line2, :postcode, :phone, :holds_own_stock, :provider_type, :housing_registration_no)
|
|
|
|
end
|
|
|
|
|
|
|
|
def search_term
|
|
|
|
params["search"]
|
|
|
|
end
|
|
|
|
|
|
|
|
def authenticate_scope!
|
|
|
|
if %w[create new lettings_logs download_csv email_csv].include? action_name
|
|
|
|
head :unauthorized and return unless current_user.support?
|
|
|
|
elsif current_user.organisation != @organisation && !current_user.support?
|
|
|
|
render_not_found
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def find_resource
|
|
|
|
@organisation = Organisation.find(params[:id])
|
|
|
|
end
|
|
|
|
end
|