123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- from .access import create_project_possible, create_task_possible, acc_task
- from django.db.models.functions import Lower
- from django.utils.translation import gettext as _
- from .help import actionbar as actionbar_add_help
- import inspect
- import mycreole
- import patt
- from .search import common_searches
- from themes import empty_entry_parameters, color_icon_url, gray_icon_url
- from users.context import menubar as menubar_users
- from users.context import PROFILE_ENTRY_UID
-
- ATTACHMENT_UID = 'attachment'
- BACK_UID = 'back'
- COMMENTNEW_UID = 'commentnew'
- CREATE_PROJECT_UID = 'create-project'
- CREATE_TASK_UID = 'create-task'
- HELP_UID = 'help'
- PRINTVIEW_UID = 'printview'
- TASKEDIT_UID = 'taskedit'
- VIEW_PROJECTLIST_UID = 'view-projectlist'
- VIEW_TASKLIST_UID = 'view-tasklist'
-
-
- def context_adaption(context, request, **kwargs):
- caller_name = inspect.currentframe().f_back.f_code.co_name
- try:
- context.set_additional_title(kwargs.pop('title'))
- except KeyError:
- pass
- menubar_users(context[context.MENUBAR], request)
- menubar(context, request, caller_name, **kwargs)
- actionbar(context, request, caller_name, **kwargs)
- navigationbar(context, request)
- for key in kwargs:
- context[key] = kwargs[key]
-
-
- def menubar(context, request, caller_name, **kwargs):
- bar = context[context.MENUBAR]
- replace_profile(request, bar)
- add_help_menu(request, bar)
- add_tasklist_menu(request, bar)
- add_filter_submenu(request, bar, VIEW_TASKLIST_UID)
- add_projectlist_menu(request, bar)
- add_printview_menu(request, bar)
- finalise_bar(request, bar)
-
-
- def navigationbar(context, request):
- bar = context[context.NAVIGATIONBAR]
- add_back_menu(request, bar)
- finalise_bar(request, bar)
-
-
- def actionbar(context, request, caller_name, **kwargs):
- bar = context[context.ACTIONBAR]
- if caller_name == 'patt_tasklist':
- if create_task_possible(request.user):
- add_newtask_menu(request, bar, kwargs.get('project_id'))
- elif caller_name == 'patt_projectlist':
- if create_project_possible(request.user):
- add_newproject_menu(request, bar)
- elif caller_name == 'patt_taskview':
- acc = acc_task(kwargs['task'], request.user)
- if acc.modify or acc.modify_limited:
- add_edittask_menu(request, bar, kwargs['task'].id)
- if acc.add_comments:
- add_newcomment_menu(request, bar, kwargs['task'].id)
- add_manageupload_menu(request, bar, kwargs['task'])
- elif caller_name == 'patt_helpview':
- actionbar_add_help(context, request, **kwargs)
- finalise_bar(request, bar)
-
-
- def finalise_bar(request, bar):
- if len(bar) == 0:
- bar.append_entry(*empty_entry_parameters(request))
-
-
- def replace_profile(request, bar):
- try:
- bar.replace_entry(
- PROFILE_ENTRY_UID,
- PROFILE_ENTRY_UID,
- request.user.username,
- color_icon_url(request, 'user.png'),
- patt.url_profile(request),
- False,
- False
- )
- except ValueError:
- pass
-
-
- def add_help_menu(request, bar):
- bar.append_entry(
- HELP_UID,
- _('Help'),
- color_icon_url(request, 'help.png'),
- patt.url_helpview(request, 'main'),
- True,
- False
- )
-
-
- def add_tasklist_menu(request, bar):
- bar.append_entry(
- VIEW_TASKLIST_UID,
- _('Tasklist'),
- color_icon_url(request, 'task.png'),
- patt.url_tasklist(request),
- True,
- patt.is_tasklistview(request)
- )
-
-
- def add_projectlist_menu(request, bar):
- bar.append_entry(
- VIEW_PROJECTLIST_UID,
- _('Projectlist'),
- color_icon_url(request, 'folder.png'),
- patt.url_projectlist(request),
- True,
- patt.is_projectlistview(request)
- )
-
-
- def add_printview_menu(request, bar):
- bar.append_entry(
- PRINTVIEW_UID,
- _('Printview'),
- color_icon_url(request, 'print.png'),
- patt.url_printview(request),
- True,
- patt.is_printview(request)
- )
-
-
- def add_newtask_menu(request, bar, project_id):
- bar.append_entry(
- CREATE_TASK_UID,
- _('New Task'),
- color_icon_url(request, 'plus.png'),
- patt.url_tasknew(request, project_id),
- True,
- False
- )
-
-
- def add_edittask_menu(request, bar, task_id):
- bar.append_entry(
- TASKEDIT_UID,
- _('Edit'),
- color_icon_url(request, 'edit.png'),
- patt.url_taskedit(request, task_id),
- True,
- False
- )
-
-
- def add_newcomment_menu(request, bar, task_id):
- bar.append_entry(
- COMMENTNEW_UID,
- _('Add Comment'),
- color_icon_url(request, 'edit2.png'),
- patt.url_commentnew(request, task_id),
- True,
- False
- )
-
-
- def add_newproject_menu(request, bar):
- bar.append_entry(
- CREATE_PROJECT_UID,
- _('New Project'),
- color_icon_url(request, 'plus.png'),
- patt.url_projectnew(request),
- True,
- False
- )
-
-
- def add_manageupload_menu(request, bar, task):
- bar.append_entry(
- ATTACHMENT_UID,
- _("Attachments"),
- color_icon_url(request, 'upload.png'),
- mycreole.url_manage_uploads(request, task.attachment_target_path),
- True,
- False,
- )
-
-
- def add_back_menu(request, bar):
- bar.append_entry(
- BACK_UID,
- _('Back'),
- gray_icon_url(request, 'back.png'),
- 'javascript:history.back()',
- True,
- False
- )
-
-
- def add_filter_submenu(request, bar, menu_uid):
- bar.append_entry_to_entry(
- menu_uid,
- menu_uid + '-easysearch',
- _('Easysearch'),
- gray_icon_url(request, 'search.png'),
- patt.url_easysearch(request),
- True,
- False
- )
- if patt.get_search_query(request) is not None:
- bar.append_entry_to_entry(
- menu_uid,
- menu_uid + '-save',
- _('Save Search as Filter'),
- gray_icon_url(request, 'save.png'),
- patt.url_filteredit(request),
- True,
- False
- )
- bar.append_entry_to_entry(
- menu_uid,
- menu_uid + '-all',
- _('All Tasks'),
- gray_icon_url(request, 'task.png'),
- patt.url_tasklist(request),
- True,
- False
- )
- cs = common_searches(request)
- for common_filter_id in cs:
- bar.append_entry_to_entry(
- menu_uid,
- menu_uid + '-common',
- _(cs[common_filter_id][0]),
- gray_icon_url(request, 'filter.png'),
- patt.url_tasklist(request, common_filter_id=common_filter_id),
- True,
- False
- )
- for s in request.user.search_set.order_by(Lower('name')):
- active = patt.is_tasklistview(request, s.id)
- if active is True:
- url = patt.url_filteredit(request, s.id)
- else:
- url = patt.url_tasklist(request, user_filter_id=s.id)
- if active:
- icon = 'settings.png'
- else:
- icon = 'favourite.png'
- bar.append_entry_to_entry(
- menu_uid,
- menu_uid + '-sub',
- s.name,
- gray_icon_url(request, icon),
- url,
- True,
- active
- )
|