diff --git a/CHANGELOG.md b/CHANGELOG.md index 7b729df4..e8604094 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,15 +8,19 @@ and this project adheres to [Semantic Versioning](http://semver.org/). ### Added - Searching within involvement admin will now search more fields. - A new form field type for person numbers +- Inspection view for Position, showing applicants ### Changed - Switch to the materialize CSS/JS framework. - Election contact e-mail has been moved to the Role model and has been labeled as such. +- Contact information of team members is now available in the Team inspection view. ### Removed - Old migrations in the website app. ### Fixed - Searching for positions within the admin interface will no longer cause an error. -- Allow person numbers to be "T-numbers" +- Allow person numbers to be "T-numbers". - Several instances where dirrty wasn't triggered at the right time. +- Improved queries for loading positions. +- Disallow creating roles outside your team. ## [0.2.0] - 2017-04-07 ### Added diff --git a/website/involvement/rules.py b/website/involvement/rules.py index 6465da4a..2ae660af 100644 --- a/website/involvement/rules.py +++ b/website/involvement/rules.py @@ -90,6 +90,8 @@ def is_past_due(user, application): rules.add_perm('involvement.list_position', is_admin | is_official | is_approval_committee) +rules.add_perm('involvement.inspect_position', is_admin | is_position_official + | is_approval_committee_for) rules.add_perm('involvement.add_position', is_admin | is_official) rules.add_perm('involvement.change_position', is_admin | is_position_official) rules.add_perm('involvement.approve_position', is_admin diff --git a/website/involvement/templates/modeladmin/involvement/position/inspect.html b/website/involvement/templates/modeladmin/involvement/position/inspect.html new file mode 100644 index 00000000..e976fa3e --- /dev/null +++ b/website/involvement/templates/modeladmin/involvement/position/inspect.html @@ -0,0 +1,33 @@ +{% extends 'modeladmin/inspect.html' %} +{% load i18n %} + +{% block fields_output %} +
+
{% trans 'position' %}
+
{{ instance }}
+ +
{% trans 'applications' %}
+
+ +
+
+{% endblock %} \ No newline at end of file diff --git a/website/involvement/wagtail_hooks.py b/website/involvement/wagtail_hooks.py index 6cfcecde..f98bb254 100644 --- a/website/involvement/wagtail_hooks.py +++ b/website/involvement/wagtail_hooks.py @@ -123,6 +123,11 @@ def queryset(self, request, queryset): class PositionPermissionHelper(RulesPermissionHelper): + def user_can_inspect_obj(self, user, obj): + opts = self.opts + codename = get_permission_codename('inspect', opts) + return user.has_perm('%s.%s' % (opts.app_label, codename), obj) + def user_can_approve_obj(self, user, obj): opts = self.opts codename = get_permission_codename('approve', opts) @@ -193,6 +198,7 @@ def get_buttons_for_obj(self, obj, exclude=None, classnames_add=None, obj, exclude=exclude, classnames_add=classnames_add, classnames_exclude=classnames_exclude ) + print(btns) return btns @@ -240,6 +246,7 @@ class PositionAdmin(ModelAdmin): 'role__name_en', 'role__name_sv', 'comment_en', 'comment_sv') list_filter = ('role__team', PositionYearFilter) + inspect_view_enabled = True permission_helper_class = PositionPermissionHelper button_helper_class = PositionButtonHelper create_view_class = PositionCreateView