diff --git a/accounts/forms.py b/accounts/forms.py index 8ab13b3e..3612168b 100644 --- a/accounts/forms.py +++ b/accounts/forms.py @@ -63,19 +63,9 @@ class UserCreationForm(forms.ModelForm): return user -class UserChangeForm(forms.ModelForm): - password = ReadOnlyPasswordHashField() - - class Meta: - model = User - - def clean_password(self): - return self.initial['password'] - - class UserForm(forms.ModelForm): # email = forms.EmailField(widget=forms.TextInput(attrs={'disabled' : True}), required=False) - country = forms.ChoiceField(label='Страна', choices=[(item.id, item.name) for item in Country.objects.all()], + country = forms.ChoiceField(label='Страна', choices=[(item.id, item.name) for item in Country.objects.language().all()], required=False) city = forms.CharField(label='Город', widget=forms.HiddenInput(), required=False) company = forms.ChoiceField(label='Компания', @@ -319,7 +309,7 @@ class UserFilterForm(forms.Form): class FeedFilterForm(forms.Form): data_with_parents = None filter = None - th = forms.MultipleChoiceField(label=_(u'Тематика'), choices=[(item.id, item.name) for item in Theme.active.all()], + th = forms.MultipleChoiceField(label=_(u'Тематика'), choices=[(item.id, item.name) for item in Theme.active.expo_themes()], required=False, widget=forms.CheckboxSelectMultiple()) tg = forms.CharField(label=_(u'Теги'), required=False, widget=forms.CheckboxSelectMultiple()) area = forms.MultipleChoiceField(label=_(u'Регион'), diff --git a/article/managers.py b/article/managers.py index 17026786..ccea0c90 100644 --- a/article/managers.py +++ b/article/managers.py @@ -4,7 +4,7 @@ from hvad.models import TranslatableModel, TranslatedFields, TranslationManager class ArticleManager(TranslationManager): - cache_time = 60 + cache_time = 45 def safe_get(self, **kwargs): model = self.model try: @@ -29,8 +29,8 @@ class ArticleManager(TranslationManager): def main_page_news(self): lang = translation.get_language() key = 'main_page_news_%s'%lang - cached_news = cache.get(key) - if cached_news: + if key in cache: + cached_news = cache.get(key) return cached_news else: news = list(self.news().filter(publish_date__isnull=False).order_by('-main_page', '-publish_date', '-modified')[:3]) @@ -40,10 +40,10 @@ class ArticleManager(TranslationManager): def main_page_blogs(self): lang = translation.get_language() key = 'main_page_blogs_%s'%lang - cached_blogs = cache.get(key) - if cached_blogs: + if key in cache: + cached_blogs = cache.get(key) return cached_blogs else: blogs = list(self.blogs().filter(publish_date__isnull=False).order_by('-main_page', '-publish_date')[:3]) cache.set(key, blogs, self.cache_time) - return blogs + return blogs \ No newline at end of file diff --git a/company/urls.py b/company/urls.py index fefa6e3c..0e5e2b37 100644 --- a/company/urls.py +++ b/company/urls.py @@ -1,6 +1,6 @@ # -*- coding: utf-8 -*- from django.conf.urls import patterns, url -from views import CompanySearchView, MemberDetail, MemberList, MemberTagList, MemberThemeList +from views import MemberDetail, MemberList, MemberTagList, MemberThemeList from django.contrib.auth.decorators import login_required from edit_views import * @@ -8,8 +8,7 @@ from edit_views import * urlpatterns = patterns('', url(r'company/create-company/$', 'company.views.create_company'), url(r'company/get-company/$', 'company.views.get_company'), - # - url(r'members/search/$', CompanySearchView.as_view()), + #url(r'members/(?P.*)/(?P\d+)/$', CompanyView.as_view()), #url(r'members/(?P\d+)/$', CompanyView.as_view()), #url(r'members/(?P.*)/$', CompanyView.as_view()), diff --git a/company/views.py b/company/views.py index d77a6ca2..9d07eb70 100644 --- a/company/views.py +++ b/company/views.py @@ -6,12 +6,9 @@ from django.views.generic import DetailView from functions.custom_views import ListView from django.shortcuts import get_object_or_404 from django.utils.translation import ugettext as _, get_language -from haystack.query import EmptySearchQuerySet from models import Company from theme.models import Theme, Tag from forms import CreateCompanyForm -from functions.custom_views import ExpoListView -from functions.search_forms import CompanySearchForm from .edit_forms import NameForm as CompNameForm, HomeForm as CompHomeForm, PhoneForm as CompPhoneForm,\ EmailForm as CompEmailForm, WebPageForm as CompWebPageForm, SocialForm as CompSocialForm,\ TagForm as CompTagForm, DescriptionForm as CompDescr, StaffForm as CompStaff, \ @@ -20,44 +17,10 @@ from .edit_forms import NameForm as CompNameForm, HomeForm as CompHomeForm, Phon from meta.views import MetadataMixin -class CompanySearchView(ListView): - paginate_by = 10 - template_name = 'client/company/search.html' - search_form = CompanySearchForm - model = Company - - def get_queryset(self): - - if self.request.GET: - form = self.search_form(self.request.GET) - if form.is_valid(): - return form.search() - else: - return EmptySearchQuerySet() - else: - return EmptySearchQuerySet() - - - def get_context_data(self, **kwargs): - context = super(CompanySearchView, self).get_context_data(**kwargs) - - context['search_form'] = CompanySearchForm(self.request.GET) - queries = self.request.GET.copy() - if queries.has_key('page'): - del queries['page'] - context['queries'] = queries - context['search_action'] = '/members/search/' - context['type'] = 'members search' - - return context - - - class MemberList(MetadataMixin, ListView): model = Company paginate_by = settings.CLIENT_PAGINATION template_name = 'client/company/companies_list.html' - search_form = CompanySearchForm catalog_url = '/members/' def get_queryset(self): @@ -67,7 +30,6 @@ class MemberThemeList(MetadataMixin, ListView): model = Company paginate_by = settings.CLIENT_PAGINATION template_name = 'client/company/companies_list.html' - search_form = CompanySearchForm catalog_url = '/members/' def get_queryset(self): @@ -83,7 +45,6 @@ class MemberTagList(MetadataMixin, ListView): model = Company paginate_by = settings.CLIENT_PAGINATION template_name = 'client/company/companies_list.html' - search_form = CompanySearchForm catalog_url = '/members/' def get_queryset(self): diff --git a/core/views.py b/core/views.py index 08ecb20c..f50d9256 100644 --- a/core/views.py +++ b/core/views.py @@ -10,77 +10,12 @@ from functions.views_help import split_params from django.utils.translation import ugettext as _ -#from forms import PlaceSearchForm -from functions.search_forms import PlaceSearchForm -from functions.search_forms import EventSearchForm -from haystack.query import EmptySearchQuerySet - -class EventSearchView(ListView): - paginate_by = 10 - template_name = 'exposition/search.html' - search_form = EventSearchForm - - - def get_queryset(self): - if self.request.GET: - form = self.search_form(self.request.GET) - if form.is_valid(): - return form.search() - else: - return EmptySearchQuerySet() - else: - return EmptySearchQuerySet() - - - def get_context_data(self, **kwargs): - context = super(EventSearchView, self).get_context_data(**kwargs) - context['search_form'] = EventSearchForm(self.request.GET) - queries = self.request.GET.copy() - if queries.has_key('page'): - del queries['page'] - context['queries'] = queries - context['search_action'] = '/events/search/' - - - return context - -class PlaceSearchView(ListView): - paginate_by = 10 - template_name = 'place/search.html' - model = PlaceExposition - search_form = PlaceSearchForm - - def get_queryset(self): - if self.request.GET: - form = self.search_form(self.request.GET) - if form.is_valid(): - return form.search() - else: - return [] - else: - return [] - - - def get_context_data(self, **kwargs): - context = super(PlaceSearchView, self).get_context_data(**kwargs) - context['search_form'] = PlaceSearchForm(self.request.GET) - queries = self.request.GET.copy() - if queries.has_key('page'): - del queries['page'] - context['queries'] = queries - context['search_action'] = '/places/search/' - context['type'] = 'places search' - - return context - - class PlaceListView(ListView): paginate_by = 10 params = None single_page = False template_name = 'place_catalog_test.html' model = 'places' - search_form = PlaceSearchForm order = 'data_begin' def get_params(self): diff --git a/country/manager.py b/country/manager.py index 672ca2a2..c57ff98f 100644 --- a/country/manager.py +++ b/country/manager.py @@ -95,11 +95,19 @@ class CountryManager(TranslationManager): class AreaManager(TranslationManager): + cache_time = 55 + def all_sorted(self): """ return list, not queryset """ - model = self.model - result = list(model.objects.filter()) - result.sort(key=lambda x: len(x.expos()), reverse=True) + lang = translation.get_language() + key = 'country_area_all_%s' % lang + if key in cache: + result = cache.get(key) + else: + model = self.model + result = list(model.objects.language().filter()) + #result.sort(key=lambda x: len(x.expos()), reverse=True) + cache.set(key, result, self.cache_time) return result diff --git a/country/models.py b/country/models.py index d4125c12..eb086ae7 100644 --- a/country/models.py +++ b/country/models.py @@ -10,11 +10,6 @@ from bitfield import BitField from manager import CountryManager, AreaManager from directories.models import Language, Currency from city.models import City -from exposition.models import Exposition -from place_exposition.models import PlaceExposition -from conference.models import Conference -from seminar.models import Seminar -from webinar.models import Webinar from functions.signal_handlers import post_save_handler, pre_save_handler @@ -53,6 +48,7 @@ class Area(TranslatableModel): """ return expos that occur in current area """ + from exposition.models import Exposition countries = self.countries() return Exposition.objects.filter(country__in=countries) @@ -135,26 +131,24 @@ class Country(TranslatableModel): returns nearest expos in this country """ now = date.today() + from exposition.models import Exposition return Exposition.objects.filter(data_begin__gte=now, country=self).order_by('data_begin')[:3] def get_places(self): + from place_exposition.models import PlaceExposition return PlaceExposition.objects.filter(country=self)[:3] def get_permanent_url(self): return self.catalog+self.url def expositions_number(self): + from exposition.models import Exposition return Exposition.objects.filter(country=self).count() def conferences_number(self): + from conference.models import Conference return Conference.objects.filter(country=self).count() - def seminars_number(self): - return Seminar.objects.filter(country=self).count() - - def webinars_number(self): - return Webinar.objects.filter(country=self).count() - def active_cities(self): result = list(set(City.used.active_qs().filter(country=self))) result.sort(key=lambda x: x.name) diff --git a/exposition/models.py b/exposition/models.py index f32b57a6..f8a82622 100644 --- a/exposition/models.py +++ b/exposition/models.py @@ -213,6 +213,9 @@ class Exposition(TranslatableModel, EventMixin, ExpoMixin): def tags(self): return self.tag.language().all() + def themes(self): + return self.theme.language().all() + def statistic_exists(self): return Statistic.objects.filter(exposition=self).exists() diff --git a/exposition/views.py b/exposition/views.py index 3643a636..2b1d5d75 100644 --- a/exposition/views.py +++ b/exposition/views.py @@ -42,7 +42,7 @@ class ExpositionBy(JitterCacheMixin, MetadataMixin, ListView): class ExpositionByCountry(ExpositionBy): - cache_range = settings.CACHE_RANGE + cache_range = [60*30, 60*60] model = Country title1 = _(u'По странам') title2 = _(u'Выставки мира по странам') @@ -57,7 +57,7 @@ class ExpositionByCountry(ExpositionBy): class ExpositionByTheme(ExpositionBy): - cache_range = settings.CACHE_RANGE + cache_range = [60*30, 60*60] model = Theme title1 = _(u'По тематикам') title2 = _(u'Выставки мира по тематикам') @@ -71,7 +71,7 @@ class ExpositionByTheme(ExpositionBy): # .order_by('translations__name').distinct() class ExpositionByTag(ExpositionBy): - cache_range = settings.CACHE_RANGE + cache_range = [60*30, 60*60] model = Tag title1 = _(u'По тегам') title2 = _(u'Выставки мира по тегам') @@ -83,7 +83,7 @@ class ExpositionByTag(ExpositionBy): class ExpositionByCity(ExpositionBy): - cache_range = settings.CACHE_RANGE + cache_range = [60*30, 60*60] model = City title1 = _(u'По городам') title2 = _(u'Выставки мира по городам') @@ -146,11 +146,12 @@ def exposition_visit(request, id): class ExpoDetail(JitterCacheMixin, MetadataMixin, DetailView): - cache_range = settings.CACHE_RANGE + cache_range = [60*30, 60*60] model = Exposition slug_field = 'url' template_name = 'client/exposition/exposition_detail.html' - queryset = Exposition.objects.language().select_related('place', 'city', 'country', 'paid_new') + queryset = Exposition.objects.language().select_related('place', 'city', 'country', 'paid_new').\ + prefetch_related('theme', 'tag') def get_context_data(self, **kwargs): context = super(ExpoDetail, self).get_context_data(**kwargs) @@ -163,7 +164,8 @@ class ExpoDetail(JitterCacheMixin, MetadataMixin, DetailView): return context -class ExpositionProgramme(MetadataMixin, DetailView): +class ExpositionProgramme(JitterCacheMixin, MetadataMixin, DetailView): + cache_range = [60*30, 60*60] model = Exposition slug_field = 'url' template_name = 'client/exposition/programm.html' @@ -179,7 +181,8 @@ class ExpositionProgramme(MetadataMixin, DetailView): return context -class ExpositionPrice(MetadataMixin, DetailView): +class ExpositionPrice(JitterCacheMixin, MetadataMixin, DetailView): + cache_range = [60*30, 60*60] model = Exposition slug_field = 'url' template_name = 'client/exposition/price.html' @@ -195,7 +198,8 @@ class ExpositionPrice(MetadataMixin, DetailView): return context -class ExpositionStatistic(MetadataMixin, DetailView): +class ExpositionStatistic(JitterCacheMixin, MetadataMixin, DetailView): + cache_range = [60*30, 60*60] model = Exposition slug_field = 'url' template_name = 'client/exposition/statistic.html' @@ -211,7 +215,8 @@ class ExpositionStatistic(MetadataMixin, DetailView): return context -class ExpositionThankView(MetadataMixin, DetailView): +class ExpositionThankView(JitterCacheMixin, MetadataMixin, DetailView): + cache_range = [60*30, 60*60] model = Exposition slug_field = 'url' template_name = 'client/service/thank_u_page.html' @@ -231,7 +236,8 @@ def visit_redirect(request, slug): redirect = obj.get_permanent_url() + 'price/' return HttpResponsePermanentRedirect(redirect) -class ExpositionServiceView(MetadataMixin, FormMixin, DetailView): +class ExpositionServiceView(JitterCacheMixin, MetadataMixin, FormMixin, DetailView): + cache_range = [60*30, 60*60] model = Exposition slug_field = 'url' service = None @@ -301,7 +307,7 @@ class ExpositionServiceView(MetadataMixin, FormMixin, DetailView): class ExpoList(MetadataMixin, JitterCacheMixin, ListView): - cache_range = settings.CACHE_RANGE + cache_range = [60*30, 60*60] model = Exposition paginate_by = settings.CLIENT_PAGINATION template_name = 'client/exposition/exposition_list.html' @@ -337,7 +343,7 @@ class ExpoList(MetadataMixin, JitterCacheMixin, ListView): -class ExpoCatalog(MetadataMixin, ListView): +class ExpoCatalog(JitterCacheMixin, MetadataMixin, ListView): model = Exposition paginate_by = settings.CLIENT_PAGINATION template_name = 'client/exposition/catalog.html' diff --git a/functions/model_mixin.py b/functions/model_mixin.py index a918c972..d612a507 100644 --- a/functions/model_mixin.py +++ b/functions/model_mixin.py @@ -136,6 +136,10 @@ class EventMixin(object): return gallery + def tags(self): + return self.tag.language().all() + + def copy(self, url): """ Copy event with new url diff --git a/functions/models_methods.py b/functions/models_methods.py index 943fac5b..be30179f 100644 --- a/functions/models_methods.py +++ b/functions/models_methods.py @@ -28,8 +28,9 @@ class ExpoManager(TranslationManager): def expo_main(self): lang = translation.get_language() key = 'expo_main_page_key_%s'%lang - result = cache.get(key) - if not result: + if key in cache: + result = cache.get(key) + else: result = list(self.language(lang). select_related('country', 'city', 'place', 'main'). prefetch_related('tag'). @@ -42,8 +43,9 @@ class ExpoManager(TranslationManager): def conf_main(self): lang = translation.get_language() key = 'conf_main_page_key_%s'%lang - result = cache.get(key) - if not result: + if key in cache: + result = cache.get(key) + else: result = list(self.language(lang). select_related('country', 'city', 'place', 'main'). prefetch_related('tag'). @@ -54,9 +56,6 @@ class ExpoManager(TranslationManager): return result - - - class CityManager(TranslationManager): cache_time = 600 def all(self): @@ -74,9 +73,9 @@ class CityManager(TranslationManager): def expo_cities(self): lang = translation.get_language() - key = 'used_expo_cities_%s'%lang - cached_cities = cache.get(key) - if cached_cities: + key = 'used_expo_cities_%s' % lang + if key in cache: + cached_cities = cache.get(key) return cached_cities else: from exposition.models import Exposition @@ -87,12 +86,11 @@ class CityManager(TranslationManager): def expo_cities_with_count(self): lang = translation.get_language() - key = 'used_expo_cities_count_%s'%lang - cached_cities = cache.get(key) - if cached_cities: + key = 'used_expo_cities_count_%s' % lang + if key in cache: + cached_cities = cache.get(key) return cached_cities else: - from exposition.models import Exposition sql = {'expo_count': """SELECT COUNT(*) @@ -110,9 +108,9 @@ class CityManager(TranslationManager): def conference_cities_with_count(self): lang = translation.get_language() - key = 'used_conference_cities_count_%s'%lang - cached_cities = cache.get(key) - if cached_cities: + key = 'used_conference_cities_count_%s' % lang + if key in cache: + cached_cities = cache.get(key) return cached_cities else: @@ -131,12 +129,11 @@ class CityManager(TranslationManager): cache.set(key, cities, self.cache_time) return cities - def conference_cities(self): lang = translation.get_language() key = 'used_conference_cities_%s'%lang - cached_cities = cache.get(key) - if cached_cities: + if key in cache: + cached_cities = cache.get(key) return cached_cities else: from conference.models import Conference @@ -151,8 +148,8 @@ class CityManager(TranslationManager): """ lang = translation.get_language() key = 'used_cities_%s'%lang - cached_cities = cache.get(key) - if cached_cities: + if key in cache: + cached_cities = cache.get(key) return cached_cities else: from exposition.models import Exposition diff --git a/functions/search_forms.py b/functions/search_forms.py index 88889641..50466fe4 100644 --- a/functions/search_forms.py +++ b/functions/search_forms.py @@ -2,16 +2,14 @@ import pytils import ast import json +import datetime from django import forms from django.db.models import Q -from django.utils import translation from django.utils.translation import ugettext_lazy as _ from haystack.query import EmptySearchQuerySet, SearchQuerySet from country.models import Area from exposition.models import Exposition from conference.models import Conference -from seminar.models import Seminar -from webinar.models import Webinar from company.models import Company from theme.models import Theme, Tag from country.models import Country @@ -236,20 +234,20 @@ class AbstactSearchForm(forms.Form): sqs = sqs.filter(place_filter) return sqs#.order_by('data_begin') -import datetime + + class ExpositionSearchForm(AbstactSearchForm): search_url = '/expo/search/' autocomplete_url = '/search-form/autosearch/exposition/' title = _(u'ПОИСК СОБЫТИЙ') models = [Exposition] - th = forms.MultipleChoiceField(label=_(u'Тематика'), choices=[(item.id, item.name) for item in Theme.active.all()], + th = forms.MultipleChoiceField(label=_(u'Тематика'), choices=[(item.id, item.name) for item in Theme.active.expo_themes()], required=False, widget=forms.CheckboxSelectMultiple()) tg = forms.CharField(label=_(u'Теги'), required=False, widget=forms.CheckboxSelectMultiple()) - #co = forms.CharField(label=_(u'Страна'), required=False, widget=forms.CheckboxSelectMultiple()) area = forms.MultipleChoiceField(label=_(u'Регион'), - choices=[(item.id, item.name) for item in Area.objects.language().all()], + choices=[(item.id, item.name) for item in Area.objects.all_sorted()], required=False, widget=forms.CheckboxSelectMultiple()) co = forms.MultipleChoiceField(label=_(u'Страна'), required=False, widget=forms.CheckboxSelectMultiple(), choices=[(item.id, item.name) for item in Country.objects.expo_countries()] @@ -268,7 +266,7 @@ class ExpositionSearchForm(AbstactSearchForm): def __init__(self, *args, **kwargs): super(ExpositionSearchForm, self).__init__(*args, **kwargs) - self.theme_classes = {item.id:item.generate_search_class() for item in Theme.objects.all()} + self.theme_classes = {item.id : item.generate_search_class() for item in Theme.active.expo_themes()} def search(self): @@ -335,109 +333,6 @@ class ExpositionSearchForm(AbstactSearchForm): return sqs.order_by('data_begin') -class PlaceSearchForm(AbstactSearchForm): - search_url = '/places/search/' - autocomplete_url = '/search-form/autosearch/place/' - title = _(u'ПОИСК МЕСТ') - models = [PlaceExposition, PlaceConference] - # place fields - area = forms.MultipleChoiceField(label=_(u'Регион'), choices=[(item.id, item.name) for item in list(Area.objects.language().all())], - required=False, widget=forms.CheckboxSelectMultiple()) - co = forms.MultipleChoiceField(label=_(u'Страна'), required=False, widget=forms.CheckboxSelectMultiple(), - choices=[(item.id, item.name) for item in list(Country.objects.expo_countries())] - ) - - ci = forms.MultipleChoiceField(label=_(u'Город'), required=False, widget=forms.CheckboxSelectMultiple(), - choices=[(item.id, item.name) for item in list(City.used.expo_cities())] - ) - # - place_type = forms.MultipleChoiceField(label=_(u'Тип'), required=False, choices=[]) - - def get_place_type_display(self): - return _(u'Не важно') - def search(self): - pass - - -class CompanySearchForm(AbstactSearchForm): - search_url = '/members/search/' - autocomplete_url = '/search-form/autosearch/company/' - title = _(u'ПОИСК УЧАСТНИКОВ') - models = [Company] - th = forms.MultipleChoiceField(label=_(u'Тематика'), choices=[(item.id, item.name) for item in Theme.objects.all()], - required=False, widget=forms.CheckboxSelectMultiple()) - tg = forms.CharField(label=_(u'Теги'), required=False, widget=forms.CheckboxSelectMultiple()) - - area = forms.MultipleChoiceField(label=_(u'Регион'), choices=[(item.id, item.name) for item in Area.objects.language().all()], - required=False, widget=forms.CheckboxSelectMultiple()) - co = forms.MultipleChoiceField(label=_(u'Страна'), required=False, widget=forms.CheckboxSelectMultiple(), - choices=[(item.id, item.name) for item in Country.objects.expo_countries()] - ) - - ci = forms.MultipleChoiceField(label=_(u'Город'), required=False, widget=forms.CheckboxSelectMultiple(), - choices=[(item.id, item.name) for item in City.used.expo_cities()] - ) - - def __init__(self, *args, **kwargs): - super(CompanySearchForm, self).__init__(*args, **kwargs) - self.theme_classes = {item.id:item.generate_search_class() for item in list(Theme.objects.language().all())} - def search(self): - q = self.cleaned_data.get('q') - w = self.cleaned_data.get('w') - th = self.cleaned_data.get('th') - tg = self.cleaned_data.get('tg') - c = self.cleaned_data.get('c') - city = self.cleaned_data.get('city') - - sqs = SearchQuerySet().models(Company) - - if q: - - sqs = sqs.auto_query(q) - - if w: - sqs = sqs.filter(where__contains=w) - if th: - - sqs = sqs.filter(theme__in=th) - if tg: - sqs = sqs.filter(tag__in=tg) - if c: - sqs = sqs.filter(country__in=c) - if city: - sqs = sqs.filter(country__in=c) - - - - return sqs - - -class EventSearchForm(forms.Form): - q = forms.CharField(label=_(u'Поиск'), required=False) - w = forms.CharField(label=_(u'Где'), required=False) - fr = forms.DateField(required=False, - widget=forms.DateInput(attrs={'class': 'date', 'id': 'dateFrom', - 'placeholder': _(u'дд.мм.гггг')})) - to = forms.DateField(required=False, - widget=forms.DateInput(attrs={'class': 'date', 'id': 'dateTo', - 'placeholder': _(u'дд.мм.гггг')})) - - def search(self): - - if not self.is_valid(): - return EmptySearchQuerySet() - q = self.cleaned_data.get('q') - w = self.cleaned_data.get('w') - - if not q and not w: - return EmptySearchQuerySet() - sqs = SearchQuerySet().models(Exposition, Conference, Seminar, Webinar) - - if q: - sqs = sqs.auto_query(q) - if w: - sqs = sqs.filter(where__contains=w) - return sqs diff --git a/meta/models.py b/meta/models.py index 3e5587a5..050c6799 100644 --- a/meta/models.py +++ b/meta/models.py @@ -128,20 +128,20 @@ class MetaSetting(TranslatableModel): class SeoTextManager(TranslationManager): - cache_time = 120 + cache_time = 3600 def cache_get(self, *args, **kwargs): url = kwargs.get('url') lang = kwargs.get('lang')[:2] or translation.get_language()[:2] key = 'seo_text_cache' - result = cache.get(key) - if result: + if key in cache: + result = cache.get(key) return result.get("%s_%s" % (lang, url)) - - qs = list(SeoText.objects.language('all')) - value_dict = {obj.language_code+'_'+obj.url: obj for obj in qs} - cache.set(key, value_dict, self.cache_time) - return value_dict.get("%s_%s" % (lang, url)) + else: + qs = list(SeoText.objects.language('all')) + value_dict = {obj.language_code+'_'+obj.url: obj for obj in qs} + cache.set(key, value_dict, self.cache_time) + return value_dict.get("%s_%s" % (lang, url)) class SeoText(TranslatableModel): diff --git a/proj/settings.py b/proj/settings.py index d155829f..c4588d68 100644 --- a/proj/settings.py +++ b/proj/settings.py @@ -493,7 +493,7 @@ else: ) # debug_toolbar settings -""" + if DEBUG: DEBUG_TOOLBAR_PATCH_SETTINGS = False INTERNAL_IPS = ('127.0.0.1','176.121.5.82', '176.121.11.162', '77.123.47.46') @@ -508,23 +508,19 @@ if DEBUG: JQUERY_URL = os.path.join(SITE_ROOT, 'static/client/js/jquery-ui-1.10.4.custom.min.js'), DEBUG_TOOLBAR_PANELS = [ #'debug_toolbar.panels.versions.VersionsPanel', - #'debug_toolbar.panels.timer.TimerPanel', - #'debug_toolbar.panels.settings.SettingsPanel', - #'debug_toolbar.panels.headers.HeadersPanel', - #'debug_toolbar.panels.request.RequestPanel', + 'debug_toolbar.panels.timer.TimerPanel', + 'debug_toolbar.panels.settings.SettingsPanel', + 'debug_toolbar.panels.headers.HeadersPanel', + 'debug_toolbar.panels.request.RequestPanel', 'debug_toolbar.panels.sql.SQLPanel', - #'debug_toolbar.panels.staticfiles.StaticFilesPanel', - #'debug_toolbar.panels.templates.TemplatesPanel', - #'debug_toolbar.panels.cache.CachePanel', - #'debug_toolbar.panels.signals.SignalsPanel', - #'debug_toolbar.panels.logging.LoggingPanel', - #'debug_toolbar.panels.redirects.RedirectsPanel', + 'debug_toolbar.panels.staticfiles.StaticFilesPanel', + 'debug_toolbar.panels.templates.TemplatesPanel', + 'debug_toolbar.panels.cache.CachePanel', + 'debug_toolbar.panels.signals.SignalsPanel', + 'debug_toolbar.panels.logging.LoggingPanel', + 'debug_toolbar.panels.redirects.RedirectsPanel', ] - #DEBUG_TOOLBAR_CONFIG = { - # 'INTERCEPT_REDIRECTS': False, - #} -""" -# -- PAGINATION -- # + diff --git a/proj/urls.py b/proj/urls.py index 71777d32..0afc06d7 100644 --- a/proj/urls.py +++ b/proj/urls.py @@ -74,7 +74,11 @@ urlpatterns = patterns('', url(r'^', include('settings.old_urls')), url(r'^', include('service.urls')), ) - +if settings.DEBUG: + import debug_toolbar + urlpatterns += patterns('', + url(r'^__debug__/', include(debug_toolbar.urls)), + ) # ajax urls urlpatterns += patterns('', @@ -93,8 +97,3 @@ urlpatterns += patterns('', ) -if settings.DEBUG: - import debug_toolbar - urlpatterns += patterns('', - url(r'^__debug__/', include(debug_toolbar.urls)), - ) \ No newline at end of file diff --git a/proj/views.py b/proj/views.py index 1801b84a..da2a4ba3 100644 --- a/proj/views.py +++ b/proj/views.py @@ -66,7 +66,7 @@ def error404(request): class MainPageView(JitterCacheMixin, TemplateView): - cache_range = settings.CACHE_RANGE + cache_range = [60*3, 60*5] template_name = 'client/index.html' def get_context_data(self, **kwargs): diff --git a/service/models.py b/service/models.py index f39824d7..c0282ef3 100644 --- a/service/models.py +++ b/service/models.py @@ -1,4 +1,5 @@ # -*- coding: utf-8 -*- +from django.db.models import F from django.db import models from hvad.models import TranslatableModel, TranslatedFields, TranslationManager from functions.custom_fields import EnumField @@ -146,21 +147,16 @@ class CallBack(models.Model): class Meta: ordering = ['-created'] - -from country.models import Country -from exposition.models import Exposition -from conference.models import Conference -from django.db.models import F - class LinkedService(models.Model): service = models.ForeignKey(Service, blank=False) - countries = models.ManyToManyField(Country, blank=True, verbose_name=u"Страны") + countries = models.ManyToManyField('country.Country', blank=True, verbose_name=u"Страны") exclude_countries = models.BooleanField(default=False, verbose_name=u"Исключить страны") - expositions = models.ManyToManyField(Exposition, blank=True, verbose_name= u"Выставки") - conferences = models.ManyToManyField(Conference, blank=True, verbose_name=u'Конференции') + expositions = models.ManyToManyField('exposition.Exposition', blank=True, verbose_name= u"Выставки") + conferences = models.ManyToManyField('conference.Conference', blank=True, verbose_name=u'Конференции') def update_countries_flag(self): + from country.models import Country if self.exclude_countries: 'filter all countries except selected and set flag to true' Country.objects.language().exclude(id__in=[c.id for c in self.countries.all()]).update(services=F('services').bitor(getattr(Country.services, self.service.url))) @@ -172,12 +168,14 @@ class LinkedService(models.Model): Country.objects.exclude(id__in=[c.id for c in self.countries.all()]).update(services=F('services').bitand(~getattr(Country.services, self.service.url))) def update_expositions_flag(self): - self.expositions.update(services=F('services').bitor(getattr(Exposition.services, self.service.url))) - Exposition.objects.exclude(id__in=[c.id for c in self.expositions.all()]).update(services=F('services').bitand(~getattr(Exposition.services, self.service.url))) + from exposition.models import Exposition + self.expositions.update(services=F('services').bitor(getattr(Exposition.services, self.service.url))) + Exposition.objects.exclude(id__in=[c.id for c in self.expositions.all()]).update(services=F('services').bitand(~getattr(Exposition.services, self.service.url))) def update_conferences_flag(self): - self.conferences.update(services=F('services').bitor(getattr(Conference.services, self.service.url))) - Conference.objects.exclude(id__in=[c.id for c in self.conferences.all()]).update(services=F('services').bitand(~getattr(Conference.services, self.service.url))) + from conference.models import Conference + self.conferences.update(services=F('services').bitor(getattr(Conference.services, self.service.url))) + Conference.objects.exclude(id__in=[c.id for c in self.conferences.all()]).update(services=F('services').bitand(~getattr(Conference.services, self.service.url))) def update_all_flags(self): self.update_countries_flag() diff --git a/settings/management/commands/update_views_cache.py b/settings/management/commands/update_views_cache.py index 6baafc7b..9115c17e 100644 --- a/settings/management/commands/update_views_cache.py +++ b/settings/management/commands/update_views_cache.py @@ -1,14 +1,38 @@ # -*- coding: utf-8 -*- -from django.core.management.base import BaseCommand, CommandError -from django.test.client import RequestFactory +from django.core.management.base import BaseCommand from django.utils import translation from django.conf import settings -from exposition.views import ExpositionByCity - - - - - +from django.core.cache import cache +from exposition.models import Exposition +from conference.models import Conference +from article.models import Article +from city.models import City +from country.models import Country, Area +from theme.models import Theme, Tag + + + +CACHE_TIME = 300 +update_keys = {'expo_main_page_key_%s': Exposition.objects.expo_main, + 'country_area_all_%s': Area.objects.all_sorted, + 'conf_main_page_key_%s': Conference.objects.conf_main, + 'main_page_news_%s': Article.objects.main_page_news, + 'main_page_blogs_%s': Article.objects.main_page_blogs, + 'used_expo_cities_%s': City.used.expo_cities, + 'used_expo_cities_count_%s': City.used.expo_cities_with_count, + 'used_conference_cities_count_%s': City.used.conference_cities_with_count, + 'used_conference_cities_%s': City.used.conference_cities, + 'used_cities_%s': City.used.cities, + 'used_expo_countries_%s': Country.objects.expo_countries, + 'used_expo_countries_count_%s': Country.objects.expo_countries_with_count, + 'used_conference_countries_count_%s': Country.objects.conference_countries_with_count, + 'used_conference_countries_%s': Country.objects.conference_countries, + 'used_expo_themes_%s': Theme.active.expo_themes, + 'used_expo_themes_count_%s': Theme.active.expo_themes_with_count, + 'used_conference_themes_count_%s': Theme.active.conference_themes_with_count, + 'used_conference_tags_%s': Tag.active.conference_tags, + 'used_expo_tags_count_%s': Tag.active.expo_themes_with_count, + 'used_conference_tags_count_%s': Tag.active.conference_themes_with_count} class Command(BaseCommand): def handle(self, *args, **options): @@ -16,11 +40,18 @@ class Command(BaseCommand): for lang in langs: translation.activate(lang) + for k, func in update_keys.iteritems(): + + key = k % lang + print(key) + if key in cache: + print('exist') + else: + print('not exist') + result = func() + cache.set(key, result, CACHE_TIME) + - request = RequestFactory().get('/expo/city/') - view = ExpositionByCity.as_view() - response = view(request) - print(lang) print('success') diff --git a/settings/templatetags/template_filters.py b/settings/templatetags/template_filters.py index 670ad842..d4ab8c8e 100644 --- a/settings/templatetags/template_filters.py +++ b/settings/templatetags/template_filters.py @@ -240,7 +240,7 @@ def without_page(value): @register.filter def note_by_user(obj, user): - if obj: + if obj and user.is_authenticated(): return obj.get_note_by_user(user.id) return '' diff --git a/static/custom_js/main.js b/static/custom_js/main.js index e5eaa456..acc2173e 100644 --- a/static/custom_js/main.js +++ b/static/custom_js/main.js @@ -324,7 +324,7 @@ $(document).ready(function(){ } - if( $("#id_main_page_news" ).length ) { + if( $("#id_tag" ).length ) { $('#id_tag').select2({ placeholder: "Теги", width: '550px', diff --git a/static/debug_toolbar/.DS_Store b/static/debug_toolbar/.DS_Store deleted file mode 100644 index 84ab3c93..00000000 Binary files a/static/debug_toolbar/.DS_Store and /dev/null differ diff --git a/static/debug_toolbar/css/toolbar.css b/static/debug_toolbar/css/toolbar.css deleted file mode 100644 index c85b155b..00000000 --- a/static/debug_toolbar/css/toolbar.css +++ /dev/null @@ -1,649 +0,0 @@ -/* http://www.positioniseverything.net/easyclearing.html */ -#djDebug .clearfix:after { - content: "."; - display: block; - height: 0; - clear: both; - visibility: hidden; -} -#djDebug .clearfix {display: inline-block;} -/* Hides from IE-mac \*/ -#djDebug .clearfix {display: block;} -* html #djDebug .clearfix {height: 1%;} -/* end hide from IE-mac */ - -/* Debug Toolbar CSS Reset, adapted from Eric Meyer's CSS Reset */ -#djDebug {color:#000;background:#FFF;} -#djDebug, #djDebug div, #djDebug span, #djDebug applet, #djDebug object, #djDebug iframe, -#djDebug h1, #djDebug h2, #djDebug h3, #djDebug h4, #djDebug h5, #djDebug h6, #djDebug p, #djDebug blockquote, #djDebug pre, -#djDebug a, #djDebug abbr, #djDebug acronym, #djDebug address, #djDebug big, #djDebug cite, #djDebug code, -#djDebug del, #djDebug dfn, #djDebug em, #djDebug font, #djDebug img, #djDebug ins, #djDebug kbd, #djDebug q, #djDebug s, #djDebug samp, -#djDebug small, #djDebug strike, #djDebug strong, #djDebug sub, #djDebug sup, #djDebug tt, #djDebug var, -#djDebug b, #djDebug u, #djDebug i, #djDebug center, -#djDebug dl, #djDebug dt, #djDebug dd, #djDebug ol, #djDebug ul, #djDebug li, -#djDebug fieldset, #djDebug form, #djDebug label, #djDebug legend, -#djDebug table, #djDebug caption, #djDebug tbody, #djDebug tfoot, #djDebug thead, #djDebug tr, #djDebug th, #djDebug td, -#djDebug button { - margin:0; - padding:0; - min-width:0; - width:auto; - border:0; - outline:0; - font-size:12px; - line-height:1.5em; - color:#000; - vertical-align:baseline; - background-color:transparent; - font-family:sans-serif; - text-align:left; - text-shadow: none; - -webkit-transition: none; - -moz-transition: none; - -o-transition: none; - transition: none; -} - -#djDebug button { - background-color: #eee; - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #eee), color-stop(100%, #cccccc)); - background-image: -webkit-linear-gradient(top, #eee, #cccccc); - background-image: -moz-linear-gradient(top, #eee, #cccccc); - background-image: -ms-linear-gradient(top, #eee, #cccccc); - background-image: -o-linear-gradient(top, #eee, #cccccc); - background-image: linear-gradient(top, #eee, #cccccc); - border: 1px solid #ccc; - border-bottom: 1px solid #bbb; - -webkit-border-radius: 3px; - -moz-border-radius: 3px; - border-radius: 3px; - color: #333; - line-height: 1; - padding: 0 8px; - text-align: center; - text-shadow: 0 1px 0 #eee; -} - -#djDebug button:hover { - background-color: #ddd; - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ddd), color-stop(100%, #bbb)); - background-image: -webkit-linear-gradient(top, #ddd, #bbb); - background-image: -moz-linear-gradient(top, #ddd, #bbb); - background-image: -ms-linear-gradient(top, #ddd, #bbb); - background-image: -o-linear-gradient(top, #ddd, #bbb); - background-image: linear-gradient(top, #ddd, #bbb); - border-color: #bbb; - border-bottom-color: #999; - cursor: pointer; - text-shadow: 0 1px 0 #ddd; -} - -#djDebug button:active { - border: 1px solid #aaa; - border-bottom: 1px solid #888; - -webkit-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee; - -moz-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee; - box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee; -} - -#djDebug #djDebugToolbar { - background-color:#111; - width:200px; - z-index:100000000; - position:fixed; - top:0; - bottom:0; - right:0; - opacity:0.9; - overflow-y: auto; -} - -#djDebug #djDebugToolbar small { - color:#999; -} - -#djDebug #djDebugToolbar ul { - margin:0; - padding:0; - list-style:none; -} - -#djDebug #djDebugToolbar li { - border-bottom:1px solid #222; - color:#fff; - display:block; - font-weight:bold; - float:none; - margin:0; - padding:0; - position:relative; - width:auto; -} - -#djDebug #djDebugToolbar input[type=checkbox] { - float: right; - margin: 10px; -} - -#djDebug #djDebugToolbar li>a, -#djDebug #djDebugToolbar li>div.contentless { - font-weight:normal; - font-style:normal; - text-decoration:none; - display:block; - font-size:16px; - padding:10px 10px 5px 25px; - color:#fff; -} -#djDebug #djDebugToolbar li>div.disabled { - font-style: italic; - color: #999; -} - -#djDebug #djDebugToolbar li a:hover { - color:#111; - background-color:#ffc; -} - -#djDebug #djDebugToolbar li.active { - background: #333 no-repeat left center; - background-image: url(""); - padding-left:10px; -} - -#djDebug #djDebugToolbar li.active a:hover { - color:#b36a60; - background-color:transparent; -} - -#djDebug #djDebugToolbar li small { - font-size:12px; - color:#999; - font-style:normal; - text-decoration:none; - font-variant:small-caps; -} - -#djDebug #djDebugToolbarHandle { - position:fixed; - background-color:#fff; - border:1px solid #111; - top:30px; - right:0; - z-index:100000000; - opacity:0.75; -} - -#djDebug #djShowToolBarButton { - display:block; - height:75px; - width:30px; - border-right:none; - border-bottom:4px solid #fff; - border-top:4px solid #fff; - border-left:4px solid #fff; - color:#fff; - font-size:10px; - font-weight:bold; - text-decoration:none; - text-align:center; - text-indent:-999999px; - background: #000 no-repeat left center; - background-image: url(""); - opacity:0.5; -} - -#djDebug #djShowToolBarButton:hover { - background-color:#111; - border-top-color:#FFE761; - border-left-color:#FFE761; - border-bottom-color:#FFE761; - cursor:move; - opacity:1.0; -} - -#djDebug code { - display:block; - font-family:Consolas, Monaco, "Bitstream Vera Sans Mono", "Lucida Console", monospace; - font-size: 12px; - white-space:pre; - overflow:auto; -} - -#djDebug .djDebugOdd { - background-color:#f5f5f5; -} - -#djDebug .panelContent { - display:none; - position:fixed; - margin:0; - top:0; - right:200px; - bottom:0; - left:0px; - background-color:#eee; - color:#666; - z-index:100000000; -} - -#djDebug .panelContent > div { - border-bottom:1px solid #ddd; -} - -#djDebug .djDebugPanelTitle { - position:absolute; - background-color:#ffc; - color:#666; - padding-left:20px; - top:0; - right:0; - left:0; - height:50px; -} - -#djDebug .djDebugPanelTitle code { - display:inline; - font-size:inherit; -} - -#djDebug .djDebugPanelContent { - position:absolute; - top:50px; - right:0; - bottom:0; - left:0; - height:auto; - padding:5px 0 0 20px; -} - -#djDebug .djDebugPanelContent .loader { - display:block; - margin:80px auto; -} - -#djDebug .djDebugPanelContent .scroll { - height:100%; - overflow:auto; - display:block; - padding:0 10px 0 0; -} - -#djDebug h3 { - font-size:24px; - font-weight:normal; - line-height:50px; -} - -#djDebug h4 { - font-size:20px; - font-weight:bold; - margin-top:0.8em; -} - -#djDebug .panelContent table { - border:1px solid #ccc; - border-collapse:collapse; - width:100%; - background-color:#fff; - display:block; - margin-top:0.8em; - overflow: auto; -} -#djDebug .panelContent tbody td, -#djDebug .panelContent tbody th { - vertical-align:top; - padding:2px 3px; -} -#djDebug .panelContent tbody td.time { - text-align: center; -} - -#djDebug .panelContent thead th { - padding:1px 6px 1px 3px; - text-align:left; - font-weight:bold; - font-size:14px; - white-space: nowrap; -} -#djDebug .panelContent tbody th { - width:12em; - text-align:right; - color:#666; - padding-right:.5em; -} - -#djDebug .djTemplateHideContextDiv { - background-color:#fff; -} - -/* -#djDebug .panelContent p a:hover, #djDebug .panelContent dd a:hover { - color:#111; - background-color:#ffc; -} - -#djDebug .panelContent p { - padding:0 5px; -} - -#djDebug .panelContent p, #djDebug .panelContent table, #djDebug .panelContent ol, #djDebug .panelContent ul, #djDebug .panelContent dl { - margin:5px 0 15px; - background-color:#fff; -} -#djDebug .panelContent table { - clear:both; - border:0; - padding:0; - margin:0; - border-collapse:collapse; - border-spacing:0; -} - -#djDebug .panelContent table a { - color:#000; - padding:2px 4px; -} -#djDebug .panelContent table a:hover { - background-color:#ffc; -} - -#djDebug .panelContent table th { - background-color:#333; - font-weight:bold; - color:#fff; - padding:3px 7px 3px; - text-align:left; - cursor:pointer; -} -#djDebug .panelContent table td { - padding:5px 10px; - font-size:14px; - background-color:#fff; - color:#000; - vertical-align:top; - border:0; -} -#djDebug .panelContent table tr.djDebugOdd td { - background-color:#eee; -} -*/ - -#djDebug .panelContent .djDebugClose { - text-indent:-9999999px; - display:block; - position:absolute; - top:4px; - right:15px; - height:40px; - width:40px; - background: no-repeat center center; - background-image: url(""); -} - -#djDebug .panelContent .djDebugClose:hover { - background-image: url(""); -} - -#djDebug .panelContent .djDebugClose.djDebugBack { - background-image: url(""); -} - -#djDebug .panelContent .djDebugClose.djDebugBack:hover { - background-image: url(""); -} - -#djDebug .panelContent dt, #djDebug .panelContent dd { - display:block; -} - -#djDebug .panelContent dt { - margin-top:0.75em; -} - -#djDebug .panelContent dd { - margin-left:10px; -} - -#djDebug a.toggleTemplate { - padding:4px; - background-color:#bbb; - -webkit-border-radius:3px; - -moz-border-radius:3px; - border-radius:3px; -} - -#djDebug a.toggleTemplate:hover { - padding:4px; - background-color:#444; - color:#ffe761; - -webkit-border-radius:3px; - -moz-border-radius:3px; - border-radius:3px; -} - - -#djDebug a.djTemplateShowContext, #djDebug a.djTemplateShowContext span.toggleArrow { - color:#999; -} - -#djDebug a.djTemplateShowContext:hover, #djDebug a.djTemplateShowContext:hover span.toggleArrow { - color:#000; - cursor:pointer; -} - -#djDebug .djDebugSqlWrap { - position:relative; -} - -#djDebug .djDebugCollapsed { - display: none; - text-decoration: none; - color: #333; -} - -#djDebug .djDebugUncollapsed { - color: #333; - text-decoration: none; -} - -#djDebug .djUnselected { - display: none; -} -#djDebug tr.djHiddenByDefault { - display: none; -} -#djDebug tr.djSelected { - display: table-row; -} - -#djDebug .djDebugSql { - z-index:100000002; -} - -#djDebug .djSQLDetailsDiv tbody th { - text-align: left; -} - -#djDebug .djSqlExplain td { - white-space: pre; -} - -#djDebug span.djDebugLineChart { - background-color:#777; - height:3px; - position:absolute; - bottom:0; - top:0; - left:0; - display:block; - z-index:1000000001; -} -#djDebug span.djDebugLineChartWarning { - background-color:#900; -} - -#djDebug .highlight { color:#000; } -#djDebug .highlight .err { color:#000; } /* Error */ -#djDebug .highlight .g { color:#000; } /* Generic */ -#djDebug .highlight .k { color:#000; font-weight:bold } /* Keyword */ -#djDebug .highlight .o { color:#000; } /* Operator */ -#djDebug .highlight .n { color:#000; } /* Name */ -#djDebug .highlight .mi { color:#000; font-weight:bold } /* Literal.Number.Integer */ -#djDebug .highlight .l { color:#000; } /* Literal */ -#djDebug .highlight .x { color:#000; } /* Other */ -#djDebug .highlight .p { color:#000; } /* Punctuation */ -#djDebug .highlight .m { color:#000; font-weight:bold } /* Literal.Number */ -#djDebug .highlight .s { color:#333 } /* Literal.String */ -#djDebug .highlight .w { color:#888888 } /* Text.Whitespace */ -#djDebug .highlight .il { color:#000; font-weight:bold } /* Literal.Number.Integer.Long */ -#djDebug .highlight .na { color:#333 } /* Name.Attribute */ -#djDebug .highlight .nt { color:#000; font-weight:bold } /* Name.Tag */ -#djDebug .highlight .nv { color:#333 } /* Name.Variable */ -#djDebug .highlight .s2 { color:#333 } /* Literal.String.Double */ -#djDebug .highlight .cp { color:#333 } /* Comment.Preproc */ - -#djDebug .timeline { - width: 30%; -} -#djDebug .djDebugTimeline { - position: relative; - height: 100%; - min-height: 100%; -} -#djDebug div.djDebugLineChart { - position: absolute; - left: 0; - right: 0; - top: 0; - bottom: 0; - vertical-align: middle; -} -#djDebug div.djDebugLineChart strong { - text-indent: -10000em; - display: block; - font-weight: normal; - vertical-align: middle; - background-color:#ccc; -} - -#djDebug div.djDebugLineChartWarning strong { - background-color:#900; -} - -#djDebug .djDebugInTransaction div.djDebugLineChart strong { - background-color: #d3ff82; -} -#djDebug .djDebugStartTransaction div.djDebugLineChart strong { - border-left: 1px solid #94b24d; -} -#djDebug .djDebugEndTransaction div.djDebugLineChart strong { - border-right: 1px solid #94b24d; -} -#djDebug .djDebugHover div.djDebugLineChart strong { - background-color: #000; -} -#djDebug .djDebugInTransaction.djDebugHover div.djDebugLineChart strong { - background-color: #94b24d; -} - - -#djDebug .panelContent ul.stats { - position: relative; - list-style-type: none; -} -#djDebug .panelContent ul.stats li { - width: 30%; - float: left; -} -#djDebug .panelContent ul.stats li strong.label { - display: block; -} -#djDebug .panelContent ul.stats li span.color { - height: 12px; - width: 3px; - display: inline-block; -} -#djDebug .panelContent ul.stats li span.info { - display: block; - padding-left: 5px; -} - -#djDebug .panelcontent thead th { - white-space: nowrap; -} -#djDebug .djDebugRowWarning .time { - color: red; -} -#djdebug .panelcontent table .toggle { - width: 14px; - padding-top: 3px; -} -#djDebug .panelContent table .actions { - min-width: 70px; - white-space: nowrap; -} -#djdebug .panelcontent table .color { - width: 3px; -} -#djdebug .panelcontent table .color span { - width: 3px; - height: 12px; - overflow: hidden; - padding: 0; -} -#djDebug .djToggleSwitch { - text-decoration: none; - border: 1px solid #999; - height: 12px; - width: 12px; - line-height: 12px; - text-align: center; - color: #777; - display: inline-block; - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#FFF', endColorstr='#DCDCDC'); /* for IE */ - background: -webkit-gradient(linear, left top, left bottom, from(#FFF), to(#DCDCDC)); /* for webkit browsers */ - background:-moz-linear-gradient(center top , #FFFFFF 0pt, #DCDCDC 100%) repeat scroll 0 0 transparent; -} -#djDebug .djNoToggleSwitch { - height: 14px; - width: 14px; - display: inline-block; -} - -#djDebug .djSQLDetailsDiv { - margin-top:0.8em; -} -#djDebug pre { - white-space: -moz-pre-wrap; /* Mozilla, since 1999 */ - white-space: -pre-wrap; /* Opera 4-6 */ - white-space: -o-pre-wrap; /* Opera 7 */ - white-space: pre-wrap; /* CSS-3 */ - word-wrap: break-word; /* Internet Explorer 5.5+ */ - color: #555; - border:1px solid #ccc; - border-collapse:collapse; - background-color:#fff; - display:block; - overflow: auto; - padding:2px 3px; - margin-bottom: 3px; - font-family:Consolas, Monaco, "Bitstream Vera Sans Mono", "Lucida Console", monospace; -} -#djDebug .stack span { - color: #000; - font-weight: bold; -} -#djDebug .stack span.path { - color: #777; - font-weight: normal; -} -#djDebug .stack span.code { - font-weight: normal; -} - -@media print { - #djDebug { - display: none; - } -} diff --git a/static/debug_toolbar/img/ajax-loader.gif b/static/debug_toolbar/img/ajax-loader.gif deleted file mode 100644 index a7c3f2ba..00000000 Binary files a/static/debug_toolbar/img/ajax-loader.gif and /dev/null differ diff --git a/static/debug_toolbar/img/back.png b/static/debug_toolbar/img/back.png deleted file mode 100644 index aef96c12..00000000 Binary files a/static/debug_toolbar/img/back.png and /dev/null differ diff --git a/static/debug_toolbar/img/back_hover.png b/static/debug_toolbar/img/back_hover.png deleted file mode 100644 index 2ce3edaf..00000000 Binary files a/static/debug_toolbar/img/back_hover.png and /dev/null differ diff --git a/static/debug_toolbar/img/close.png b/static/debug_toolbar/img/close.png deleted file mode 100644 index ce4317f2..00000000 Binary files a/static/debug_toolbar/img/close.png and /dev/null differ diff --git a/static/debug_toolbar/img/close_hover.png b/static/debug_toolbar/img/close_hover.png deleted file mode 100644 index 6b4d96e8..00000000 Binary files a/static/debug_toolbar/img/close_hover.png and /dev/null differ diff --git a/static/debug_toolbar/img/djdt_vertical.png b/static/debug_toolbar/img/djdt_vertical.png deleted file mode 100644 index a05d3afa..00000000 Binary files a/static/debug_toolbar/img/djdt_vertical.png and /dev/null differ diff --git a/static/debug_toolbar/img/indicator.png b/static/debug_toolbar/img/indicator.png deleted file mode 100644 index 828a6c01..00000000 Binary files a/static/debug_toolbar/img/indicator.png and /dev/null differ diff --git a/static/debug_toolbar/js/toolbar.js b/static/debug_toolbar/js/toolbar.js deleted file mode 100644 index 771bdda8..00000000 --- a/static/debug_toolbar/js/toolbar.js +++ /dev/null @@ -1,284 +0,0 @@ -(function ($) { - var djdt = { - handleDragged: false, - events: { - ready: [] - }, - isReady: false, - init: function() { - $('#djDebug').show(); - var current = null; - $(document).on('click', '#djDebugPanelList li a', function() { - if (!this.className) { - return false; - } - current = $('#djDebug #' + this.className); - if (current.is(':visible')) { - $(document).trigger('close.djDebug'); - $(this).parent().removeClass('active'); - } else { - $('.panelContent').hide(); // Hide any that are already open - var inner = current.find('.djDebugPanelContent .scroll'), - store_id = $('#djDebug').data('store-id'), - render_panel_url = $('#djDebug').data('render-panel-url'); - if (store_id !== '' && inner.children().length === 0) { - var ajax_data = { - data: { - store_id: store_id, - panel_id: this.className - }, - type: 'GET', - url: render_panel_url - }; - $.ajax(ajax_data).done(function(data){ - inner.prev().remove(); // Remove AJAX loader - inner.html(data); - }).fail(function(xhr){ - var message = '
Back

