2018-12-23 11:05:38 +01:00
|
|
|
from typing import Any, Dict
|
2017-08-30 00:07:54 +02:00
|
|
|
|
2019-01-27 13:17:17 +01:00
|
|
|
from ..users.projector import get_user_name
|
|
|
|
from ..utils.projector import (
|
|
|
|
AllData,
|
|
|
|
ProjectorElementException,
|
|
|
|
get_config,
|
|
|
|
register_projector_slide,
|
|
|
|
)
|
2015-06-24 22:11:54 +02:00
|
|
|
|
|
|
|
|
2018-12-23 11:05:38 +01:00
|
|
|
# Important: All functions have to be prune. This means, that thay can only
|
|
|
|
# access the data, that they get as argument and do not have any
|
|
|
|
# side effects. They are called from an async context. So they have
|
|
|
|
# to be fast!
|
2015-06-24 22:11:54 +02:00
|
|
|
|
2016-10-01 20:42:44 +02:00
|
|
|
|
2019-01-19 21:36:30 +01:00
|
|
|
def get_state(
|
|
|
|
all_data: AllData, motion: Dict[str, Any], state_id: int
|
2018-12-23 11:05:38 +01:00
|
|
|
) -> Dict[str, Any]:
|
2019-01-19 21:36:30 +01:00
|
|
|
"""
|
|
|
|
Returns a state element from one motion.
|
|
|
|
|
|
|
|
Returns an error if the state_id does not exist for the workflow in the motion.
|
|
|
|
"""
|
|
|
|
states = all_data["motions/workflow"][motion["workflow_id"]]["states"]
|
|
|
|
for state in states:
|
|
|
|
if state["id"] == state_id:
|
|
|
|
return state
|
2019-01-27 13:17:17 +01:00
|
|
|
raise ProjectorElementException(
|
|
|
|
f"motion {motion['id']} can not be on the state with id {state_id}"
|
|
|
|
)
|
2019-01-19 21:36:30 +01:00
|
|
|
|
|
|
|
|
2019-01-27 13:17:17 +01:00
|
|
|
def motion_slide(all_data: AllData, element: Dict[str, Any]) -> Dict[str, Any]:
|
2016-10-01 20:42:44 +02:00
|
|
|
"""
|
2018-12-23 11:05:38 +01:00
|
|
|
Motion slide.
|
2019-01-19 21:36:30 +01:00
|
|
|
|
|
|
|
The returned dict can contain the following fields:
|
|
|
|
* identifier
|
|
|
|
* title
|
|
|
|
* text
|
|
|
|
* amendment_paragraphs
|
|
|
|
* is_child
|
|
|
|
* show_meta_box
|
|
|
|
* reason
|
|
|
|
* modified_final_version
|
|
|
|
* state
|
|
|
|
* state_extension
|
|
|
|
* recommendation
|
|
|
|
* recommendation_extension
|
|
|
|
* submitter
|
|
|
|
* poll
|
2016-10-01 20:42:44 +02:00
|
|
|
"""
|
2019-01-19 21:36:30 +01:00
|
|
|
mode = element.get("mode")
|
|
|
|
motion_id = element.get("id")
|
2019-01-06 16:22:33 +01:00
|
|
|
|
2019-01-19 21:36:30 +01:00
|
|
|
if motion_id is None:
|
|
|
|
return {"error": "id is required for motion slide"}
|
2016-10-01 20:42:44 +02:00
|
|
|
|
2019-01-19 21:36:30 +01:00
|
|
|
try:
|
|
|
|
motion = all_data["motions/motion"][motion_id]
|
|
|
|
except KeyError:
|
2019-01-27 13:17:17 +01:00
|
|
|
raise ProjectorElementException(f"motion with id {motion_id} does not exist")
|
2019-01-19 21:36:30 +01:00
|
|
|
|
|
|
|
show_meta_box = not get_config(all_data, "motions_disable_sidebox_on_projector")
|
|
|
|
|
|
|
|
return_value = {
|
|
|
|
"identifier": motion["identifier"],
|
|
|
|
"title": motion["title"],
|
|
|
|
"text": motion["text"],
|
|
|
|
"amendment_paragraphs": motion["amendment_paragraphs"],
|
|
|
|
"is_child": bool(motion["parent_id"]),
|
|
|
|
"show_meta_box": show_meta_box,
|
|
|
|
}
|
|
|
|
|
|
|
|
if not get_config(all_data, "motions_disable_reason_on_projector"):
|
|
|
|
return_value["reason"] = motion["reason"]
|
2019-01-27 13:17:17 +01:00
|
|
|
|
2019-01-19 21:36:30 +01:00
|
|
|
if mode == "final":
|
|
|
|
return_value["modified_final_version"] = motion["modified_final_version"]
|
|
|
|
|
|
|
|
if show_meta_box:
|
|
|
|
state = get_state(all_data, motion, motion["state_id"])
|
|
|
|
return_value["state"] = state["name"]
|
2019-01-27 13:17:17 +01:00
|
|
|
if state["show_state_extension_field"]:
|
|
|
|
return_value["state_extension"] = motion["state_extension"]
|
2019-01-19 21:36:30 +01:00
|
|
|
|
|
|
|
if (
|
|
|
|
not get_config(all_data, "motions_disable_recommendation_on_projector")
|
|
|
|
and motion["recommendation_id"]
|
|
|
|
):
|
2019-01-27 13:17:17 +01:00
|
|
|
recommendation_state = get_state(
|
|
|
|
all_data, motion, motion["recommendation_id"]
|
|
|
|
)
|
|
|
|
return_value["recommendation"] = recommendation_state[
|
|
|
|
"recommendation_label"
|
2019-01-19 21:36:30 +01:00
|
|
|
]
|
2019-01-27 13:17:17 +01:00
|
|
|
if recommendation_state["show_recommendation_extension_field"]:
|
|
|
|
return_value["recommendation_extension"] = motion[
|
|
|
|
"recommendation_extension"
|
|
|
|
]
|
|
|
|
|
|
|
|
return_value["change_recommendations"] = motion["change_recommendations"]
|
2019-01-19 21:36:30 +01:00
|
|
|
|
|
|
|
return_value["submitter"] = [
|
2019-01-27 13:17:17 +01:00
|
|
|
get_user_name(all_data, submitter["user_id"])
|
|
|
|
for submitter in sorted(
|
|
|
|
motion["submitters"], key=lambda submitter: submitter["weight"]
|
|
|
|
)
|
2019-01-19 21:36:30 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
for poll in motion["polls"][::-1]:
|
|
|
|
if poll["has_votes"]:
|
|
|
|
return_value["poll"] = {
|
|
|
|
"yes": poll["yes"],
|
|
|
|
"no": poll["no"],
|
|
|
|
"abstain": poll["abstain"],
|
|
|
|
}
|
|
|
|
break
|
|
|
|
|
|
|
|
return return_value
|
|
|
|
|
|
|
|
|
2019-01-27 13:17:17 +01:00
|
|
|
def motion_block_slide(all_data: AllData, element: Dict[str, Any]) -> Dict[str, Any]:
|
2018-12-23 11:05:38 +01:00
|
|
|
"""
|
|
|
|
Motion slide.
|
|
|
|
"""
|
|
|
|
return {"error": "TODO"}
|
2017-08-30 00:07:54 +02:00
|
|
|
|
|
|
|
|
2019-01-27 13:17:17 +01:00
|
|
|
def register_projector_slides() -> None:
|
|
|
|
register_projector_slide("motions/motion", motion_slide)
|
|
|
|
register_projector_slide("motions/motion-block", motion_block_slide)
|