2 Commits

Author SHA1 Message Date
mario
63b9bc5ffc dynamic pdf url from default.js 2025-05-21 16:27:29 +07:00
mario
f4dea5a9d6 ini bisone internal click dari bisone -p 3000 2025-05-19 15:54:36 +07:00
5 changed files with 54 additions and 43 deletions

1
.gitignore vendored
View File

@@ -12,6 +12,7 @@ coverage/
.yarn/ .yarn/
.nx/ .nx/
addOns/yarn.lock addOns/yarn.lock
**.zip
# YALC (for Erik) # YALC (for Erik)
.yalc .yalc

View File

@@ -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>
); );
} }

View File

@@ -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,

View File

@@ -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'
// },
}, },
}, },
{ {

View File

@@ -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