'+xhr.status+': '+xhr.statusText+'

'; - $('#djDebugWindow').html(message).show(); - }); - } - current.show(); - $('#djDebugToolbar li').removeClass('active'); - $(this).parent().addClass('active'); - } - return false; - }); - $(document).on('click', '#djDebug a.djDebugClose', function() { - $(document).trigger('close.djDebug'); - $('#djDebugToolbar li').removeClass('active'); - return false; - }); - $(document).on('click', '#djDebug .djDebugPanelButton input[type=checkbox]', function() { - djdt.cookie.set($(this).attr('data-cookie'), $(this).prop('checked') ? 'on' : 'off', { - path: '/', - expires: 10 - }); - }); - - // Used by the SQL and template panels - $(document).on('click', '#djDebug .remoteCall', function() { - var self = $(this); - var name = self[0].tagName.toLowerCase(); - var ajax_data = {}; - - if (name == 'button') { - var form = self.parents('form:eq(0)'); - ajax_data['url'] = self.attr('formaction'); - - if (form.length) { - ajax_data['data'] = form.serialize(); - ajax_data['type'] = form.attr('method') || 'POST'; - } - } - - if (name == 'a') { - ajax_data['url'] = self.attr('href'); - } - - $.ajax(ajax_data).done(function(data){ - $('#djDebugWindow').html(data).show(); - }).fail(function(xhr){ - var message = '
Back

