diff --git a/src/backend/app/organisations/organisation_deps.py b/src/backend/app/organisations/organisation_deps.py index cf3b81351e..6db119e028 100644 --- a/src/backend/app/organisations/organisation_deps.py +++ b/src/backend/app/organisations/organisation_deps.py @@ -85,9 +85,9 @@ async def get_org_odk_creds( ) return central_schemas.ODKCentralDecrypted( - odk_central_url=org.odk_central_url, - odk_central_user=org.odk_central_user, - odk_central_password=org.odk_central_password, + odk_central_url=url, + odk_central_user=user, + odk_central_password=password, ) diff --git a/src/backend/app/organisations/organisation_schemas.py b/src/backend/app/organisations/organisation_schemas.py index cc8f86581d..d32e3a8aff 100644 --- a/src/backend/app/organisations/organisation_schemas.py +++ b/src/backend/app/organisations/organisation_schemas.py @@ -79,20 +79,16 @@ def parse_organisation_input( The parsed data is returned as an OrganisationIn instance, with the ODKCentralIn fields merged in. """ - odk_central_data = ODKCentralIn( - odk_central_url=odk_central_url, - odk_central_user=odk_central_user, - odk_central_password=odk_central_password, - ) - org_data = OrganisationUpdate( + return OrganisationUpdate( name=name, slug=slug, created_by=created_by, community_type=community_type, type=type, - **odk_central_data.dict(exclude_unset=True), + odk_central_url=odk_central_url, + odk_central_user=odk_central_user, + odk_central_password=odk_central_password, ) - return org_data class OrganisationOut(BaseModel): diff --git a/src/backend/app/projects/project_schemas.py b/src/backend/app/projects/project_schemas.py index 7e7aa8676a..9eba15b46e 100644 --- a/src/backend/app/projects/project_schemas.py +++ b/src/backend/app/projects/project_schemas.py @@ -239,6 +239,7 @@ class ProjectSummary(BaseModel): tasks_mapped: Optional[int] = None tasks_validated: Optional[int] = None tasks_bad: Optional[int] = None + organisation_logo: Optional[str] = None class PaginationInfo(BaseModel): diff --git a/src/frontend/src/api/Project.ts b/src/frontend/src/api/Project.ts index ac14e5f84f..ab2e46d60e 100755 --- a/src/frontend/src/api/Project.ts +++ b/src/frontend/src/api/Project.ts @@ -48,6 +48,7 @@ export const ProjectById = (projectId: string) => { custom_tms_url: projectResp?.custom_tms_url, organisation_id: projectResp?.organisation_id, organisation_logo: projectResp?.organisation_logo, + organisation_name: projectResp?.organisation_name, created_at: projectResp?.created_at, }), ); diff --git a/src/frontend/src/api/Submission.ts b/src/frontend/src/api/Submission.ts index e1a05122ec..d5d2f1e838 100644 --- a/src/frontend/src/api/Submission.ts +++ b/src/frontend/src/api/Submission.ts @@ -3,6 +3,7 @@ import { SubmissionActions } from '@/store/slices/SubmissionSlice'; export const SubmissionService: Function = (url: string) => { return async (dispatch) => { + dispatch(SubmissionActions.SetSubmissionDetails(null)); dispatch(SubmissionActions.SetSubmissionDetailsLoading(true)); const getSubmissionDetails = async (url: string) => { try { diff --git a/src/frontend/src/components/ProjectDetailsV2/ProjectInfo.tsx b/src/frontend/src/components/ProjectDetailsV2/ProjectInfo.tsx index f55b491c88..bf68787afc 100644 --- a/src/frontend/src/components/ProjectDetailsV2/ProjectInfo.tsx +++ b/src/frontend/src/components/ProjectDetailsV2/ProjectInfo.tsx @@ -106,6 +106,7 @@ const ProjectInfo: React.FC = () => { alt="Organization Photo" /> +
{projectInfo?.organisation_name}
)} diff --git a/src/frontend/src/components/ProjectSubmissions/SubmissionsTable.tsx b/src/frontend/src/components/ProjectSubmissions/SubmissionsTable.tsx index 48b43bce87..52edfe47bb 100644 --- a/src/frontend/src/components/ProjectSubmissions/SubmissionsTable.tsx +++ b/src/frontend/src/components/ProjectSubmissions/SubmissionsTable.tsx @@ -464,7 +464,7 @@ const SubmissionsTable = ({ toggleView }) => { headerClassName="updatedHeader !fmtm-sticky fmtm-right-0 fmtm-shadow-[-10px_0px_20px_0px_rgba(0,0,0,0.1)] fmtm-text-center" rowClassName="updatedRow !fmtm-sticky fmtm-right-0 fmtm-bg-white fmtm-shadow-[-10px_0px_20px_0px_rgba(0,0,0,0.1)]" dataFormat={(row) => { - const taskUid = taskList?.find((task) => task?.id == row?.task_id)?.id; + const taskUid = taskList?.find((task) => task?.index == row?.task_id)?.id; return ({geojsonFile?.name}
- //- // *The supported file formats are zipped shapefile, geojson or kml files. - //
- //- // Total Area: 234 sq.km - //
- //