Compare commits
2 Commits
bisone
...
bisone-int
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
63b9bc5ffc | ||
|
|
f4dea5a9d6 |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -12,6 +12,7 @@ coverage/
|
|||||||
.yarn/
|
.yarn/
|
||||||
.nx/
|
.nx/
|
||||||
addOns/yarn.lock
|
addOns/yarn.lock
|
||||||
|
**.zip
|
||||||
|
|
||||||
# YALC (for Erik)
|
# YALC (for Erik)
|
||||||
.yalc
|
.yalc
|
||||||
|
|||||||
@@ -6,7 +6,9 @@ function OHIFCornerstonePdfViewport({ displaySets }) {
|
|||||||
var [url, setUrl] = useState(null);
|
var [url, setUrl] = useState(null);
|
||||||
|
|
||||||
const sopInstanceUid = displaySets[0].SOPInstanceUID;
|
const sopInstanceUid = displaySets[0].SOPInstanceUID;
|
||||||
url = `http://128.199.154.150:8080/rid/IHERetrieveDocument?requestType=DOCUMENT&documentUID=${sopInstanceUid}&preferredContentType=application%2Fpdf`;
|
url = `http://${window.config.pacs_document_host}:${window.config.pacs_document_port}/rid/IHERetrieveDocument?requestType=DOCUMENT&documentUID=${sopInstanceUid}&preferredContentType=application%2Fpdf`;
|
||||||
|
|
||||||
|
// console.log('PDF URL:', url);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
document.body.addEventListener('drag', makePdfDropTarget);
|
document.body.addEventListener('drag', makePdfDropTarget);
|
||||||
@@ -33,13 +35,15 @@ function OHIFCornerstonePdfViewport({ displaySets }) {
|
|||||||
|
|
||||||
const { pdfUrl } = displaySets[0];
|
const { pdfUrl } = displaySets[0];
|
||||||
|
|
||||||
useEffect(() => {
|
// console.log('Dicomweb PDF URL:', pdfUrl);
|
||||||
const load = async () => {
|
|
||||||
setUrl(await pdfUrl);
|
|
||||||
};
|
|
||||||
|
|
||||||
load();
|
// useEffect(() => {
|
||||||
}, [pdfUrl]);
|
// const load = async () => {
|
||||||
|
// setUrl(await pdfUrl);
|
||||||
|
// };
|
||||||
|
|
||||||
|
// load();
|
||||||
|
// }, [pdfUrl]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
@@ -50,9 +54,7 @@ function OHIFCornerstonePdfViewport({ displaySets }) {
|
|||||||
data={url}
|
data={url}
|
||||||
type="application/pdf"
|
type="application/pdf"
|
||||||
className={style}
|
className={style}
|
||||||
>
|
></object>
|
||||||
<div>No online PDF viewer installed</div>
|
|
||||||
</object>
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,8 +24,8 @@ window.config = {
|
|||||||
prefetch: 25,
|
prefetch: 25,
|
||||||
},
|
},
|
||||||
expertise: false, //* Tambahan untuk enable expertise (CustomizableViewportOverlay)
|
expertise: false, //* Tambahan untuk enable expertise (CustomizableViewportOverlay)
|
||||||
expertise_host: `http://192.168.1.29`, //* Tambahan untuk fetch data Expertise)
|
expertise_host: `https://devone.aplikasi.web.id/one-api/mockup/pacsmwl/Workorder/get_dummy_expertise`, //* Tambahan untuk fetch data Expertise)
|
||||||
pacs_document_host: `192.168.1.29`,
|
pacs_document_host: `152.42.173.210`,
|
||||||
pacs_document_port: 8080,
|
pacs_document_port: 8080,
|
||||||
// filterQueryParam: false,
|
// filterQueryParam: false,
|
||||||
// defaultDataSourceName: 'dicomweb',
|
// defaultDataSourceName: 'dicomweb',
|
||||||
@@ -47,8 +47,8 @@ window.config = {
|
|||||||
configuration: {
|
configuration: {
|
||||||
friendlyName: 'Static WADO Local Data',
|
friendlyName: 'Static WADO Local Data',
|
||||||
name: 'DCM4CHEE',
|
name: 'DCM4CHEE',
|
||||||
qidoRoot: `http://192.168.1.29:5000/rs`,
|
qidoRoot: `http://152.42.173.210:5000/rs`,
|
||||||
wadoRoot: `http://192.168.1.29:5000/rs`,
|
wadoRoot: `http://152.42.173.210:5000/rs`,
|
||||||
qidoSupportsIncludeField: false,
|
qidoSupportsIncludeField: false,
|
||||||
supportsReject: true,
|
supportsReject: true,
|
||||||
supportsStow: true,
|
supportsStow: true,
|
||||||
|
|||||||
@@ -10,25 +10,6 @@ window.config = {
|
|||||||
showCPUFallbackMessage: true,
|
showCPUFallbackMessage: true,
|
||||||
showLoadingIndicator: true,
|
showLoadingIndicator: true,
|
||||||
strictZSpacingForVolumeViewport: true,
|
strictZSpacingForVolumeViewport: true,
|
||||||
// This is an array, but we'll only use the first entry for now
|
|
||||||
// Remove OIDC configuration since proxy handles authentication
|
|
||||||
// oidc: [
|
|
||||||
// {
|
|
||||||
// // ~ REQUIRED
|
|
||||||
// // Authorization Server URL
|
|
||||||
// authority: 'https://accounts.google.com',
|
|
||||||
// client_id: '382212153306-7q39hdie4ecj0uhemkitvedo93bnvfhn.apps.googleusercontent.com',
|
|
||||||
// redirect_uri: '/callback',
|
|
||||||
// response_type: 'id_token token',
|
|
||||||
// scope:
|
|
||||||
// 'email profile openid https://www.googleapis.com/auth/cloudplatformprojects.readonly https://www.googleapis.com/auth/cloud-healthcare', // email profile openid
|
|
||||||
// // ~ OPTIONAL
|
|
||||||
// post_logout_redirect_uri: '/logout-redirect.html',
|
|
||||||
// revoke_uri: 'https://accounts.google.com/o/oauth2/revoke?token=',
|
|
||||||
// automaticSilentRenew: true,
|
|
||||||
// revokeAccessTokenOnSignout: true,
|
|
||||||
// },
|
|
||||||
// ],
|
|
||||||
extensions: [],
|
extensions: [],
|
||||||
modes: [],
|
modes: [],
|
||||||
showStudyList: true,
|
showStudyList: true,
|
||||||
@@ -53,12 +34,6 @@ window.config = {
|
|||||||
dicomUploadEnabled: true,
|
dicomUploadEnabled: true,
|
||||||
omitQuotationForMultipartRequest: true,
|
omitQuotationForMultipartRequest: true,
|
||||||
configurationAPI: 'ohif.dataSourceConfigurationAPI.google',
|
configurationAPI: 'ohif.dataSourceConfigurationAPI.google',
|
||||||
// defaultDicomStoreConfiguredItems: {
|
|
||||||
// id: 'projects/ohifproxy/locations/asia-southeast2/datasets/sas-storage',
|
|
||||||
// itemType: '3',
|
|
||||||
// name: 'store-1',
|
|
||||||
// url: 'https://healthcare.googleapis.com/v1/projects/ohifproxy/locations/asia-southeast2/datasets/sas-storage/dicomStores/store-1'
|
|
||||||
// },
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -356,14 +356,21 @@ const SidePanel = ({
|
|||||||
}
|
}
|
||||||
|
|
||||||
setIsExpertiseLoading(true);
|
setIsExpertiseLoading(true);
|
||||||
const url = `${window.config.expertise_host}/nv/query.php?method=view&AccessionNumber=${encodeURIComponent(accessionNumber)}`;
|
const url = `${window.config.expertise_host}?accessionNo=${accessionNumber}`;
|
||||||
|
|
||||||
const response = await fetch(url);
|
const response = await fetch(url);
|
||||||
const data = await response.json();
|
const data = await response.json();
|
||||||
console.log('Study data:', data);
|
if (data?.status === 'OK' && data?.data) {
|
||||||
|
// Create expertise data in the format expected by your component
|
||||||
|
const formattedExpertiseData = {
|
||||||
|
ordering_physician: data.data.senderDoctorName,
|
||||||
|
radiologist: data.data.pjDoctorName,
|
||||||
|
expertise_dttm: data.data.expTime,
|
||||||
|
// Convert the expertise object to a string format that parseExpertise can handle
|
||||||
|
expertise: formatExpertiseToString(data.data.expertise),
|
||||||
|
};
|
||||||
|
|
||||||
if (data?.study?.expertise && data.study.expertise.length > 0) {
|
setExpertiseData(formattedExpertiseData);
|
||||||
setExpertiseData(data.study.expertise[0]);
|
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error('Error fetching expertise data:', error);
|
console.error('Error fetching expertise data:', error);
|
||||||
@@ -372,6 +379,32 @@ const SidePanel = ({
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Helper function to convert expertise object to string format
|
||||||
|
const formatExpertiseToString = expertiseObj => {
|
||||||
|
if (!expertiseObj) return '';
|
||||||
|
|
||||||
|
let result = '';
|
||||||
|
|
||||||
|
// Add each section with proper formatting
|
||||||
|
if (expertiseObj.Indikasi) {
|
||||||
|
result += `KLINIS: ${expertiseObj.Indikasi}\r\n`;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (expertiseObj.Teknik) {
|
||||||
|
result += `TEKNIK: ${expertiseObj.Teknik}\r\n\r\n`;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (expertiseObj.Deskripsi) {
|
||||||
|
result += `KETERANGAN:\r\n${expertiseObj.Deskripsi.replace(/\n/g, '\r\n')}\r\n\r\n`;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (expertiseObj.Kesan) {
|
||||||
|
result += `KESAN: ${expertiseObj.Kesan}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
};
|
||||||
|
|
||||||
const getExpertisePanel = () => {
|
const getExpertisePanel = () => {
|
||||||
if (side !== 'right') return null; // Only show in the right side panel
|
if (side !== 'right') return null; // Only show in the right side panel
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user