'+xhr.status+': '+xhr.statusText+'

'; - $('#djDebugWindow').html(message).show(); - }); - - $(document).on('click', '#djDebugWindow a.djDebugBack', function() { - $(this).parent().parent().hide(); - return false; - }); - - return false; - }); - - // Used by the cache, profiling and SQL panels - $(document).on('click', '#djDebug a.djToggleSwitch', function(e) { - e.preventDefault(); - var btn = $(this); - var id = btn.attr('data-toggle-id'); - var open_me = btn.text() == btn.attr('data-toggle-open'); - if (id === '' || !id) { - return; - } - var name = btn.attr('data-toggle-name'); - btn.parents('.djDebugPanelContent').find('#' + name + '_' + id).find('.djDebugCollapsed').toggle(open_me); - btn.parents('.djDebugPanelContent').find('#' + name + '_' + id).find('.djDebugUncollapsed').toggle(!open_me); - $(this).parents('.djDebugPanelContent').find('.djToggleDetails_' + id).each(function(){ - var $this = $(this); - if (open_me) { - $this.addClass('djSelected'); - $this.removeClass('djUnselected'); - btn.text(btn.attr('data-toggle-close')); - $this.find('.djToggleSwitch').text(btn.text()); - } else { - $this.removeClass('djSelected'); - $this.addClass('djUnselected'); - btn.text(btn.attr('data-toggle-open')); - $this.find('.djToggleSwitch').text(btn.text()); - } - }); - return; - }); - - $('#djHideToolBarButton').click(function() { - djdt.hide_toolbar(true); - return false; - }); - $('#djShowToolBarButton').click(function() { - if (!djdt.handleDragged) { - djdt.show_toolbar(); - } - return false; - }); - var handle = $('#djDebugToolbarHandle'); - $('#djShowToolBarButton').on('mousedown', function (event) { - var startPageY = event.pageY; - var baseY = handle.offset().top - startPageY; - $(document).on('mousemove.djDebug', function (event) { - // Chrome can send spurious mousemove events, so don't do anything unless the - // cursor really moved. Otherwise, it will be impossible to expand the toolbar - // due to djdt.handleDragged being set to true. - if (djdt.handleDragged || event.pageY != startPageY) { - var offset = handle.offset(); - offset.top = baseY + event.pageY; - handle.offset(offset); - djdt.handleDragged = true; - } - }); - return false; - }); - $(document).on('mouseup', function () { - $(document).off('mousemove.djDebug'); - if (djdt.handleDragged) { - var top = handle.offset().top; - djdt.cookie.set('djdttop', top, { - path: '/', - expires: 10 - }); - setTimeout(function () { - djdt.handleDragged = false; - }, 10); - return false; - } - }); - $(document).bind('close.djDebug', function() { - // If a sub-panel is open, close that - if ($('#djDebugWindow').is(':visible')) { - $('#djDebugWindow').hide(); - return; - } - // If a panel is open, close that - if ($('.panelContent').is(':visible')) { - $('.panelContent').hide(); - $('#djDebugToolbar li').removeClass('active'); - return; - } - // Otherwise, just minimize the toolbar - if ($('#djDebugToolbar').is(':visible')) { - djdt.hide_toolbar(true); - return; - } - }); - if (djdt.cookie.get('djdt') == 'hide') { - djdt.hide_toolbar(false); - } else { - djdt.show_toolbar(false); - } - $('#djDebug .djDebugHoverable').hover(function(){ - $(this).addClass('djDebugHover'); - }, function(){ - $(this).removeClass('djDebugHover'); - }); - djdt.isReady = true; - $.each(djdt.events.ready, function(_, callback){ - callback(djdt); - }); - }, - close: function() { - $(document).trigger('close.djDebug'); - return false; - }, - hide_toolbar: function(setCookie) { - // close any sub panels - $('#djDebugWindow').hide(); - // close all panels - $('.panelContent').hide(); - $('#djDebugToolbar li').removeClass('active'); - // finally close toolbar - $('#djDebugToolbar').hide('fast'); - $('#djDebugToolbarHandle').show(); - // set handle position - var handleTop = djdt.cookie.get('djdttop'); - if (handleTop) { - $('#djDebugToolbarHandle').css({top: handleTop + 'px'}); - } - // Unbind keydown - $(document).unbind('keydown.djDebug'); - if (setCookie) { - djdt.cookie.set('djdt', 'hide', { - path: '/', - expires: 10 - }); - } - }, - show_toolbar: function(animate) { - // Set up keybindings - $(document).bind('keydown.djDebug', function(e) { - if (e.keyCode == 27) { - djdt.close(); - } - }); - $('#djDebugToolbarHandle').hide(); - if (animate) { - $('#djDebugToolbar').show('fast'); - } else { - $('#djDebugToolbar').show(); - } - djdt.cookie.set('djdt', 'show', { - path: '/', - expires: 10 - }); - }, - ready: function(callback){ - if (djdt.isReady) { - callback(djdt); - } else { - djdt.events.ready.push(callback); - } - }, - cookie: { - get: function(key){ - if (document.cookie.indexOf(key) === -1) return null; - - var cookieArray = document.cookie.split('; '), - cookies = {}; - - cookieArray.forEach(function(e){ - var parts = e.split('='); - cookies[ parts[0] ] = parts[1]; - }); - - return cookies[ key ]; - }, - set: function(key, value, options){ - options = options || {}; - - if (typeof options.expires === 'number') { - var days = options.expires, t = options.expires = new Date(); - t.setDate(t.getDate() + days); - } - - document.cookie = [ - encodeURIComponent(key) + '=' + String(value), - options.expires ? '; expires=' + options.expires.toUTCString() : '', - options.path ? '; path=' + options.path : '', - options.domain ? '; domain=' + options.domain : '', - options.secure ? '; secure' : '' - ].join(''); - - return value; - } - } - }; - $(document).ready(djdt.init); -})(djdt.jQuery); diff --git a/static/debug_toolbar/js/toolbar.profiling.js b/static/debug_toolbar/js/toolbar.profiling.js deleted file mode 100644 index 1018e9b4..00000000 --- a/static/debug_toolbar/js/toolbar.profiling.js +++ /dev/null @@ -1,20 +0,0 @@ -(function ($) { - function getSubcalls(row) { - var id = row.attr('id'); - return $('.djDebugProfileRow[id^="'+id+'_"]'); - } - function getDirectSubcalls(row) { - var subcalls = getSubcalls(row); - var depth = parseInt(row.attr('depth'), 10) + 1; - return subcalls.filter('[depth='+depth+']'); - } - $('.djDebugProfileRow .djDebugProfileToggle').on('click', function(){ - var row = $(this).closest('.djDebugProfileRow'); - var subcalls = getSubcalls(row); - if (subcalls.css('display') == 'none') { - getDirectSubcalls(row).show(); - } else { - subcalls.hide(); - } - }); -})(djdt.jQuery); diff --git a/static/debug_toolbar/js/toolbar.sql.js b/static/debug_toolbar/js/toolbar.sql.js deleted file mode 100644 index e470ac8f..00000000 --- a/static/debug_toolbar/js/toolbar.sql.js +++ /dev/null @@ -1,7 +0,0 @@ -(function ($) { - $('#djDebug a.djDebugToggle').on('click', function(e) { - e.preventDefault(); - $(this).parent().find('.djDebugCollapsed').toggle(); - $(this).parent().find('.djDebugUncollapsed').toggle(); - }); -})(djdt.jQuery); diff --git a/static/debug_toolbar/js/toolbar.template.js b/static/debug_toolbar/js/toolbar.template.js deleted file mode 100644 index 01ac8a4a..00000000 --- a/static/debug_toolbar/js/toolbar.template.js +++ /dev/null @@ -1,11 +0,0 @@ -(function ($) { - var uarr = String.fromCharCode(0x25b6), - darr = String.fromCharCode(0x25bc); - - $('a.djTemplateShowContext').on('click', function() { - var arrow = $(this).children('.toggleArrow'); - arrow.html(arrow.html() == uarr ? darr : uarr); - $(this).parent().next().toggle(); - return false; - }); -})(djdt.jQuery); diff --git a/static/debug_toolbar/js/toolbar.timer.js b/static/debug_toolbar/js/toolbar.timer.js deleted file mode 100644 index cc9d6ae7..00000000 --- a/static/debug_toolbar/js/toolbar.timer.js +++ /dev/null @@ -1,48 +0,0 @@ -(function ($) { - // Browser timing remains hidden unless we can successfully access the performance object - var perf = window.performance || window.msPerformance || - window.webkitPerformance || window.mozPerformance; - if (!perf) - return; - - var rowCount = 0, - timingOffset = perf.timing.navigationStart, - timingEnd = perf.timing.loadEventEnd, - totalTime = timingEnd - timingOffset; - function getLeft(stat) { - return ((perf.timing[stat] - timingOffset) / (totalTime)) * 100.0; - } - function getCSSWidth(stat, endStat) { - var width = ((perf.timing[endStat] - perf.timing[stat]) / (totalTime)) * 100.0; - // Calculate relative percent (same as sql panel logic) - width = 100.0 * width / (100.0 - getLeft(stat)); - return (width < 1) ? "2px" : width + "%"; - } - function addRow(stat, endStat) { - rowCount++; - var $row = $(''); - if (endStat) { - // Render a start through end bar - $row.html('' + stat.replace('Start', '') + '' + - '
 
