@smals-belgium-shared/vidis-prescription-list v2.0.0
Vidis prescriptions list web component
Context
VIDIS (Virtual Integrated Drug Information System) integrates several sources and systems:
- Recip-e prescriptions
- Vitalink / RSW / RSB medication scheme
- Vitalink / RSW / RSB diary notes
- Farmaflux delivered medications
In order to be reused by other software vendors, the VIDIS front-end is now split into web components. The container application will have to provide the input parameters to provision the web component with a working context.
Prerequisites
- A supported browser by our Web Components AND by eHealth
- A valid VIDIS token. It could be obtained from eHealth Token eXchange service. This token must be refreshed periodically in order to be used by VIDIS
- Notify partners that are using REST APIs so your VIDIS tokens & clients will be trusted :
⚠️ IE (internet explorer) is not supported. You can include polyfill scripts ("polyfills") for the browsers that you must support.
Features
This web component provides users with a comprehensive list of their medical prescriptions, offering an intuitive overview of essential information like the medication name, the validity date, the prescriber, and other additional key details. The list specifically highlights "open prescriptions," which are those that have been prescribed but have not yet been retrieved from the pharmacy. To ensure users are aware of any impending expiration, the validity date for each prescription is displayed in a warning color when it is approaching expiration, providing a visual cue for timely action.
The system also enables users to select one or multiple prescriptions from the list to print, ensuring they can have a physical copy for legal and personal reference, in accordance with local healthcare regulations. This paper version can be helpful for users who need to carry it with them to the pharmacy (in case they don't have a smartphone, or loss of ID-card) or for any required documentation.
Inputs
Name | Mandatory | Possible values | Description |
---|---|---|---|
language | true | en , de , fr , nl | The language holds the current language as a value, which means it can change over time if the user changes his/her preferred language. The web component adapts the translations based on the value set. The values of the language property are defined in the Language enum. |
configName | true | acc , prod | Name of the configuration the application and the components are being deployed to. |
services | true | N/A | Set of services to be consumed by the component. see USAGE. |
Outputs
Name | Type | Description |
---|---|---|
onSelectPrescription | string | Notified with the selected RID code as string |
onPrint | {title: string, content: string} | Notified with the selected prescriptions as base64 pdf and title. The pdf is created for portrait printing |
getTotalItems | number | Gets the number of total prescriptions |
Usage
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vidis prescriptions list web component</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<script type="module" src="vidis-prescription-list/prescription-list.js"></script>
<link rel="stylesheet" href="vidis-prescription-list/prescription-list.css">
</head>
<body>
<script>
const wc = document.createElement("vidis-prescription-list");
// Common inputs for all VIDIS web components
// Refer to https://www.npmjs.com/package/@smals-belgium/myhealth-wc-integration for more details
wc.language = 'en'
wc.configName = 'acc';
wc.services = {
cache: {
get: (key) => (undefined),
set: (key, value) => {
},
remove: (key) => {
}
},
getAccessToken: async (audience) => "TODO : the eHealth OAuth2 JWT token.",
registerRefreshCallback: () => {
}
}
// Example on how to provide extra input parameter(s), if needed / requested by the component
// wc["attributeName"] = "myValue"
// Example on how to listen to output parameter(s)
wc.addEventListener("eventName", (event) => {
console.log(`event:`, event)
const params = event.detail;
console.log('param:', params);
})
// Example on how to listen to output parameter(s), for printing
wc.addEventListener("onPrint", (event) => {
console.log(`event:`, event)
const params = event.detail;
console.log('param:', params);
const byteArray = new Uint8Array(atob(params.content).split('').map(char => char.charCodeAt(0)))
const blob = new Blob([byteArray], {type: 'application/pdf'})
const url = window.URL.createObjectURL(blob)
window.open(url, '_blank').print()
})
document.body.append(wc);
</script>
</body>
</html>
Versioning
This project follows Semantic Versioning. Each release is categorized by major, minor, and patch updates. Significant changes that may break existing integrations will be introduced with major versions. Please check CHANGELOG.md file for more info.
Accessibility
We are committed to making our web components accessible to all users. Our components are:
- Screen reader friendly : Designed to work well with popular screen readers (Talkback / VoiceOver / ...)
- Responsive : Adapt to various screen sizes (desktop / mobile).
- Compliant: Meet accessibility criteria, including ARIA labels and keyboard navigation
Customizations
The web components are build with Angular Material. The styling of it is overwritten by the “My Health” portal, by there design kit.
Troubleshoots
If you encounter issues while using the web components :
- Ensure that your token is valid and hasn't expired. For assistance, contact eHealth.
- Ensure you are using the latest version of the web components
- Ensure you are using a supported browser and that you have cleared your cache if issues persist.
- Ensure your organization, browser or device don't block calls to VIDIS API by any way.
- If none of the above, please contact mijngeneesmiddelen@riziv-inami.fgov.be / mesmedicaments@riziv-inami.fgov.be