Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

The aim of this project is to produce CDA documents from OpenMRS data objects on the based upon user 's requests.The

Clinical Document Architecture(CDA) is an XML-based standard for exchange of health information records, it is meant to ensure interoperability.we have used

The CDA generator module uses the MDHT API to produce and validate CDA Documents.

 

This document will cover following information :-

  1. What types of CDA Documents or Messages are currently supported by the CDA Generator module
  2. Design of the Module
  3. How users can extend on CDA Generator module
  4. How we are populating sections of APHP CDA Message
  5. Installation of the Module
  6. Potential Improvements
  7. Screenshots
  8. Quick DemoDemonstration
  9. Sample APHP Documents produced by the CDA Generator module

What types of CDA Documents or Messages are currently generated by the CDA Generator module ?

This release of module only generate supports the generation of an APHP CDA Document type. However, developers are free to write up new CDA documents or message which  which can be added to the module. There are many types of CDA documents (APHP, APS, APL ,APE, e.t.c) people refer to it as IHE Profilesthat may be found on the IHE profile page.

 

Design of the Module

During this summer our focus was to generate APHP CDA message, but their there are many types of IHE profile or CDA documents types.

Now question isHowever, will our module allow any other type of CDA Document?Yesour module was designed to be configured in a manner that allows users to write their own CDA message handlers.

 

We have designed our module to ensure that our work is flexible for , and can be extended further extension. If someone wants to add new CDA type documents other than APHP, our module accommodate accommodates this change. So, our Our design consists of an hierarchy of classes (or as we call them as , an hierarchy of handlerhandlers. BaseCdaTypeHandler is serves as the base class which contains all attributes necessary for CDA document and all . All other handlers extend this BaseCdaTypeHandler (example APHP handler, APS handler or some other handler).

In our entire code base we are using the reference of Our module uses the BaseCDATypeHandler to make our work as generic as possible.

If we want to add a new CDA Document Type, all we need to do is create a class, extend from this BasCdaTypeHandler class and use setter methods to add values that’s it. Its as simple as that!

 

The same design approach is followed for Section as well. There we have BaseCdaSectionhandler and child handlers extending upon it.

 

Class Diagrams

 Image Removed                

Image Added    

The class digram above depicts how different Document handler classes extend on the BaseCdaTypeHandler.            

             Image Removed Image Added    

 

How can users

...

extend on the CDA Generator module?

Users can extend the module by adding new CDA document Type Types or Editing existing oneones (not recommended). Each CDA document consist of few sections and users can also add new sections to the module or Edit existing ones. The Editing/Adding/Deleting of Sections and CDA document types can be done programmatically through code not the User Interface.

...

  • fork our module from gitub here .
  • open "CDAGenerator-api"folder.
  • In src/main/java package try to locate "org.openmrs.module.CDAGenerator.CDAHandlers" package.
  • Now in this "org.openmrs.module.CDAGenerator.CDAHandlers" package, Create class for new CDA Document Type you need and Note that this class must extend BaseCdaTypeHandler class.
  • Add details about documents either using setter methods or adding in a constructor. Thats it and new CDA document type is ready! .

 

Image showing location to add new CDA Document Type

Image RemovedImage Added     

 

Sample Code

...

  • fork our module from gitub here .
  • open "CDAGenerator-api"folder.
  • In src/main/java package try to locate "org.openmrs.module.CDAGenerator.SectionHandlers" package.
  • Now in this "org.openmrs.module.CDAGenerator.SectionHandlers" package, Create class for new section you need and Note that this class must extend BaseCdaSectionHandler class.
  • Add details about section either using setter methods or adding in a constructor. Thats it and new Section is ready! .

 

Image showing location to add new sections

Image RemovedImage Added


Sample Code

Code Block
languagejava
titleCode showing how New Section Class Must look like
firstline1
package org.openmrs.module.CDAGenerator.SectionHandlers;
public class MySection extends BaseCdaSectionHandler
{

public ChiefComplaintSection()
{
    this.sectionName="My Section";
    this.templateid="";//ihe specific id
    this.sectionDescription="This is my new section";
    this.code="";//Ihe specific code for section
}
}

...

Similarly one can edit or delete any Sections or CDA document type.

 

...

Populating sections of the APHP CDA Message

we are We have used OpenMRS Concept Dictionary to Populate populate APHP CDA message section with answers. we We used IHE APHP Document value sets which list out specific concepts that must be used for specific sections. we We are updating OpenMRS the MVP-CIEL Concept dictionary with LOINC codes,  SNOMED codes and new concept that our module needs.

Installation of the Module

To be updatedInstallation of the OpenMRS CDA Generator Module

Potential Improvements

  • We can Add/Edit/Delete a Delete  CDA Documents and Sections Programmatically but not though the UI.

  •  Create clients to consume CDAs by hitting a REST Web Service with a patient identifier and cda document type to download their CDA instead of user users downloading through administrative tab.

  • We are using gazelle as a an external validator in addition to mdht cda validation code in our module. I’m manually using GUI gazelle validator provides to check our cda documents. So, Instead of this we should can call gazelle validator via a web service from our module.

Screenshots

1) When Administration tab (After the module is loaded Administration tab looks like thisImage Removed)

Image Added

 

2) Export CDA Document Link

Image RemovedImage Added

 

3) Validation of Export CDA Form

 

Image RemovedImage Added                                         Image Removed Image Added

 

4) Successful Generation of CDA Document

Image RemovedImage Added

 

5) Error reported, report (If generated document is invalid)

Image RemovedImage Added

 

6) Manage CDA Section Link

It list lists out all sections present in our module and also provide details of each section

 

Image RemovedImage Added                   Image Removed Image Added

 

7) Manage CDA Type Link

It list lists out all CDA Document types present in our module and also provide details of each document type

 

Image RemovedImage Added                            Image Removed Image Added

 

 

Quick

...

Demonstration


Please watch demonstration of module :

...

Widget Connector
urlhttps://www.youtube.com/watch?v=aBTfdt8ImRY

Sample CDA Documents for review

For a sample document generated using the OpenMRS CDA generator module, see here 

Downloads

Source code: https://github.com/openmrs/openmrs-module-cdagenerator