' + - '' + (perf.timing[stat] - timingOffset) + ' (+' + (perf.timing[endStat] - perf.timing[stat]) + ')'); - } else { - // Render a point in time - $row.html('' + stat + '' + - '
 
' + - '' + (perf.timing[stat] - timingOffset) + ''); - } - $('#djDebugBrowserTimingTableBody').append($row); - } - - // This is a reasonably complete and ordered set of timing periods (2 params) and events (1 param) - addRow('domainLookupStart', 'domainLookupEnd'); - addRow('connectStart', 'connectEnd'); - addRow('requestStart', 'responseEnd'); // There is no requestEnd - addRow('responseStart', 'responseEnd'); - addRow('domLoading', 'domComplete'); // Spans the events below - addRow('domInteractive'); - addRow('domContentLoadedEventStart', 'domContentLoadedEventEnd'); - addRow('loadEventStart', 'loadEventEnd'); - $('#djDebugBrowserTiming').css("display", "block"); -})(djdt.jQuery); diff --git a/templates/client/includes/exposition/default_description.html b/templates/client/includes/exposition/default_description.html index b3a5fea3..dfea5ead 100644 --- a/templates/client/includes/exposition/default_description.html +++ b/templates/client/includes/exposition/default_description.html @@ -21,7 +21,7 @@ {% endblocktrans %}{% if expo.place %} {% blocktrans with name=expo.place.name url=expo.place.url %}Как добраться до выставочного центра {{ name }} можно посмотреть - здесь.{% endblocktrans %} + здесь.{% endblocktrans %} {% endif %} {% blocktrans with name=expo.name %} Не забудьте проверить место и даты выставки на официальном сайте и в календаре выставочного комплекса. diff --git a/templates/client/includes/exposition/expo_paid.html b/templates/client/includes/exposition/expo_paid.html index fc2e3547..abc3ae9b 100644 --- a/templates/client/includes/exposition/expo_paid.html +++ b/templates/client/includes/exposition/expo_paid.html @@ -90,7 +90,7 @@ {% trans 'изменить' %} {% endif %} - {% if exposition.photogallery %} + {% if exposition.photogallery_id %} {% trans 'фото' %} {% endif %} diff --git a/templates/client/includes/exposition/exposition_object.html b/templates/client/includes/exposition/exposition_object.html index d88ff286..e81d8f79 100644 --- a/templates/client/includes/exposition/exposition_object.html +++ b/templates/client/includes/exposition/exposition_object.html @@ -94,7 +94,7 @@ {% if request.user.is_admin %} {% trans 'изменить' %} {% endif %} - {% if exposition.photogallery %} + {% if exposition.photogallery_id %} {% trans 'фото' %} {% endif %} @@ -105,7 +105,7 @@
- {% with tags=exposition.tag.all %} + {% with tags=exposition.tags %} {% for tag in tags %} {{ tag.name }}{% if forloop.counter != tags|length %},{% endif %} {% endfor %} diff --git a/templates/client/includes/index/main_events.html b/templates/client/includes/index/main_events.html index 6fa3c0ca..f0b2c014 100644 --- a/templates/client/includes/index/main_events.html +++ b/templates/client/includes/index/main_events.html @@ -45,7 +45,7 @@
- {% with tags=event.tag.all %} + {% with tags=event.tags %} {% for tag in tags %} {{ tag }}{% if forloop.counter < tags|length %},{% endif %} {% endfor %} diff --git a/templates/debug_toolbar/base.html b/templates/debug_toolbar/base.html deleted file mode 100644 index c6462835..00000000 --- a/templates/debug_toolbar/base.html +++ /dev/null @@ -1,70 +0,0 @@ -{% load i18n %}{% load static from staticfiles %}{% load url from future %} - - -{% if toolbar.config.JQUERY_URL %} - - - - -{% else %} - -{% endif %} - - diff --git a/templates/debug_toolbar/panels/cache.html b/templates/debug_toolbar/panels/cache.html deleted file mode 100644 index 527306cf..00000000 --- a/templates/debug_toolbar/panels/cache.html +++ /dev/null @@ -1,69 +0,0 @@ -{% load i18n %} -

