2018-11-01 17:30:18 +01:00
|
|
|
from typing import Any, Dict, List, Set
|
2017-08-24 12:26:55 +02:00
|
|
|
|
2014-11-13 22:23:16 +01:00
|
|
|
from django.apps import AppConfig
|
2017-08-24 12:26:55 +02:00
|
|
|
from mypy_extensions import TypedDict
|
2014-11-13 22:23:16 +01:00
|
|
|
|
2017-08-30 00:07:54 +02:00
|
|
|
from ..utils.projector import register_projector_elements
|
2017-03-06 16:34:20 +01:00
|
|
|
|
2014-11-13 22:23:16 +01:00
|
|
|
|
2015-07-01 17:48:41 +02:00
|
|
|
class AssignmentsAppConfig(AppConfig):
|
2015-03-26 05:36:10 +01:00
|
|
|
name = 'openslides.assignments'
|
|
|
|
verbose_name = 'OpenSlides Assignments'
|
2015-07-01 17:48:41 +02:00
|
|
|
angular_site_module = True
|
|
|
|
angular_projector_module = True
|
2014-11-13 22:23:16 +01:00
|
|
|
|
|
|
|
def ready(self):
|
|
|
|
# Import all required stuff.
|
2018-11-01 17:30:18 +01:00
|
|
|
from ..core.signals import permission_change
|
2018-11-05 09:04:41 +01:00
|
|
|
from ..utils.access_permissions import required_user
|
2017-08-30 00:07:54 +02:00
|
|
|
from ..utils.rest_api import router
|
2018-11-05 09:04:41 +01:00
|
|
|
from . import serializers # noqa
|
2017-08-30 00:07:54 +02:00
|
|
|
from .projector import get_projector_elements
|
2018-11-01 17:30:18 +01:00
|
|
|
from .signals import get_permission_change_data
|
2015-06-14 23:26:06 +02:00
|
|
|
from .views import AssignmentViewSet, AssignmentPollViewSet
|
2014-11-13 22:23:16 +01:00
|
|
|
|
2018-09-10 08:15:31 +02:00
|
|
|
# Define projector elements.
|
2017-08-30 00:07:54 +02:00
|
|
|
register_projector_elements(get_projector_elements())
|
2014-11-13 22:23:16 +01:00
|
|
|
|
2017-02-21 09:34:24 +01:00
|
|
|
# Connect signals.
|
|
|
|
permission_change.connect(
|
|
|
|
get_permission_change_data,
|
2017-03-06 16:34:20 +01:00
|
|
|
dispatch_uid='assignments_get_permission_change_data')
|
2017-02-21 09:34:24 +01:00
|
|
|
|
2015-01-17 14:25:05 +01:00
|
|
|
# Register viewsets.
|
2016-02-11 22:58:32 +01:00
|
|
|
router.register(self.get_model('Assignment').get_collection_string(), AssignmentViewSet)
|
2015-11-28 00:27:14 +01:00
|
|
|
router.register('assignments/poll', AssignmentPollViewSet)
|
2017-01-14 12:29:42 +01:00
|
|
|
|
2018-11-01 17:30:18 +01:00
|
|
|
# Register required_users
|
|
|
|
required_user.add_collection_string(self.get_model('Assignment').get_collection_string(), required_users)
|
|
|
|
|
2018-09-10 08:15:31 +02:00
|
|
|
def get_config_variables(self):
|
|
|
|
from .config_variables import get_config_variables
|
|
|
|
return get_config_variables()
|
|
|
|
|
2017-01-14 12:29:42 +01:00
|
|
|
def get_startup_elements(self):
|
2017-03-06 16:34:20 +01:00
|
|
|
"""
|
2018-07-09 23:22:26 +02:00
|
|
|
Yields all Cachables required on startup i. e. opening the websocket
|
2017-03-06 16:34:20 +01:00
|
|
|
connection.
|
|
|
|
"""
|
2018-07-09 23:22:26 +02:00
|
|
|
yield self.get_model('Assignment')
|
2017-01-20 10:23:14 +01:00
|
|
|
|
|
|
|
def get_angular_constants(self):
|
|
|
|
assignment = self.get_model('Assignment')
|
2018-08-29 15:49:44 +02:00
|
|
|
Item = TypedDict('Item', {'value': int, 'display_name': str})
|
|
|
|
phases: List[Item] = []
|
2017-01-20 10:23:14 +01:00
|
|
|
for phase in assignment.PHASES:
|
2018-08-29 15:49:44 +02:00
|
|
|
phases.append({
|
2017-01-20 10:23:14 +01:00
|
|
|
'value': phase[0],
|
|
|
|
'display_name': phase[1],
|
|
|
|
})
|
2018-08-29 15:49:44 +02:00
|
|
|
return {'AssignmentPhases': phases}
|
2018-11-01 17:30:18 +01:00
|
|
|
|
|
|
|
|
|
|
|
def required_users(element: Dict[str, Any]) -> Set[int]:
|
|
|
|
"""
|
|
|
|
Returns all user ids that are displayed as candidates (including poll
|
|
|
|
options) in the assignment element.
|
|
|
|
"""
|
|
|
|
candidates = set(related_user['user_id'] for related_user in element['assignment_related_users'])
|
|
|
|
for poll in element['polls']:
|
|
|
|
candidates.update(option['candidate_id'] for option in poll['options'])
|
|
|
|
return candidates
|