File: communication_guide.rst

package info (click to toggle)
matplotlib 3.10.1%2Bdfsg1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 78,340 kB
  • sloc: python: 147,118; cpp: 62,988; objc: 1,679; ansic: 1,426; javascript: 786; makefile: 92; sh: 53
file content (265 lines) | stat: -rw-r--r-- 10,099 bytes parent folder | download | duplicates (2)
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