Orbit::Application.routes.draw do

  mount Ckeditor::Engine => '/ckeditor'

  resources :sessions

  get "logout", to: "sessions#destroy", as: "logout"


  get "/pages/edit_view" => "pages#edit_view"
  get "/pages/preview" => "pages#preview"
  get "/pages/get_categories" => "pages#get_categories"
  post "/pages/update_item_position" => "pages#update_item_position"

  get "/page_parts/getwidgets" => "page_parts#getwidgets"
  get "/page_parts/info" => "page_parts#info"


  resources :pages
  resources :page_parts
 
  get "/module/:name" => "home#index"
  get "/module/:name/show" => "home#show"
  # The priority is based upon order of creation: first created -> highest priority.
  # See how all your routes lay out with "rake routes".

  # You can have the root of your site routed with "root"
  root 'pages#home'
  get 'admin/authorizations/modal_select/:module(/:type(/:id))' => 'admin/authorizations#modal_select', :as => :modal_select_authorizations
  match 'admin/authorizations/add_users/:module(/:type(/:id))' => 'admin/authorizations#add_users', :as => :add_users_authorizations, via: [:get, :post]
  match 'admin/authorizations/add_roles/:module(/:type(/:id))' => 'admin/authorizations#add_roles', :as => :add_roles_authorizations, via: [:get, :post]
  match 'admin/authorizations/remove_users/:module(/:type(/:id))' => 'admin/authorizations#remove_users', :as => :remove_users_authorizations, via: [:delete]

  locales = Site.first.in_use_locales rescue I18n.available_locales

  scope "(:locale)", locale: Regexp.new(locales.join("|")) do
    resources :users do
      collection do
        get 'confirm_user'
        get 'post_confirmation'
      end
    end

    resources :passwords

    namespace :admin do
      resources :dashboards
      resources :members
      resources :roles do
        get 'role_field'
        post 'toggle'
      end
      
      resources :module_apps do
        resources :categories do
          collection do
            post 'create_in_form'
          end
          member do
            post 'toggle'
          end
        end
        resources :tags do
          collection do
            post 'add_to_default'
            post 'add_from_default'
            post 'create_in_form'
            post 'delete_tags'
            post 'merge'
            post 'remove_default'
            post 'update_included_default'
          end
        end
      end

      get 'authorizations(/:module(/:type(/:id)))' => 'authorizations#index', :as => :authorizations
      
      resources :authorizations
      resources :items
      resources :categories do
        member do
          post 'toggle'
        end
      end
      resources :tags do
        collection do
          post 'add_to_default'
          post 'add_from_default'
          post 'delete_tags'
          post 'merge'
          post 'remove_default'
          post 'update_included_default'
        end
      end

        resources :sites do
	       get 'mail_setting'
	       get 'site_info'
	       get 'responsive_setting'
	       get 'search_engine'
	       get 'sitemap'
	       get 'sitemap_frontend'
	       get 'sitemap_toggle', :on => :member
	       get 'system_info'
	       get 'ui_theme'
	       get 'change_design'
	       get 'reset_default_locale'
	       get 'preference'
	       get 'update_manager'
	       get 'get_update_history'
	       get 'check_updates'
	       get 'update_orbit'
	       get 'restart_server'
	     end

     

      resources :designs
      get 'module_store' => 'module_store#index'
    end
    get ':page(/:page)(/:page)(/:page)', to: 'pages#show', constraints: KeywordConstraint.new
    resources :pages
  end
  # Example of regular route:
  #   get 'products/:id' => 'catalog#view'

  # Example of named route that can be invoked with purchase_url(id: product.id)
  #   get 'products/:id/purchase' => 'catalog#purchase', as: :purchase

  # Example resource route (maps HTTP verbs to controller actions automatically):
  #   resources :products

  # Example resource route with options:
  #   resources :products do
  #     member do
  #       get 'short'
  #       post 'toggle'
  #     end
  #
  #     collection do
  #       get 'sold'
  #     end
  #   end

  # Example resource route with sub-resources:
  #   resources :products do
  #     resources :comments, :sales
  #     resource :seller
  #   end

  # Example resource route with more complex sub-resources:
  #   resources :products do
  #     resources :comments
  #     resources :sales do
  #       get 'recent', on: :collection
  #     end
  #   end

  # Example resource route with concerns:
  #   concern :toggleable do
  #     post 'toggle'
  #   end
  #   resources :posts, concerns: :toggleable
  #   resources :photos, concerns: :toggleable

  # Example resource route within a namespace:
    namespace :admin do
      # Directs /admin/products/* to Admin::ProductsController
      # (app/controllers/admin/products_controller.rb)
      resources :users
    end
end