1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265
|
.. _communications-guidelines:
==========================
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 :ref:`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.
.. _communication-channels:
Official communication channels
===============================
The Scientific Python community uses various communications 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
* forum: https://discourse.matplotlib.org/
* chat: `https://matrix.to/#/#matplotlib:matrix.org <https://matrix.to/#/#matplotlib:matrix.org>`_
* blog: https://blog.scientific-python.org/
.. _social-media:
Social media
------------
Active social media
^^^^^^^^^^^^^^^^^^^
* https://twitter.com/matplotlib
* https://instagram.com/matplotart/
Official accounts
^^^^^^^^^^^^^^^^^
* https://bsky.app/profile/matplotlib.bsky.social
* https://fosstodon.org/@matplotlib
* https://www.tiktok.com/@matplotart
* https://www.youtube.com/matplotlib
.. _mailing-lists:
Mailing lists
-------------
* `matplotlib-announce@python.org <https://mail.python.org/mailman/listinfo/matplotlib-announce>`_
* `matplotlib-users@python.org <https://mail.python.org/mailman/listinfo/matplotlib-users>`_
* `matplotlib-devel@python.org <https://mail.python.org/mailman/listinfo/matplotlib-devel>`_
.. _social-media-coordination:
Social media coordination
-------------------------
* Team mailing list: matplotlib-social@numfocus.org
* Public chat room: `https://matrix.to/#/#matplotlib_community:gitter.im <https://matrix.to/#/#matplotlib_community:gitter.im>`_
Maintenance
-----------
If you are interested in moderating the chat or forum or accessing the social
media accounts:
* 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.
* Describe the reason for wanting to moderate or contribute to social.
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 :ref:`social-media-coordination` channels before posting.
General guidelines
------------------
* 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. https://twitter.com/matplotlib/status/1244178154618605568
* 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
:ref:`code of conduct <code_of_conduct>`, nor any platform's rules.
Specifically:
* Visual media must conform to the guidelines of all sites it may be posted on:
* https://help.twitter.com/en/rules-and-policies/twitter-rules
* https://help.instagram.com/477434105621119
* 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:
* `alt text for data viz <https://medium.com/nightingale/writing-alt-text-for-data-visualization-2a218ef43f81>`_
* `general alt text guide <https://webaim.org/techniques/alttext/>`_
* 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/.
.. _social-media-brand:
Social media
============
Matplotlib aims for a single voice across all social media platforms to build and
maintain a consistent brand identity for Matplotlib as an organization. This
depersonalization is the norm on social media platforms because it enables
constructive and productive conversations; People generally feel more comfortable
giving negative and constructive feedback to a brand than to specific contributors.
The current Matplotlib voice and persona aims to be kind, patient, supportive and
educational. This is so that it can de-escalate tensions and facilitate
constructive conversations; being perceived as negative or
argumentative can escalate very fast into long-lasting brand damage, being
perceived as personal leads to aggression and accusations faster than an
impersonal account, and being perceived as friendly and approachable leads to
higher engagement. Instead of speaking with a directive authority, which can be
intimidating and lead to negative engagement, it speaks as a peer or educator to
empower participation. The current voice encourages more input from folks we
engage with, and also makes it possible for folks who are not in the core team
to participate in managing the account.
While the :ref:`brand identity <social-media-brand>` is casual, the showcased
content is high quality, peer-led resource building. Please follow these
guidelines to maintain a consistent brand identity across platforms.
Persona
-------
On social media, Matplotlib:
* Acts as a sentient visualization library, so talks about itself as a we, us,
our, and it. Avoids talking about itself in the 3rd person. Never uses 1st person.
* Is very earnest, eager to please, and aims to be patient & painfully oblivious
to snark and sarcasm.
* Gets over-excited over shiny visualizations - lots of emojis and the like -
and encourages folks to share their work.
* Highlights various parts of the library, especially the more obscure bits and
bobbles.
* Acknowledges that it is a sometimes frustrating tangle of bits & bobbles that
can confuse even the folks who work on it & signal boosts their confuzzlment.
Behavior
--------
When acting as a representative of the library, keep responses polite and assume
user statements are in good faith unless they violate the :ref:`code of conduct <code_of_conduct>`.
Social graph
------------
Only follow **organizations and projects**, do not follow individual accounts for
any reason, even maintainers/project leads/famous Python people!
Following these types of accounts is encouraged:
* NumFocus and Scientific Python projects
* 3rd party packages
* Visualization related projects and organizations
* Open Source community projects
* Sponsors
Recurring campaigns
-------------------
Typically the social media accounts will promote the following:
* Matplotlib releases:
* Highlight new features & major deprecations
* Link to download/install instructions
* Ask folks to try it out.
* `third party packages <https://matplotlib.org/mpl-third-party/>`_
* NumFocus/Scientific Python/open source visualization project releases
* GSOC/GSOD recruiting and progress
Retired campaigns
^^^^^^^^^^^^^^^^^
* John Hunter Excellence in Plotting, submission and winners
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. twitter, 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.
.. _community-manager: https://matplotlib.org/governance/people.html#deputy-project-leads
|