Community management guide#
These guidelines are applicable when acting as a representative of Matplotlib, for example at sprints or when giving official talks or tutorials, and in any community venue managed by Matplotlib.
Our approach to community engagement is foremost guided by our Mission Statement:
We demonstrate that we care about visualization as a practice.
We deepen our practice and the community’s capacity to support users, facilitate exploration, produce high quality visualizations, and be understandable and extensible.
We showcase advanced use of the library without adding maintenance burden to the documentation and recognize contributions that happen outside of the github workflow.
We use communications platforms to maintain relationships with contributors who may no longer be active on GitHub, build relationships with potential contributors, and connect with other projects and communities who use Matplotlib.
In prioritizing understandability and extensibility, we recognize that people using Matplotlib, in whatever capacity, are part of our community. Doing so empowers our community members to build community with each other, for example by creating educational resources, building third party tools, and building informal mentoring networks.
Moderation#
Moderation rights are granted specific to each official platform. All matplotlib maintainers are moderators on github. If you are interested in moderating any of the other platforms:
Matplotlib maintainers should reach out to the community-manager.
Everyone else should send an email to matplotlib-social-admin@numfocus.org:
Introduce yourself - GitHub handle and participation in the community.
Explain why you want moderation rights
Enforcement responsibilities#
Any person with moderation rights is granted the authority to clarify and enforce our standards of expected behavior. This is a supplement to our Code of Conduct, not a replacement; moderators should make use of the Contributor Covenant Code of Conduct process for CoC violations. In addition violations of platform specific terms of service should be reported to that platform.
Moderators may hide, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that do not comply with our contributing guidelines. Deletion should only be used to remove sensitive information that can not be removed through edits. On most platforms, these actions can be accessed through the [...] context menu.
Communication#
After taking action, Moderators should publicly communicate their reasons for doing so to the user when possible, e.g. when doing so will not reveal sensitive information. When the situation is sensitive, moderators should reassess whether the situation would be better handled through the code of conduct process and attempt to communicate privately with the user (e.g. DMs) if appropriate.
Consequences#
Moderators have the right and responsibility to enforce consequences for disruptive
behavior. Moderators are welcome to consult on levying consequences in the staff
discourse channel. When possible, this should be done in the following stages:
warn: alert the user of their misconduct and how they can remedy the situation - this can be done privately and then publicly if the behavior persists - second warning should mention consequence of not heeding warning
temporary ban: apply a short term ban from the platform (default 1 week) - temporary bans can be applied in increasing increments at the moderator's discretion
permanent ban from the platform
If the user has not modified their behavior in an acceptable fashion, then the moderator
can move to the next stage. Moderators should notify the other maintainers of temporary
and permanent bans via the staff discourse channel or at the weekly developer meeting.
When feasible, moderators should also maintain a record of the unacceptable behavior. If
the user would like to appeal a ban (on any platform), moderators should make use of the
code of conduct process to resolve the situation by directing the user to file a code of
conduct report.
Moderators may immediately ban users in extenuating circumstance, such as while a CoC or TOS report is being investigated or when the user is an agent or bot. Moderators should file a code of conduct report for (human) users they feel should be permanently banned from all platforms.
Official project platforms#
The Scientific Python community uses various platforms to stay updated on new features and projects, to contribute by telling us what is on their mind and suggest issues and bugs, and to showcase their use cases and the tools they have built.
The following venues are managed by Matplotlib maintainers and contributors:
library and docs: https://github.com/matplotlib/matplotlib
Mailing lists#
Content guidelines#
Communication on official channels, such as the Matplotlib homepage or on Matplotlib social accounts, should conform to the following standards. If you are unsure if content that you would like to post or share meets these guidelines, ask on the Social media coordination channels before posting.
General guidelines#
Do not share information that violates Matplotlib's code of conduct or does not align with Matplotlib's Mission Statement.
Focus on Matplotlib, 3rd party packages, and visualizations made with Matplotlib.
These are also acceptable topics:
Visualization best practices and libraries.
Projects and initiatives by NumFOCUS and Scientific Python.
How to contribute to open source projects.
Projects, such as scientific papers, that use Matplotlib.
No gratuitous disparaging of other visualization libraries and tools, but criticism is acceptable so long as it serves a constructive purpose.
Follow communication best practices:
Do not share non-expert visualizations when it could cause harm, e.g.:
Could the information affect someone's decisions in a way that impacts their personal health or safety?
Could the information be used as part of a politicised debate?
Clearly state when the visualization data/conclusions cannot be verified.
Do not rely on machine translations for sensitive visualization.
Verify sourcing of content (especially on Instagram & blog):
Instagram/blog: ensure mpl has right to repost/share content
Make sure content is clearly cited:
e.g. a tutorial reworking an example must credit the original example
Limited self/corporate promotion is acceptable.
Should be no more than about a quarter of the content.
Visual media guidelines#
Visual media, such as images and videos, must not violate the code of conduct, nor any platform's rules. Specifically:
Visual media must conform to the guidelines of all sites it may be posted on:
Emphasize the visualization techniques demonstrated by the visual media.
Clearly state that sharing is not an endorsement of the content.
e.g. bitcoin related visualizations
Accessibility#
Visual media in communications should be made as accessible as possible:
Add alt text to images and videos when the platform allows:
Warn on bright, strobing, images & turn off autoplay if possible.
For images and videos made by the social media team:
Make graphic perceivable to people who cannot perceive color well due to color-blindness, low vision, or any other reason.
Do not make bright, strobing images.
More guidelines at https://webaim.org/techniques/images/.
Changing the guidelines#
As the person tasked with implementing these guidelines, the community-manager should be alerted to proposed changes. Similarly, specific platform guidelines (e.g. github, discourse, Instagram) should be reviewed by the person responsible for that platform, when different from the community manager. If there is no consensus, decisions about guidelines revert to the community manager.
Social media#
Active social media#
https://bsky.app/profile/matplotlib.bsky.social
https://fosstodon.org/@matplotlib
https://x.com/matplotlib
https://instagram.com/matplotart/
Official accounts#
https://www.tiktok.com/@matplotart
https://www.youtube.com/matplotlib