diff options
author | Stefan Wintermeyer <stefan.wintermeyer@amooma.de> | 2013-01-22 15:33:06 +0100 |
---|---|---|
committer | Stefan Wintermeyer <stefan.wintermeyer@amooma.de> | 2013-01-22 15:33:06 +0100 |
commit | 39aa7132ceed3d4beab3a9b828e571bbfc67c07e (patch) | |
tree | 6c88289c9f99be0af8635636fcdf64102090e5ec /app/controllers/call_routes_controller.rb | |
parent | 5ad8203ce4f1bfea997960d0b52c626dea24b944 (diff) | |
parent | 6f69c1a85055ec7c2515719d79d2a7a4e60cec50 (diff) |
Merge branch 'develop'5.1-beta1
Diffstat (limited to 'app/controllers/call_routes_controller.rb')
-rw-r--r-- | app/controllers/call_routes_controller.rb | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/app/controllers/call_routes_controller.rb b/app/controllers/call_routes_controller.rb new file mode 100644 index 0000000..0259a10 --- /dev/null +++ b/app/controllers/call_routes_controller.rb @@ -0,0 +1,75 @@ +class CallRoutesController < ApplicationController + authorize_resource :call_route + + def index + @call_routes = CallRoute.order([:routing_table, :position]) + @routing_tables = @call_routes.pluck(:routing_table).uniq.sort + spread_breadcrumbs + end + + def show + @call_route = CallRoute.find(params[:id]) + spread_breadcrumbs + end + + def new + @call_route = CallRoute.new + spread_breadcrumbs + end + + def create + @call_route = CallRoute.new(call_route_parameter_params) + spread_breadcrumbs + if @call_route.save + redirect_to @call_route, :notice => t('call_routes.controller.successfuly_created') + else + render :new + end + end + + def edit + @call_route = CallRoute.find(params[:id]) + spread_breadcrumbs + end + + def update + @call_route = CallRoute.find(params[:id]) + spread_breadcrumbs + if @call_route.update_attributes(call_route_parameter_params) + redirect_to @call_route, :notice => t('call_routes.controller.successfuly_updated') + else + render :edit + end + end + + def destroy + @call_route = CallRoute.find(params[:id]) + @call_route.destroy + redirect_to call_routes_url, :notice => t('call_routes.controller.successfuly_destroyed') + end + + def move_higher + @call_route = CallRoute.find(params[:id]) + @call_route.move_higher + redirect_to :back + end + + def move_lower + @call_route = CallRoute.find(params[:id]) + @call_route.move_lower + redirect_to :back + end + + private + def call_route_parameter_params + params.require(:call_route).permit(:routing_table, :name, :endpoint_type, :endpoint_id) + end + + def spread_breadcrumbs + add_breadcrumb t("call_routes.index.page_title"), call_routes_path + if @call_route && !@call_route.new_record? + add_breadcrumb @call_route, @call_route + end + end + +end |