From d1aa1abb39a5fa2f9fe4f5cbd9dc4366ffe12636 Mon Sep 17 00:00:00 2001 From: Tushar Vyas <89837102+Vayras@users.noreply.github.com> Date: Wed, 24 Jan 2024 10:35:21 +0530 Subject: [PATCH] get org values from backend --- frontend/app/src/people/main/FocusView.tsx | 78 +++++++++++++++++----- 1 file changed, 61 insertions(+), 17 deletions(-) diff --git a/frontend/app/src/people/main/FocusView.tsx b/frontend/app/src/people/main/FocusView.tsx index 426591828..dd60eb19b 100644 --- a/frontend/app/src/people/main/FocusView.tsx +++ b/frontend/app/src/people/main/FocusView.tsx @@ -4,7 +4,6 @@ import { cloneDeep } from 'lodash'; import { observer } from 'mobx-react-lite'; import { FocusViewProps } from 'people/interfaces'; import { EuiGlobalToastList } from '@elastic/eui'; -import { Organization } from 'store/main'; import { Box } from '@mui/system'; import { useStores } from '../../store'; import Form from '../../components/form/bounty'; @@ -17,11 +16,7 @@ import { import WantedSummary from '../widgetViews/summaries/WantedSummary'; import { useIsMobile } from '../../hooks'; import { dynamicSchemasByType } from '../../components/form/schema'; -import { - convertLocaleToNumber, - extractRepoAndIssueFromIssueUrl, - toCapitalize -} from '../../helpers'; +import { convertLocaleToNumber, extractRepoAndIssueFromIssueUrl } from '../../helpers'; import { B, BWrap } from './style'; // selected bounty popup window @@ -60,12 +55,52 @@ function FocusedView(props: FocusViewProps) { const isTorSave = canEdit && main.isTorSave(); - const userOrganizations = main.dropDownOrganizations.length - ? main.dropDownOrganizations.map((org: Organization) => ({ - label: toCapitalize(org.name), - value: org.uuid - })) - : []; + //this code block can be used to get the real org values + // const [userOrganizations,setUserOrganizations] = useState({}); + // const getOrg =async()=>{ + // const response = await main.getOrganizations() + // const mappedResponse = response.map((org: Organization) => ({ + // label: org.name, + // value: org.uuid + // })) + // setUserOrganizations(mappedResponse) + // } + // getOrg() + + const [orgName, setOrgName] = useState([]); + const getOrganization = async () => { + const urlParts = window.location.href.split('/bounties/'); + const uuid = urlParts.length > 1 ? urlParts[1] : null; + + if (!uuid) { + console.error('No UUID found in the URL'); + return; + } + + try { + const response = await main.getUserOrganizationByUuid(uuid); + console.log(response, 'res'); + + if (response && response.uuid && response.name) { + // Creating an array with an object containing label and value + const orgDetails = [ + { + label: response.name, + value: response.uuid + } + ]; + setOrgName(orgDetails); + } else { + console.error('Response does not have the expected structure'); + } + } catch (error) { + console.error('Error fetching organization:', error); + } + }; + + useEffect(() => { + getOrganization(); + }); function isNotHttps(url: string | undefined) { if (main.isTorSave() || url?.startsWith('http://')) { @@ -266,8 +301,20 @@ function FocusedView(props: FocusViewProps) { props?.ReCallBounties(); } + // set user organizations + if (config?.schema?.[0]?.['defaultSchema']?.[0]?.['options']) { + config.schema[0]['defaultSchema'][0]['options'] = orgName; + } + let initialValues: any = {}; + let altInitialValue = {}; + if (window.location.href.includes('/org')) { + altInitialValue = { + org_uuid: `"ck95pe04nncjnaefo08g"` || orgName[0]?.value + }; + } + const personInfo = canEdit ? ui.meInfo : person; // set initials here @@ -313,6 +360,8 @@ function FocusedView(props: FocusViewProps) { initialValues[s.name] = wanted[s.name]; }); } + } else { + initialValues = altInitialValue; } } @@ -350,11 +399,6 @@ function FocusedView(props: FocusViewProps) { } } - // set user organizations - if (config?.schema?.[0]?.['defaultSchema']?.[0]?.['options']) { - config.schema[0]['defaultSchema'][0]['options'] = userOrganizations; - } - return (