class Admin::LabsController < OrbitMemberController layout "member_plugin" before_action :set_plugin before_action :get_settings,:only => [:new, :edit, :setting] before_action :need_access_right before_action :allow_admin_only, :only => [:index, :setting] def index @labs = Lab.order_by(:year=>'desc').page(params[:page]).per(10) end def new @member = MemberProfile.find_by(:uid=>params['uid']) rescue nil @lab = Lab.new end def create @member = MemberProfile.find(lab_params['member_profile_id']) rescue nil @lab = Lab.new(lab_params) @lab.save redirect_to params['referer_url'] end def edit @member = MemberProfile.find_by(:uid=>params['uid']) rescue nil @lab = Lab.find(params[:id]) end def update @member = MemberProfile.find(lab_params['member_profile_id']) rescue nil @lab = Lab.find(params[:id]) @lab.update_attributes(lab_params) @lab.save redirect_to params['referer_url'] end def destroy @lab = Lab.find(params[:id]) @lab.destroy end def toggle_hide if params[:ids] @labs = Lab.any_in(_id: params[:ids]) @labs.each do |lab| lab.is_hidden = params[:disable] lab.save end end render json: {"success"=>true} end def setting end def frontend_setting @member = MemberProfile.find_by(:uid=>params['uid']) rescue nil @intro = LabIntro.find_by(:member_profile_id=>@member.id) rescue nil @intro = @intro.nil? ? LabIntro.new({:member_profile_id=>@member.id}) : @intro end def update_frontend_setting @member = MemberProfile.find(intro_params['member_profile_id']) rescue nil @intro = LabIntro.find_by(:member_profile_id=>@member.id) rescue nil @intro = @intro.nil? ? LabIntro.new({:member_profile_id=>@member.id}) : @intro @intro.update_attributes(intro_params) @intro.save redirect_to URI.encode('/admin/members/'+@member.to_param+'/Lab') end def get_settings end def set_plugin @plugin = OrbitApp::Plugin::Registration.all.select{|plugin| plugin.app_name.eql? 'Lab'}.first end private def lab_params params.require(:lab).permit! rescue nil end def intro_params params.require(:lab_intro).permit! rescue nil end end