This tool assists civil society organisations and movements in their journey to become more inclusive, diverse and sensitive to the needs, identities and backgrounds of their people. We believe in peoples' best intentions to reflect on themselves, their culture and practices, engaging in difficult dialogues when necessary.
Interacting with this tool is not a panacea for solving discrimination, racism or workplace harassment. Rather, it provides a snapshot of where your organisation lies on the maturity model spectrum, with suggestions on how to grow in areas that need attention. It is not a rating or certification platform: we believe there is no "stamp of achievement" that an organisation can claim for "sufficient diversity."
We hope that this tool will support civil society organisations in becoming inspiring role-models and champions of diversity & inclusion in their communities, helping in the process our common mission of building a better, fairer, more socially just and kind world.
This is a self-evaluation webapp based on the concept of the maturity model, inspired by Linda Raftree's work on the Responsible Data Maturity Model. The maturity model is self-reflective: instead of asking questions, it presents statements that describe a certain level of organisational maturity with regards to a category, like program development or infrastructure. Through a series of collaborative design rounds with audience representatives, the statements have been crafted and assigned to a maturity level:
- Unaware
- Ad-Hoc
- Developing
- Mastering
- Leading
For each statement, you are asked to express how much that statement resonates with your organisation's experience:
- Not at all
- Somewhat
- Very Much
- Doesn't apply
There are more than 200 statements, so the work of going through all of them is not easy. We did our best to simplify it: you can either choose to go through a random list of statements pertaining to a category, or you can drill down into a category and see all the statements pertaining to a maturity level.
For best results, we recommend going through the evaluation tool with the support of a Diversity & Inclusion specialist, who will be able to guide you through the more complex bits and give you insight.
The core feature of the website is a table where rows represent maturity categories, and columns represent maturity levels. On this overview, you can:
When saving, you are given a code to paste somewhere safe. Since this tool doesn't collect any data by design, the only way to come back to your progress is by enteringentering the code on the homepage.
If you export your progress as a PDF, you will find the code on the front page for easy copying and pasting.
We designed the PDF export as a comprehensive Maturity Plan that you can use in meetings and workshops, when sitting down with you manager, or simply to doodle through it while planning your strategy. Keep in mind that it's about 50 pages long and is generated in real time, so your browser might get a bit slow for 5 seconds.
All of the data that application is using is pulled from the following files at build time:
src/
data/
categories.yml
languages.yml
maturity-levels.yml
resources.yml
statements.yml
tags.yml
All of the data files except resources.yml
are localized with multiple languages defined directly on each data entity.
Important: When adding a new statement, it has to be appended to the end of the file or the old saved results won't work. Statements shouldn't be deleted or moved.
Different user interface translations are located in:
src/
i18n/
en.ts
es.ts
fr.ts
When adding a language:
- add the new translation file in
/src/i18n
directory with the language ISO code - add the import to
/src/i18n/index.ts
- add the new language to
/src/data/languages.yml
- add the new language to
/src/i18n/index.ts
Missing translations will fall back to english language.
No data is ever sent to the server. Answers and goals are stored to the client browser local storage so users can continue where they left and is cleared by clicking "Restart Assessment".
Users are able to export a code from the system that they can import on another computer or browser to share results or continue the assessment. The generated code is an export of all answers and goals in compressed base64 encoded format.
This is a TypeScript React web application using the following main components:
- React Router for navigation
- Redux for global state management
- React Intl for localization
- React PDF for generating PDFs
Directory structure
All the javascript code is organized in src
directory.
src/
components/ - reusable components which are used by more than one module.
data/ - statement, category, maturity level, etc. data.
hooks/ - reusable hooks.
i18n/ - user interface internalization files.
images/ - logos, icons, and other image assets.
pages/ - web pages organized into separate directories.
store/ - redux store, actions, reducers, and selectors.
styles/ - scss style files.
utils/ - global helper functions.
Setting up development
- clone the repo
- run
yarn install
Running the app locally
- run
yarn