Skip to content

Commit

Permalink
Fix lint issues
Browse files Browse the repository at this point in the history
  • Loading branch information
peterMuriuki committed Feb 15, 2024
1 parent 2384382 commit 5a7ed3c
Show file tree
Hide file tree
Showing 6 changed files with 249 additions and 198 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,11 @@ import { MoreOutlined } from '@ant-design/icons';
import { ADD_EDIT_COMMODITY_URL, groupResourceType, listResourceType } from '../../../constants';
import { Link } from 'react-router-dom';
import { useTranslation } from '../../../mls';
import { BaseListView, BaseListViewProps, TableData } from '../../BaseComponents/BaseGroupsListView';
import {
BaseListView,
BaseListViewProps,
TableData,
} from '../../BaseComponents/BaseGroupsListView';
import { TFunction } from '@opensrp/i18n';
import {
FHIRServiceClass,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,14 @@ import { MoreOutlined } from '@ant-design/icons';
import { ADD_EDIT_COMMODITY_URL } from '../../../constants';
import { Link } from 'react-router-dom';
import { useTranslation } from '../../../mls';
import { BaseListView, BaseListViewProps, TableData } from '../../BaseComponents/BaseGroupsListView';
import { TFunction } from '@opensrp/i18n';
import {
useSearchParams,
viewDetailsQuery,
} from '@opensrp/react-utils';
import {
supplyMgSnomedCode,
snomedCodeSystem,
} from '../../../helpers/utils';
BaseListView,
BaseListViewProps,
TableData,
} from '../../BaseComponents/BaseGroupsListView';
import { TFunction } from '@opensrp/i18n';
import { useSearchParams, viewDetailsQuery } from '@opensrp/react-utils';
import { supplyMgSnomedCode, snomedCodeSystem } from '../../../helpers/utils';
import { useUserRole } from '@opensrp/rbac';
import { ViewDetailsWrapper } from './ViewDetails';

