Page MenuHomePhabricator

Develop a process for discussing Codex adoption with WMF teams
Open, In Progress, MediumPublic

Description

DST wants to connect with WMF teams who do work on the front end to understand when and how they could adopt Codex.

Adoption spectrum

We see teams as being somewhere on the following spectrum of Codex adoption:

  1. Information phase. Teams in this phase have not started using Codex (or possibly Vue.js) and need information about what we're doing, when we're doing it, and how they could get onboarded to Codex. They may not know exactly what's blocking their adoption of Codex or when they would prioritize doing so.
  2. Adoption phase. Teams in this phase have started using Codex or have a general plan for doing so in the future. They likely know some of the things blocking them and have specific needs.
  3. Collaboration phase. Teams in this phase have not only started using Codex, they're also contributing to it. They have a deep understanding of Codex and are actively supporting its development.

In order to serve all teams and eventually level them up to the collaboration phase, we should develop different processes to support the three phases.


Process

0. Collect initial data on thoughts about Vue adoption

In this stage, we want to college some basic information from each front-end team about their thoughts on adopting Codex, which means adopting Vue as well. Since Vue adoption is a critical part of Codex adoption, we will ask an engineer (likely the tech lead) on each team what their team is thinking about when and how to adopt Vue and Codex, and what's blocking them from doing so. See T324481.

1. Introduce Codex + Vue.js via the roadshow

For teams in the information phase (and potentially in the adoption phase), we need to start by introducing our work to enable these teams to understand how they can use the design system and what it would mean to start using Vue.js. Once the teams are informed of the basics, they will be better equipped to tell us what they need to adopt Codex.

This step will be completed via the DST roadshow (see T317360). That task will cover both synchronous and asynchronous methods for providing teams with the information they need to start thinking about onboarding with Codex.

Once teams complete this step, they will move into the adoption phase.

2. Meet with each team to discuss Codex adoption

For teams in the adoption phase, we will hold a synchronous meeting to discuss general plans for adopting Codex and anything blocking the team from doing so. This will enable the DST to provide support and prioritize work that will ease adoption. We should meet with all product teams and relevant tech teams (see Desiree's comment for a list of tech teams).

Draft list of teams to meet with:

  • Anti-harassment tools
  • Campaigns
  • Community tech
  • Editing (?)
  • Growth
  • Fundraising tech (?)
  • Inuka
  • Language
  • Moderator tools
  • Structured data
  • Trust and safety tools
  • Web (?)
  • WMDE (?)
  • API platform
  • Analytics platform
  • Technical engagement (toolhub)
Process
  • Schedule meeting.
    • Rep from DST schedules a 30 minute meeting with the Product Manager (or similar), Designer, Tech Lead, and Program Manager
    • At time of scheduling, DST rep includes a meeting description with a list of links to resources and some topics for the team to think about beforehand if possible
  • Hold meeting. Goals:
    • Help the team understand what to expect when starting to use Codex, including:
      • New processes/tools for design (resources: ??)
      • Onboarding to Vue.js (resources: Vue 3 docs, access to Vue Mastery trainings)
      • Starting to use Codex Vue components, design tokens, and icons (resources: Codex docs, docs on using Codex in MediaWiki, sample projects)
      • Evaluating performance concerns (when to load Vue.js, supporting no-JS and slower connections)
    • Ask the team what they view as blockers to Codex adoption
      • Record responses so we can aggregate them across teams
      • Ask about what specific resources the team wants
    • Ask the team if they have a general plan for Codex adoption
      • E.g. a timeline or specific project
      • If they don't, ask them to consider this and get back to DST rep asynchronously
    • Inform the team of DST's role in providing support
      • Explain prioritization and general timeline of in-progress and future design, Codex, and infrastructure work
      • Explain hybrid model and that contributions to Codex may be necessary (and are welcomed)
      • Provide info on how the team can contact the DST for various needs

3. Evaluate feedback from meetings

After the meetings are held, we will aggregate information about blockers to Codex adoption and review it as a team so we can prioritize work that will unblock adoption.


To do

  • Review the process with the DST, update, and finalize
  • Track team meetings and evaluating feedback in Phabricator

Event Timeline

DAbad triaged this task as High priority.Nov 21 2022, 4:19 PM
DAbad moved this task from Inbox to Up Next on the Design-System-Team board.

Adding a few teams for the list:
Potential pilot teams:

  • Growth
  • Language

Non-Product Teams w/ front-end experiences:

@bmartinezcalvo / @Volker_E / @Sarai-WMDE Could you help me understand what a designer on a product team will need to do to support their team adopting Codex? I'm not sure how familiar product designers are with the design system—I suspect they're quite familiar since the WMF design team has regular meetings, but I'm not exactly sure. I'm assuming that to start using Codex, a product designer would need access to the Codex components (and design tokens?) in Figma, and perhaps some familiarity with the Codex docs site. Is there anything else they will need to onboard? Are there specific resources we can point them to other than the Figma library and docs site?

@bmartinezcalvo / @Volker_E / @Sarai-WMDE Could you help me understand what a designer on a product team will need to do to support their team adopting Codex? I'm not sure how familiar product designers are with the design system—I suspect they're quite familiar since the WMF design team has regular meetings, but I'm not exactly sure. I'm assuming that to start using Codex, a product designer would need access to the Codex components (and design tokens?) in Figma, and perhaps some familiarity with the Codex docs site. Is there anything else they will need to onboard? Are there specific resources we can point them to other than the Figma library and docs site?

@AnneT we have regular meetings with designers to inform them about how to work OOUI components, Codex components and Design Tokens. We documented in this Notion page when to use each library and we should also create the flow to clarify this process (we need to design it in T321655). The first step to support designers in the adoption of Codex is to explain them when to use each Figma library, since now OOUI and Codex components use different libraries.

Apart from this, developers also will find which demo each component in the design belongs by using the Figma inspect, as we added the library name [OOUI] / [Codex] in each component.

Captura de Pantalla 2022-11-22 a las 19.19.18.png (662×1 px, 1 MB)

If you need to understand better this information we can schedule a quick meeting where I explain you how designers should use Figma to indicate developers which library they are using.

AnneT changed the task status from Open to In Progress.Nov 23 2022, 1:42 AM

@bmartinezcalvo this is exactly what I needed, thank you!

AnneT lowered the priority of this task from High to Medium.Jan 23 2023, 5:46 PM