π New to our project? Be sure to review the OpenMRS 3 Frontend Developer Documentation. You may find the Map of the Project especially helpful.
Also see the API documentation
for @openmrs/esm-framework
, which is contained in this repository.
Below is the documentation for this repository.
This is a monorepo containing the core packages for the OpenMRS Frontend. These packages handle the "cross-cutting concerns" described in the Domain Decomposition document.
This contains tooling and the app shell.
The following common libraries have been developed. They may also be used independently of the app shell.
- @openmrs/esm-api: helps make calls to the backend
- @openmrs/esm-breadcrumbs: management of UI breadcrumbs
- @openmrs/esm-config: validation and storage of frontend configuration
- @openmrs/esm-error-handling: handling of errors
- @openmrs/esm-extensions: implementation of a frontend component extension system
- @openmrs/esm-feature-flags: hide features that are in progress
- @openmrs/esm-globals: useful global variables and types
- @openmrs/esm-offline: provides offline functionality
- @openmrs/esm-react-utils: utilities for React components
- @openmrs/esm-state: brings in state management
- @openmrs/esm-styleguide: styling and UI capabilities
- @openmrs/esm-utils: general utility and helper functions
All libraries are aggregated in the @openmrs/esm-framework
package:
A set of frontend modules provide the core technical functionality of the application.
- @openmrs/esm-devtools-app
- @openmrs/esm-implementer-tools-app
- @openmrs/esm-login-app
- @openmrs/esm-primary-navigation-app
- @openmrs/esm-offline-tools-app
To set up the repository for development, run the following commands:
yarn
yarn setup
To build all packages in the repository, run the following command:
yarn build
Verification of the existing packages can also be done in one step using yarn
:
yarn verify
yarn run:shell
run:shell
will run the latest version of the shell and the framework only.
yarn run:omrs develop --sources packages/apps/<app folder>
This will allow you to develop the app similar to the experience of developing other apps.
cd packages/tooling/openmrs
yarn build
./dist/cli.js
To run tests for all packages, run:
yarn turbo test
To run tests in watch
mode, run:
yarn turbo test:watch
To run tests for a specific package, pass the package name to the --filter
flag. For example, to run tests for esm-patient-conditions-app
, run:
yarn turbo test --filter="esm-patient-conditions-app"
To run a specific test file, run:
yarn turbo test -- login
The above command will only run tests in the file or files that match the provided string.
You can also run the matching tests from above in watch mode by running:
yarn turbo test:watch -- login.test
To generate a coverage
report, run:
yarn turbo coverage
By default, turbo
will cache test runs. This means that re-running tests wihout changing any of the related files will return the cached logs from the last run. To bypass the cache, run tests with the force
flag, as follows:
yarn turbo test --force
If you want to try out changes to a framework library, you will
probably want to yarn link
or npm link
it into a frontend module.
Note that even though frontend modules import from @openmrs/esm-framework
,
the package you need to link is the sub-library; for example, if you are trying
to test changes in packages/framework/esm-api
, you will need to link it:
yarn link path/to/openmrs-esm-core/packages/framework/esm-framework
yarn link path/to/openmrs-esm-core/packages/framework/esm-api
This satisfies the build tooling, but we must do one more step to get the frontend to load these dependencies at runtime (see docs on Runtime Dependencies). Here, there are two options.
In order to get your local version of the core packages to be served in your local dev server, you will need to link the tooling as well.
yarn link /path/to/esm-core/packages/tooling/openmrs
.
In packages/shell/esm-app-shell, run yarn build:development --watch
to ensure that the built app shell is updated with your changes and available to the patient chart.
Then run your patient chart dev server as usual, with yarn start
.
If you're not able to get this working, try the
Read the dev documentation about import map overrides if you have not already.
In esm-core
, start the app shell with yarn run:shell
. Then, in the patient chart
repository, cd
into whatever packages you are working on and run yarn serve
from there. Then use the import map override tool in the browser to tell the frontend
to load your local patient chart packages.
Please note that this will result in entries being added to the package.json file
in the resolutions
field. These changes must be undone before creating your PR,
which you can do by running yarn unlink --all
in the patient chart repo.
Check your work by adding a console.log
at the top level of a file you're
working on in esm-api
.
To increment the version, run the following command:
yarn release
You will need to pick the next version number. We use minor changes (e.g. 3.2.0
β 3.3.0
)
to indicate big new features and breaking changes, and patch changes (e.g. 3.2.0
β 3.2.1
)
otherwise.
Note that this command will not create a new tag, nor publish the packages.
After running it, make a PR or merge to main
with the resulting changeset.
Once the version bump is merged, go to GitHub and
draft a new release.
The tag should be prefixed with v
(e.g., v3.2.1
), while the release title
should just be the version number (e.g., 3.2.1
). The creation of the GitHub release
will cause GitHub Actions to publish the packages, completing the release process.
Don't run
npm publish
,yarn publish
, orlerna publish
. Use the above process.
For documentation about our design patterns, please visit our design system documentation website.