{% trans "Summary" %}

- - - - - - - - - - - - - - - - - -
{% trans "Total calls" %}{% trans "Total time" %}{% trans "Cache hits" %}{% trans "Cache misses" %}
{{ total_calls }}{{ total_time }} ms{{ hits }}{{ misses }}
-

{% trans "Commands" %}

- - - - {% for name in counts.keys %} - - {% endfor %} - - - - - {% for value in counts.values %} - - {% endfor %} - - -
{{ name }}
{{ value }}
-{% if calls %} -

{% trans "Calls" %}

- - - - - - - - - - - - {% for call in calls %} - - - - - - - - - - - - - {% endfor %} - -
{% trans "Time (ms)" %}{% trans "Type" %}{% trans "Arguments" %}{% trans "Keyword arguments" %}{% trans "Backend" %}
- + - {{ call.time|floatformat:"4" }}{{ call.name|escape }}{{ call.args|escape }}{{ call.kwargs|escape }}{{ call.backend }}
{{ call.trace }}
-{% endif %} diff --git a/templates/debug_toolbar/panels/headers.html b/templates/debug_toolbar/panels/headers.html deleted file mode 100644 index 6b43e94a..00000000 --- a/templates/debug_toolbar/panels/headers.html +++ /dev/null @@ -1,60 +0,0 @@ -{% load i18n %} - -

