require_dependency "phcmembers/application_controller" module Phcmembers class Member::ProfilesController < ApplicationController # Security & Action Filters before_action :authenticate_user! before_action :set_paper_trail_whodunnit before_action :set_member_profile, only: [:show, :edit, :update, :destroy] # INDEX - Member Profile def index @member_profiles = Member::Profile.all end # DETAILED PROFILE - Member Profile def show @member_profile = Member::Profile.find(params[:id]) @member_profile_versions = Phcmembers::ProfileVersions.where(item_id: @member_profile, item_type: 'Phcmembers::Member::Profile') end # NEW FORM - Member Profile def new @member_profile = Member::Profile.new end # EDIT FORM - Member Profile def edit end # POST - Member Profile def create @member_profile = Member::Profile.new(member_profile_params) @member_profile.user_name = current_user.username if @member_profile.save redirect_to member_profiles_url, notice: 'Profile was successfully created.' else render :new end end # PATCH/PUT - Member Profile def update @member_profile.user_name = current_user.username if @member_profile.update(member_profile_params) redirect_to member_profiles_url, notice: 'Profile was successfully updated.' else render :edit end end # DELETE - Member Profile def destroy @member_profile.destroy redirect_to member_profiles_url, notice: 'Profile was successfully destroyed.' end private # Common Callbacks def set_member_profile @member_profile = Member::Profile.find(params[:id]) end # Whitelist def member_profile_params params.require(:member_profile).permit(:mfirstname, :mlastname, :mtitle, :memail, :mphone, :mnotes, :slug, :user_id, :user_name) end end end