OpenMRS Frontend RFC
The OpenMRS Frontend RFC (Request for Comments) is a git repository where the technologies and processes that apply to all new OpenMRS distributions are explained.
- Provide a way to enact change in the OpenMRS frontend.
- Clarify what things we are aligned on across all of OpenMRS, so that everything else can be decided by the individual modules and distributions.
What this isn't
- An infringement on the autonomy of distribution maintainers. The idea is that if we're aligned on the few important things, we can be autonomous on everything else.
- Something oppressively prescriptive.
- A technical review process where people get feedback on difficult problems they're facing. Although important, the RFC is not how technical reviews happen.
- A list of technical debt initiatives. This RFC explains the decisions we've made as a group for frontend, but doesn't track the progress of those decisions.
Signs that this is working
- The content is up-to-date and people care about it.
- Things are removed when no longer relevant or correct.
- We change the process when it's annoying or doesn't work well.
- Ideas have a safe place to develop before being criticized.
Signs that this isn't working
- This blocks people from getting stuff done.
- Ivory tower gatekeeping.
- Changes are discouraged instead of encouraged.
- "Well that's just the way it is."
- The process is heavy, bureaucratic, or long.
- Some other process is being used to achieve the same thing.
What to do if the RFC isn't working
Propose a change to the process!
Process for change
Anyone can propose a change.
Step 1 - Idea
During the idea phase, we should encourage instead of critique. A person can use the OpenMRS slack workspace, IRC, or Talk forum to discuss, clarify, and foster an idea. We should examine with an open mind the pros and cons, options, and implementation.
Another part of the idea phase is asking the question "Should this be autonomous to the distributions or enforced consistently in all distributions?"
Step 2 - Proposal
A proposal is a pull request to this git repository. The proposal should follow the RFC template. Here, an idea is debated and discussed by anyone who wants to participate. Reviewers can make comments asking for changes or they can challenge the basis of the proposal.
If a pull request becomes stale (not updated or talked about after a fewish weeks), close it.
Step 3 - Approval
Once the author and reviewers have commented and the discussion and proposal have stabilized, the proposal will be merged or closed. Approval must be given by three members of the "microfrontends squad" (as defined below) must indicate on the PR that they approve.
Other groups who'd like to participate in the microfrontends squad can contact the squad on the Slack channel #microfrontend.
Step 4 - Implementation
Once a proposal is merged, it is now part of the RFC. This means that we intend to implement what is described in the RFC. The changes or additions to the RFC apply to the whole frontend and we should make whatever changes are needed to our code, processes, and organization.