{% trans "Request headers" %}

- - - - - - - - - - {% for key, value in request_headers.items %} - - - - - {% endfor %} - -
{% trans "Key" %}{% trans "Value" %}
{{ key|escape }}{{ value|escape }}
- -

{% trans "Response headers" %}

- - - - - - - - - - {% for key, value in response_headers.items %} - - - - - {% endfor %} - -
{% trans "Key" %}{% trans "Value" %}
{{ key|escape }}{{ value|escape }}
- -

{% trans "WSGI environ" %}

- -

{% trans "Since the WSGI environ inherits the environment of the server, only a significant subset is shown below." %}

- - - - - - - - - - {% for key, value in environ.items %} - - - - - {% endfor %} - -
{% trans "Key" %}{% trans "Value" %}
{{ key|escape }}{{ value|escape }}
diff --git a/templates/debug_toolbar/panels/logging.html b/templates/debug_toolbar/panels/logging.html deleted file mode 100644 index 3908f4fe..00000000 --- a/templates/debug_toolbar/panels/logging.html +++ /dev/null @@ -1,28 +0,0 @@ -{% load i18n %} -{% if records %} - - - - - - - - - - - - {% for record in records %} - - - - - - - - {% endfor %} - -
{% trans "Level" %}{% trans "Time" %}{% trans "Channel" %}{% trans "Message" %}{% trans "Location" %}
{{ record.level }}{{ record.time|date:"h:i:s m/d/Y" }}{{ record.channel|default:"-" }}{{ record.message|linebreaksbr }}{{ record.file }}:{{ record.line }}
-{% else %} -

