diff --git a/src/dispatch/incident/models.py b/src/dispatch/incident/models.py index 4b2ee2d5b3d4..75b5dbb77036 100644 --- a/src/dispatch/incident/models.py +++ b/src/dispatch/incident/models.py @@ -285,6 +285,7 @@ def description_required(cls, v): class IncidentCreate(IncidentBase): commander: Optional[ParticipantUpdate] + commander_email: Optional[str] incident_priority: Optional[IncidentPriorityCreate] incident_severity: Optional[IncidentSeverityCreate] incident_type: Optional[IncidentTypeCreate] diff --git a/src/dispatch/incident/service.py b/src/dispatch/incident/service.py index c7838fd30bb5..6baeb138fb34 100644 --- a/src/dispatch/incident/service.py +++ b/src/dispatch/incident/service.py @@ -224,7 +224,9 @@ def create(*, db_session, incident_in: IncidentCreate) -> Incident: # add commander commander_email = commander_service_id = None - if incident_in.commander: + if incident_in.commander_email: + commander_email = incident_in.commander_email + elif incident_in.commander: commander_email = incident_in.commander.individual.email else: commander_email, commander_service_id = resolve_and_associate_role( diff --git a/src/dispatch/static/dispatch/src/incident/ReportSubmissionCard.vue b/src/dispatch/static/dispatch/src/incident/ReportSubmissionCard.vue index 066ea2ae2354..bc6fe6c1dacc 100644 --- a/src/dispatch/static/dispatch/src/incident/ReportSubmissionCard.vue +++ b/src/dispatch/static/dispatch/src/incident/ReportSubmissionCard.vue @@ -68,6 +68,17 @@ + + + @@ -105,6 +116,7 @@ import IncidentPrioritySelect from "@/incident/priority/IncidentPrioritySelect.v import IncidentTypeSelect from "@/incident/type/IncidentTypeSelect.vue" import ProjectSelect from "@/project/ProjectSelect.vue" import TagFilterAutoComplete from "@/tag/TagFilterAutoComplete.vue" +import ParticipantSelect from "@/components/ParticipantSelect.vue" export default { setup() { @@ -119,12 +131,20 @@ export default { IncidentPrioritySelect, ProjectSelect, TagFilterAutoComplete, + ParticipantSelect, }, data() { return { isSubmitted: false, project_faq: null, + local_commander: null, + only_one: (value) => { + if (value && value.length > 1) { + return "Only one is allowed" + } + return true + }, } }, @@ -132,7 +152,7 @@ export default { ...mapFields("incident", [ "selected.incident_priority", "selected.incident_type", - "selected.commander", + "selected.commander_email", "selected.title", "selected.tags", "selected.description", @@ -248,9 +268,11 @@ export default { vm.incident_type, vm.title, vm.description, + vm.local_commander, vm.tags, ], () => { + if (Array.isArray(this.local_commander)) this.commander_email = this.local_commander[0].individual.email var queryParams = { project: this.project ? this.project.name : null, incident_priority: this.incident_priority ? this.incident_priority.name : null, @@ -258,6 +280,7 @@ export default { title: this.title, description: this.description, tag: this.tags ? this.tags.map((tag) => tag.name) : null, + commander_email: this.commander_email, } Object.keys(queryParams).forEach((key) => (queryParams[key] ? {} : delete queryParams[key])) router