Expand Down Expand Up @@ -60,26 +58,27 @@ export const EusmCommodityList = (props: GroupListProps) => {

const getColumns = (t: TFunction) => [
{
title: t("Material Number"),
dataIndex: "materialNumber" as const,
key: "materialNumber" as const,
title: t('Material Number'),
dataIndex: 'materialNumber' as const,
key: 'materialNumber' as const,
},
{
title: t('Name'),
dataIndex: 'name' as const,
key: 'name' as const,
},
{
title: t("Attractive Item"),
dataIndex: "attractiveItem" as const,
key: "attractiveItem" as const,
title: t('Attractive Item'),
dataIndex: 'attractiveItem' as const,
key: 'attractiveItem' as const,
render: (value: boolean) => <div>{value ? t('Yes') : t('No')}</div>,
},
{
title: t('type'),
dataIndex: 'type' as const,
key: 'type' as const,
}, {
},
{
title: t('Active'),
dataIndex: 'active' as const,
key: 'active' as const,
Expand Down Expand Up @@ -118,7 +117,9 @@ export const EusmCommodityList = (props: GroupListProps) => {
code: `${snomedCodeSystem}|${supplyMgSnomedCode}`,
'_has:List:item:_id': listId,
},
viewDetailsRender: (fhirBaseURL, resourceId) => <ViewDetailsWrapper fhirBaseURL={fhirBaseURL} resourceId={resourceId!} />
viewDetailsRender: (fhirBaseURL, resourceId) => (
<ViewDetailsWrapper fhirBaseURL={fhirBaseURL} resourceId={resourceId} />
),
};

return <BaseListView {...baseListViewProps} />;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,15 @@ import { get } from 'lodash';
import { IGroup } from '@smile-cdr/fhirts/dist/FHIR-R4/interfaces/IGroup';
import { useTranslation } from '../../../mls';
import { Identifier } from '@smile-cdr/fhirts/dist/FHIR-R4/classes/identifier';
import { accountabilityCharacteristicCoding, appropriateUsageCharacteristicCoding, attractiveCharacteristicCoding, availabilityCharacteristicCoding, conditionCharacteristicCoding, getCharacteristicWithCoding, useGetGroupAndBinary } from '../../../helpers/utils';
import {
accountabilityCharacteristicCoding,
appropriateUsageCharacteristicCoding,
attractiveCharacteristicCoding,
availabilityCharacteristicCoding,
conditionCharacteristicCoding,
getCharacteristicWithCoding,
useGetGroupAndBinary,
} from '../../../helpers/utils';
import { IBinary } from '@smile-cdr/fhirts/dist/FHIR-R4/interfaces/IBinary';

/** typings for the view details component */
Expand All @@ -22,10 +30,7 @@ export interface EusmViewDetailsProps {
fhirBaseURL: string;
}

export type ViewDetailsWrapperProps = Pick<
EusmViewDetailsProps,
'fhirBaseURL'
> & {
export type ViewDetailsWrapperProps = Pick<EusmViewDetailsProps, 'fhirBaseURL'> & {
resourceId?: string;
};

Expand All @@ -35,10 +40,13 @@ export type ViewDetailsWrapperProps = Pick<
* @param props - detail view component props
*/
export const EusmViewDetails = (props: EusmViewDetailsProps) => {
const { resourceId, fhirBaseURL, } = props;
const { resourceId, fhirBaseURL } = props;
const { t } = useTranslation();

const { groupQuery: { data, isLoading, error }, binaryQuery } = useGetGroupAndBinary(resourceId, fhirBaseURL)
const {
groupQuery: { data, isLoading, error },
binaryQuery,
} = useGetGroupAndBinary(resourceId, fhirBaseURL);

if (isLoading) {
return <Spin size="large" className="custom-spinner" />;
Expand All @@ -49,7 +57,8 @@ export const EusmViewDetails = (props: EusmViewDetailsProps) => {
}

const group = data as Group;
const { accountabilityPeriod,
const {
accountabilityPeriod,
appropriateUsage,
condition,
availability,
Expand All @@ -69,24 +78,29 @@ export const EusmViewDetails = (props: EusmViewDetailsProps) => {
[t('Is it in good condition')]: condition,
[t('Is it being used appropriately')]: appropriateUsage,
[t('accountability period(in months)')]: accountabilityPeriod,

};

return <Space direction="vertical">
<div>
{photoDataUrl ? <Image data-testid="product-img" src={photoDataUrl} alt="product photo" /> : fallbackImage}
</div>
{Object.entries(keyValues).map(([key, value]) => {
const props = {
[key]: value,
};
return value ? (
<div key={key} data-testid="key-value">
<SingleKeyNestedValue {...props} />
</div>
) : null;
})}
</Space>;
return (
<Space direction="vertical">
<div>
{photoDataUrl ? (
<Image data-testid="product-img" src={photoDataUrl} alt="product photo" />
) : (
fallbackImage
)}
</div>
{Object.entries(keyValues).map(([key, value]) => {
const props = {
[key]: value,
};
return value ? (
<div key={key} data-testid="key-value">
<SingleKeyNestedValue {...props} />
</div>
) : null;
})}
</Space>
);
};

/**
Expand Down Expand Up @@ -114,51 +128,54 @@ export const ViewDetailsWrapper = (props: ViewDetailsWrapperProps) => {
onClick={() => removeParam(viewDetailsQuery)}
/>
</div>
<EusmViewDetails
resourceId={resourceId}
fhirBaseURL={fhirBaseURL}
/>
<EusmViewDetails resourceId={resourceId} fhirBaseURL={fhirBaseURL} />
</Col>
);
};


const fallbackImage = <Image
data-testid="fallback-img"
width={200}
height={200}
src="error"
fallback=""
/>

const fallbackImage = (
<Image
data-testid="fallback-img"
width={200}
height={200}
src="error"
fallback=""
/>
);

/**
* parse a Group to object we can easily consume in Table layout
*
* @param obj - the organization resource object
* @param binary - image binary
*/
export const parseEusmCommodity = (obj: IGroup, binary?: IBinary) => {
const {
name,
active,
id,
type,
identifier: rawIdentifier,
} = obj;
const { name, active, id, type, identifier: rawIdentifier } = obj;
const identifierObj = getObjLike(
rawIdentifier,
'use',
IdentifierUseCodes.OFFICIAL
) as Identifier[];
const identifier = get(identifierObj, '0.value');
const characteristic = obj.characteristic ?? []
const accountabilityPeriod = getCharacteristicWithCoding(characteristic, accountabilityCharacteristicCoding)?.valueQuantity?.value
const appropriateUsage = getCharacteristicWithCoding(characteristic, appropriateUsageCharacteristicCoding)?.valueCodeableConcept?.text
const condition = getCharacteristicWithCoding(characteristic, conditionCharacteristicCoding)?.valueCodeableConcept?.text
const availability = getCharacteristicWithCoding(characteristic, availabilityCharacteristicCoding)?.valueCodeableConcept?.text
const attractive = getCharacteristicWithCoding(characteristic, attractiveCharacteristicCoding)?.valueBoolean
console.log({binary})
const photoDataUrl = binary ? `data:${binary.contentType};base64,${binary.data}` : undefined
const characteristic = obj.characteristic ?? [];
const accountabilityPeriod = getCharacteristicWithCoding(
characteristic,
accountabilityCharacteristicCoding
)?.valueQuantity?.value;
const appropriateUsage = getCharacteristicWithCoding(
characteristic,
appropriateUsageCharacteristicCoding
)?.valueCodeableConcept?.text;
const condition = getCharacteristicWithCoding(characteristic, conditionCharacteristicCoding)
?.valueCodeableConcept?.text;
const availability = getCharacteristicWithCoding(characteristic, availabilityCharacteristicCoding)
?.valueCodeableConcept?.text;
const attractive = getCharacteristicWithCoding(
characteristic,
attractiveCharacteristicCoding
)?.valueBoolean;

const photoDataUrl = binary ? `data:${binary.contentType};base64,${binary.data}` : undefined;

return {
accountabilityPeriod,
Expand Down
Loading

0 comments on commit 5a7ed3c

Please sign in to comment.