{% trans "No messages logged" %}.

-{% endif %} - diff --git a/templates/debug_toolbar/panels/profiling.html b/templates/debug_toolbar/panels/profiling.html deleted file mode 100644 index 0cd1f975..00000000 --- a/templates/debug_toolbar/panels/profiling.html +++ /dev/null @@ -1,37 +0,0 @@ -{% load i18n %}{% load static from staticfiles %} - - - - - - - - - - - - - {% for call in func_list %} - - - - - - - - - - {% endfor %} - -
{% trans "Call" %}{% trans "CumTime" %}{% trans "Per" %}{% trans "TotTime" %}{% trans "Per" %}{% trans "Count" %}
-
- {% if call.has_subfuncs %} - - - {% else %} - - {% endif %} - {{ call.func_std_string }} -
-
{{ call.cumtime|floatformat:3 }}{{ call.cumtime_per_call|floatformat:3 }}{{ call.tottime|floatformat:3 }}{{ call.tottime_per_call|floatformat:3 }}{{ call.count }}
- - diff --git a/templates/debug_toolbar/panels/request.html b/templates/debug_toolbar/panels/request.html deleted file mode 100644 index c3c8d58c..00000000 --- a/templates/debug_toolbar/panels/request.html +++ /dev/null @@ -1,124 +0,0 @@ -{% load i18n %} - -

{% trans "View information" %}

- - - - - - - - - - - - - - - - - -
{% trans "View function" %}{% trans "Arguments" %}{% trans "Keyword arguments" %}{% trans "URL name" %}
{{ view_func }}{{ view_args|pprint }}{{ view_kwargs|pprint }}{{ view_urlname }}
- -{% if cookies %} -

{% trans "Cookies" %}

- - - - - - - - - - - - - {% for key, value in cookies %} - - - - - {% endfor %} - -
{% trans "Variable" %}{% trans "Value" %}
{{ key|pprint }}{{ value|pprint }}
-{% else %} -

{% trans "No cookies" %}

-{% endif %} - -{% if session %} -

{% trans "Session data" %}

- - - - - - - - - - - - - {% for key, value in session %} - - - - - {% endfor %} - -
{% trans "Variable" %}{% trans "Value" %}
{{ key|pprint }}{{ value|pprint }}
-{% else %} -

{% trans "No session data" %}

-{% endif %} - -{% if get %} -

{% trans "GET data" %}

- - - - - - - - - - - - - {% for key, value in get %} - - - - - {% endfor %} - -
{% trans "Variable" %}{% trans "Value" %}
{{ key|pprint }}{{ value|pprint }}
-{% else %} -

{% trans "No GET data" %}

-{% endif %} - -{% if post %} -

{% trans "POST data" %}

- - - - - - - - - - - {% for key, value in post %} - - - - - {% endfor %} - -
{% trans "Variable" %}{% trans "Value" %}
{{ key|pprint }}{{ value|pprint }}
-{% else %} -

{% trans "No POST data" %}

-{% endif %} diff --git a/templates/debug_toolbar/panels/settings.html b/templates/debug_toolbar/panels/settings.html deleted file mode 100644 index f6b5afe8..00000000 --- a/templates/debug_toolbar/panels/settings.html +++ /dev/null @@ -1,17 +0,0 @@ -{% load i18n %} - - - - - - - - - {% for name, value in settings.items %} - - - - - {% endfor %} - -
{% trans "Setting" %}{% trans "Value" %}
{{ name }}{{ value|pprint }}
diff --git a/templates/debug_toolbar/panels/signals.html b/templates/debug_toolbar/panels/signals.html deleted file mode 100644 index ac32f373..00000000 --- a/templates/debug_toolbar/panels/signals.html +++ /dev/null @@ -1,19 +0,0 @@ -{% load i18n %} - - - - - - - - - - {% for name, signal, receivers in signals %} - - - - - - {% endfor %} - -
{% trans "Signal" %}{% trans "Providing" %}{% trans "Receivers" %}
{{ name|escape }}{{ signal.providing_args|join:", " }}{{ receivers|join:", " }}
diff --git a/templates/debug_toolbar/panels/sql.html b/templates/debug_toolbar/panels/sql.html deleted file mode 100644 index 8c6725d8..00000000 --- a/templates/debug_toolbar/panels/sql.html +++ /dev/null @@ -1,95 +0,0 @@ -{% load i18n l10n %}{% load static from staticfiles %}{% load url from future %} -
-
    - {% for alias, info in databases %} -
  • -   {{ alias }} - {{ info.time_spent|floatformat:"2" }} ms ({% blocktrans count info.num_queries as num %}{{ num }} query{% plural %}{{ num }} queries{% endblocktrans %}) -
  • - {% endfor %} -
