diff rhodecode/controllers/home.py @ 636:ffd07396d315 beta

Fixes for raw_id, needed for git Renamed hg controller to home css html changes
author Marcin Kuzminski <marcin@python-works.com>
date Tue, 26 Oct 2010 03:20:32 +0200
parents rhodecode/controllers/hg.py@7e536d1af60d
children 7486da5f0628
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/rhodecode/controllers/home.py	Tue Oct 26 03:20:32 2010 +0200
@@ -0,0 +1,58 @@
+#!/usr/bin/env python
+# encoding: utf-8
+# hg controller for pylons
+# Copyright (C) 2009-2010 Marcin Kuzminski <marcin@python-works.com>
+# 
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; version 2
+# of the License or (at your opinion) any later version of the license.
+# 
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+# 
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
+# MA  02110-1301, USA.
+"""
+Created on February 18, 2010
+hg controller for pylons
+@author: marcink
+"""
+from operator import itemgetter
+from pylons import tmpl_context as c, request
+from rhodecode.lib.auth import LoginRequired
+from rhodecode.lib.base import BaseController, render
+from rhodecode.model.hg import HgModel
+import logging
+log = logging.getLogger(__name__)
+
+class HomeController(BaseController):
+
+    @LoginRequired()
+    def __before__(self):
+        super(HomeController, self).__before__()
+
+    def index(self):
+        sortables = ['name', 'description', 'last_change', 'tip', 'contact']
+        current_sort = request.GET.get('sort', 'name')
+        current_sort_slug = current_sort.replace('-', '')
+
+        if current_sort_slug not in sortables:
+            c.sort_by = 'name'
+            current_sort_slug = c.sort_by
+        else:
+            c.sort_by = current_sort
+        c.sort_slug = current_sort_slug
+        cached_repo_list = HgModel().get_repos()
+
+        sort_key = current_sort_slug + '_sort'
+        if c.sort_by.startswith('-'):
+            c.repos_list = sorted(cached_repo_list, key=itemgetter(sort_key), reverse=True)
+        else:
+            c.repos_list = sorted(cached_repo_list, key=itemgetter(sort_key), reverse=False)
+
+        return render('/index.html')