X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=mediagoblin_libreplanet%2F__init__.py;h=af39bdc1d945a5f9400c643dca3b9bec71f51b68;hb=a0364380a90faf014e90148c2a7d7f0dcc04cad6;hp=a8403b1e8b41f23a631401afc796d8a6c254b7a2;hpb=0319c127de5bc759617fd58f4082f93cec6da56c;p=mediagoblin-libreplanet.git diff --git a/mediagoblin_libreplanet/__init__.py b/mediagoblin_libreplanet/__init__.py index a8403b1..af39bdc 100644 --- a/mediagoblin_libreplanet/__init__.py +++ b/mediagoblin_libreplanet/__init__.py @@ -18,9 +18,9 @@ import logging import os from mediagoblin import mg_globals -from mediagoblin.tools.pluginapi import get_config, register_template_path, register_routes +from mediagoblin.tools.pluginapi import get_config, register_template_path, register_routes, register_template_hooks from mediagoblin.db.models import MediaEntry -from lp_helper import media_entries_for_tag_slug_case_insensitive +from mediagoblin.db.util import media_entries_for_tag_slug from mediagoblin.tools.pagination import Pagination from mediagoblin.tools.response import render_to_response from mediagoblin.tools.licenses import SORTED_LICENSES, SUPPORTED_LICENSES, License @@ -35,9 +35,18 @@ SUPPORTED_LICENSES[cc_by_sa_4.uri] = cc_by_sa_4 PLUGIN_DIR = os.path.dirname(__file__) -MAX_HOME_ITEMS = 20 +MAX_HOME_ITEMS_DEFAULT = 10 + +MAX_HOME_ALL_VIDEO_ITEMS = 10 +MAX_HOME_ALL_PHOTO_ITEMS = 20 MAX_HOME_FEATURED_ITEMS = 10 +MAX_HOME_LP_ITEMS = 10 + +# make tags lowercase and use dashes in place of spaces. +# uppercase tags will be included by the lowercase form. FEATURED_TAG = "featured" +LATEST_LP_VIDEO_TAG = "libreplanet-2016-video" + _log = logging.getLogger(__name__) @@ -49,11 +58,11 @@ def setup_plugin(): # Register the template path. register_template_path(os.path.join(PLUGIN_DIR, 'templates')) -def lp_media_for_type(db, type, tag=None, max_items=MAX_HOME_ITEMS): +def lp_media_for_type(db, type, tag=None, max_items=MAX_HOME_ITEMS_DEFAULT): if (tag == None): cursor = MediaEntry.query else: - cursor = media_entries_for_tag_slug_case_insensitive(db, tag) + cursor = media_entries_for_tag_slug(db, tag) return cursor.\ filter((MediaEntry.media_type == type) @@ -63,8 +72,11 @@ def lp_media_for_type(db, type, tag=None, max_items=MAX_HOME_ITEMS): @user_not_banned def frontpage_view(request): - images = lp_media_for_type(request.db, u'mediagoblin.media_types.image') - videos = lp_media_for_type(request.db, u'mediagoblin.media_types.video') + images = lp_media_for_type(request.db, u'mediagoblin.media_types.image', None, MAX_HOME_ALL_PHOTO_ITEMS) + videos = lp_media_for_type(request.db, u'mediagoblin.media_types.video', None, MAX_HOME_ALL_VIDEO_ITEMS) + + lp2016_videos = lp_media_for_type(request.db, u'mediagoblin.media_types.video', LATEST_LP_VIDEO_TAG, MAX_HOME_LP_ITEMS) + featured_images = lp_media_for_type(request.db, u'mediagoblin.media_types.image', FEATURED_TAG, MAX_HOME_FEATURED_ITEMS) featured_videos = lp_media_for_type(request.db, u'mediagoblin.media_types.video', FEATURED_TAG, MAX_HOME_FEATURED_ITEMS) @@ -72,6 +84,7 @@ def frontpage_view(request): request, 'libreplanet/root.html', {'images': images, 'videos': videos, + 'lp2016_videos': lp2016_videos, 'featured_images': featured_images, 'featured_videos': featured_videos, 'allow_registration': mg_globals.app_config["allow_registration"]}) @@ -96,3 +109,8 @@ hooks = { 'setup': setup_plugin, 'frontpage_view': frontpage_view_hook } + +register_template_hooks( + {'header_extra': "/mediagoblin/plugins/libreplanet/templates/libreplanet/join.html"} +) +