-
- -{% if queries %} - - - - - - - - - - - - {% for query in queries %} - - - - - - - - - - - - - {% endfor %} - -
 {% trans "Query" %}{% trans "Timeline" %}{% trans "Time (ms)" %}{% trans "Action" %}
  - + - -
-
{{ query.sql|safe }}
-
-
-
{{ query.width_ratio }}%
-
- {{ query.duration|floatformat:"2" }} - - - {% if query.params %} - {% if query.is_select %} -
- {{ query.form }} - - - - - {% if query.vendor == 'mysql' %} - - {% endif %} -
- {% endif %} - {% endif %} -
-
-

{% trans "Connection:" %} {{ query.alias }}

- {% if query.iso_level %} -

{% trans "Isolation level:" %} {{ query.iso_level }}

- {% endif %} - {% if query.trans_status %} -

{% trans "Transaction status:" %} {{ query.trans_status }}

- {% endif %} - {% if query.stacktrace %} -
{{ query.stacktrace }}
- {% endif %} - {% if query.template_info %} - - {% for line in query.template_info.context %} - - - - - {% endfor %} -
{{ line.num }}{{ line.content }}
-

{{ query.template_info.name|default:_("(unknown)") }}

- {% endif %} -
-
-{% else %} -

{% trans "No SQL queries were recorded during this request." %}

-{% endif %} - - diff --git a/templates/debug_toolbar/panels/sql_explain.html b/templates/debug_toolbar/panels/sql_explain.html deleted file mode 100644 index 0fa30ab7..00000000 --- a/templates/debug_toolbar/panels/sql_explain.html +++ /dev/null @@ -1,37 +0,0 @@ -{% load i18n %}{% load static from staticfiles %} -
- -

{% trans "SQL explained" %}

-
-
-
-
-
{% trans "Executed SQL" %}
-
{{ sql|safe }}
-
{% trans "Time" %}
-
{{ duration }} ms
-
{% trans "Database" %}
-
{{ alias }}
-
- - - - {% for h in headers %} - - {% endfor %} - - - - {% for row in result %} - - {% for column in row %} - - {% endfor %} - - {% endfor %} - -
{{ h|upper }}
{{ column|escape }}
-
-
- - diff --git a/templates/debug_toolbar/panels/sql_profile.html b/templates/debug_toolbar/panels/sql_profile.html deleted file mode 100644 index e5813c6c..00000000 --- a/templates/debug_toolbar/panels/sql_profile.html +++ /dev/null @@ -1,44 +0,0 @@ -{% load i18n %}{% load static from staticfiles %} -
- -

{% trans "SQL profiled" %}

-
-
-
- {% if result %} -
-
{% trans "Executed SQL" %}
-
{{ sql|safe }}
-
{% trans "Time" %}
-
{{ duration }} ms
-
{% trans "Database" %}
-
{{ alias }}
-
- - - - {% for h in headers %} - - {% endfor %} - - - - {% for row in result %} - - {% for column in row %} - - {% endfor %} - - {% endfor %} - -
{{ h|upper }}
{{ column|escape }}
- {% else %} -
-
{% trans "Error" %}
-
{{ result_error }}
-
- {% endif %} -
-
- - diff --git a/templates/debug_toolbar/panels/sql_select.html b/templates/debug_toolbar/panels/sql_select.html deleted file mode 100644 index 50cd0b1c..00000000 --- a/templates/debug_toolbar/panels/sql_select.html +++ /dev/null @@ -1,41 +0,0 @@ -{% load i18n %}{% load static from staticfiles %} -
- -

{% trans "SQL selected" %}

-
-
-
-
-
{% trans "Executed SQL" %}
-
{{ sql|safe }}
-
{% trans "Time" %}
-
{{ duration }} ms
-
{% trans "Database" %}
-
{{ alias }}
-
- {% if result %} - - - - {% for h in headers %} - - {% endfor %} - - - - {% for row in result %} - - {% for column in row %} - - {% endfor %} - - {% endfor %} - -
{{ h|upper }}
{{ column|escape }}
- {% else %} -

{% trans "Empty set" %}

- {% endif %} -
-
- - diff --git a/templates/debug_toolbar/panels/staticfiles.html b/templates/debug_toolbar/panels/staticfiles.html deleted file mode 100644 index 95c9ec87..00000000 --- a/templates/debug_toolbar/panels/staticfiles.html +++ /dev/null @@ -1,57 +0,0 @@ -{% load i18n %} -{% load static from staticfiles%} - -

{% blocktrans count staticfiles_dirs|length as dirs_count %}Static file path{% plural %}Static file paths{% endblocktrans %}

-{% if staticfiles_dirs %} -
    - {% for prefix, staticfiles_dir in staticfiles_dirs %} -
  1. {{ staticfiles_dir }}{% if prefix %} {% blocktrans %}(prefix {{ prefix }}){% endblocktrans %}{% endif %}
  2. - {% endfor %} -
-{% else %} -

{% trans "None" %}

-{% endif %} - -

{% blocktrans count staticfiles_apps|length as apps_count %}Static file app{% plural %}Static file apps{% endblocktrans %}

-{% if staticfiles_apps %} -
    - {% for static_app in staticfiles_apps %} -
  1. {{ static_app }}
  2. - {% endfor %} -
-{% else %} -

{% trans "None" %}

-{% endif %} - -

{% blocktrans count staticfiles|length as staticfiles_count %}Static file{% plural %}Static files{% endblocktrans %}

-{% if staticfiles %} -
-{% for staticfile in staticfiles %} -
{{ staticfile }}
-
{{ staticfile.real_path }}
-{% endfor %} -
-{% else %} -

{% trans "None" %}

-{% endif %} - - -{% for finder, payload in staticfiles_finders.items %} -

{{ finder }} ({% blocktrans count payload|length as payload_count %}{{ payload_count }} file{% plural %}{{ payload_count }} files{% endblocktrans %})

- - - - - - - - - {% for path, real_path in payload %} - - - - - {% endfor %} - -
{% trans 'Path' %}{% trans 'Location' %}
{{ path }}{{ real_path }}
-{% endfor %} diff --git a/templates/debug_toolbar/panels/template_source.html b/templates/debug_toolbar/panels/template_source.html deleted file mode 100644 index 7914f2ed..00000000 --- a/templates/debug_toolbar/panels/template_source.html +++ /dev/null @@ -1,14 +0,0 @@ -{% load i18n %} -
- -

{% trans "Template source:" %} {{ template_name }}

-
-
-
- {% if not source.pygmentized %} - {{ source }} - {% else %} - {{ source }} - {% endif %} -
-
diff --git a/templates/debug_toolbar/panels/templates.html b/templates/debug_toolbar/panels/templates.html deleted file mode 100644 index 644b4d64..00000000 --- a/templates/debug_toolbar/panels/templates.html +++ /dev/null @@ -1,46 +0,0 @@ -{% load i18n %}{% load static from staticfiles %}{% load url from future %} -

{% blocktrans count template_dirs|length as template_count %}Template path{% plural %}Template paths{% endblocktrans %}

-{% if template_dirs %} -
    - {% for template in template_dirs %} -
  1. {{ template }}
  2. - {% endfor %} -
-{% else %} -

{% trans "None" %}

-{% endif %} - -

{% blocktrans count templates|length as template_count %}Template{% plural %}Templates{% endblocktrans %}

-{% if templates %} -
-{% for template in templates %} -
{{ template.template.name|addslashes }}
-
{{ template.template.origin_name|addslashes }}
- {% if template.context %} -
- - -
- {% endif %} -{% endfor %} -
-{% else %} -

{% trans "None" %}

-{% endif %} - -

{% blocktrans count context_processors|length as context_processors_count %}Context processor{% plural %}Context processors{% endblocktrans %}

-{% if context_processors %} -
-{% for key, value in context_processors.items %} -
{{ key|escape }}
-
- - -
-{% endfor %} -
-{% else %} -

{% trans "None" %}

-{% endif %} - - diff --git a/templates/debug_toolbar/panels/timer.html b/templates/debug_toolbar/panels/timer.html deleted file mode 100644 index 988c7156..00000000 --- a/templates/debug_toolbar/panels/timer.html +++ /dev/null @@ -1,44 +0,0 @@ -{% load i18n %}{% load static from staticfiles %} -

{% trans "Resource usage" %}

- - - - - - - - - - - - - {% for key, value in rows %} - - - - - {% endfor %} - -
{% trans "Resource" %}{% trans "Value" %}
{{ key|escape }}{{ value|escape }}
- - - - diff --git a/templates/debug_toolbar/panels/versions.html b/templates/debug_toolbar/panels/versions.html deleted file mode 100644 index 2c614f11..00000000 --- a/templates/debug_toolbar/panels/versions.html +++ /dev/null @@ -1,17 +0,0 @@ -{% load i18n %} - - - - - - - - - {% for package, version in versions.items %} - - - - - {% endfor %} - -
{% trans "Name" %}{% trans "Version" %}
{{ package }}{{ version }}
diff --git a/templates/debug_toolbar/redirect.html b/templates/debug_toolbar/redirect.html deleted file mode 100644 index 365fb482..00000000 --- a/templates/debug_toolbar/redirect.html +++ /dev/null @@ -1,16 +0,0 @@ -{% load i18n %} - - - - - -

{{ status_line }}

-

{% trans "Location:" %} {{ redirect_to }}

-

- {% trans "The Django Debug Toolbar has intercepted a redirect to the above URL for debug viewing purposes. You can click the above link to continue with the redirect as normal." %} -

- - - diff --git a/theme/manager.py b/theme/manager.py index 48fb19f6..f764c62c 100644 --- a/theme/manager.py +++ b/theme/manager.py @@ -38,23 +38,7 @@ class ThemeActiveManager(TranslationManager): themes = list(self.language().filter(id__in=themes_id)) cache.set(key, themes, 300) return themes - """ - def expo_themes_with_count(self): - lang = translation.get_language() - key = 'used_expo_themes_count_%s'%lang - cached_themes = cache.get(key) - if cached_themes: - return cached_themes - else: - from exposition.models import Exposition - sql = {'expo_count': 'SELECT COUNT(*) FROM exposition_exposition_theme WHERE exposition_exposition_theme.theme_id = theme_theme.id'} - # id of unique cities - themes_id = [item['theme'] for item in Exposition.objects.values('theme').distinct()] - themes = list(self.language().filter(id__in=themes_id).extra(select=sql)) - cache.set(key, themes, 300) - return themes - """ def expo_themes_with_count(self): lang = translation.get_language() key = 'used_expo_themes_count_%s'%lang @@ -118,10 +102,9 @@ class TagActiveManager(TranslationManager): cache.set(key, tags, 300) return tags - def conference_tags(self): lang = translation.get_language() - key = 'used_conference_tags_count_%s'%lang + key = 'used_conference_tags_%s'%lang cached_tags = cache.get(key) if cached_tags: return cached_tags diff --git a/theme/models.py b/theme/models.py index dd01de1c..7a8e85c1 100644 --- a/theme/models.py +++ b/theme/models.py @@ -14,7 +14,6 @@ from functions.models_methods import ExpoManager from manager import TagActiveManager, ThemeActiveManager - class Theme(TranslatableModel): """ Create Theme model