Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tutorial - WordPress Playground #1583

Open
15 tasks done
Tracked by #2999 ...
westnz opened this issue May 26, 2023 · 21 comments
Open
15 tasks done
Tracked by #2999 ...

Tutorial - WordPress Playground #1583

westnz opened this issue May 26, 2023 · 21 comments
Assignees

Comments

@westnz
Copy link
Collaborator

westnz commented May 26, 2023

Topic Description

For users, designers, and educators, WordPress Playground is a flexible tool that lets you:

  • Try plugins and themes in a live virtual environment
  • Experiment with an anonymous WordPress website
  • Embed a real WordPress site in your tutorial or course

Related Resources

Links to related content on Learn, HelpHub, DevHub, GitHub Gutenberg Issues, DevNotes, etc.
https://developer.wordpress.org/playground/

Guidelines

Review the team guidelines

Tutorial Development Checklist

  • Vetted by instructional designers for content idea
  • Provide feedback of the idea
  • Gather links to Support and Developer Docs
  • Review any related material on Learn
  • Define several SEO keywords to use in the article and where they should be prominently used
  • Description and Objectives finalized
  • Tutorial created and announced to the team for Q/A review
  • Tutorial reviewed and ready to publish
  • Tutorial submitted and published to WPTV
  • Tutorial published on WPTV
  • Tutorial captioned
  • Tutorial created on Learn.WordPress.org
  • Tutorial post reviewed for grammar, spelling, etc.
  • Tutorial published on Learn.WordPress.org
  • Tutorial announced to Marketing Team for promotion
@westnz
Copy link
Collaborator Author

westnz commented Jun 5, 2023

Playground.8.min.tutorial.2023.mp4

@westnz westnz moved this from 🚧 Drafts in Progress to 🔎 Review in Progress in LearnWP Content - Development Jun 5, 2023
@quitevisible
Copy link

@westnz @adamziel Some really useful info here, with demonstrations of practical application. A couple of thoughts...

Overall, good stuff! I love seeing real world use cases for Playground and how they can streamline the WordPress build process.

@westnz
Copy link
Collaborator Author

westnz commented Jun 20, 2023

Excellent work Adam! I have one suggestion - adding a bit more detail to the intro for folks who have never heard of it. I know we also discussed the following title to make it more clear: "How to start using WordPress Playground"

@adamziel
Copy link
Contributor

Sure! I will make the adjustments before the end of the week

@westnz
Copy link
Collaborator Author

westnz commented Jun 23, 2023

Excited to see this resource on Learn!

@jonathanbossenger
Copy link
Collaborator

@adamziel if you don't get a chance to make the "introduction" section before you go on leave, perhaps you wouldn't mind if I just record a short intro for the tutorial, and added it on to the beginning?

@adamziel
Copy link
Contributor

@jonathanbossenger that would be lovely, thank you!

@adamziel
Copy link
Contributor

Just documenting I shared the paced-down recording with @westnz and I'll be now heading out for my sabbatical.

@westnz
Copy link
Collaborator Author

westnz commented Jun 25, 2023

I will publish the tutorial later this week. Great work @adamziel

@westnz
Copy link
Collaborator Author

westnz commented Jun 27, 2023

@westnz westnz closed this as completed Jun 27, 2023
@github-project-automation github-project-automation bot moved this from 🔎 Review in Progress to 📜 Published or Closed in LearnWP Content - Development Jun 27, 2023
@westnz westnz reopened this Jun 18, 2024
@github-project-automation github-project-automation bot moved this from 📜 Published or Closed to 🚧 Drafts in Progress in LearnWP Content - Development Jun 18, 2024
@westnz
Copy link
Collaborator Author

westnz commented Jun 21, 2024

Hey @adamziel

We would like to add this lesson to the Advanced user learning pathway.

Are you satisfied with this version of the video, or should it be updated after the release of WordPress 6.6?

@ironnysh
Copy link

@westnz, there have been updates to Playground's UI and capabilities. Maybe we can reference them in #2543 instead?

Let's also add the new homepage to the Resources section: https://wordpress.org/playground/

@adamziel
Copy link
Contributor

@westnz There were changes in the UI indeed, but there are more coming in a few weeks. I'd use this version for now and explore updating it after the refresh @jarekmorawski will be exploring in July. Once that happens – would you have availability to update the video?

@westnz
Copy link
Collaborator Author

westnz commented Jun 25, 2024

Hey @adamziel
The deadline to publish the Advanced user learning pathway is at the end of September. Updating the video after July would be perfect. My availability to update this video will be limited. Any chance someone from the Playground team will be able to do it? Or will there be another version of the video we could use which you are planning to use at WCUS or elsewhere?

@adamziel adamziel moved this to Needs Triage/Our Reply in Playground Board Jul 1, 2024
@adamziel
Copy link
Contributor

The webapp redesign will improve the user experience a lot and we'll need a new video when it lands. While I don't have any date to share at the moment, there's a chance we'll get there before Sep 17th (WCUS). Until that's in place, we're good with the current video.

CC @jonathanbossenger @ryanwelcher @annezazu would you be able with refreshing the video once the redesign lands?

@adamziel adamziel moved this from Needs Triage/Our Reply to Needs Author's Reply in Playground Board Jul 16, 2024
@jonathanbossenger
Copy link
Collaborator

would you be able with refreshing the video once the redesign lands?

That would honestly depend on what I'm busy with at that time.

@adamziel adamziel moved this from Needs Author's Reply to Inbox in Playground Board Jul 17, 2024
@annezazu
Copy link

If no one else can do it, I can do my best to help 😄 I'd love if someone with better gear takes care of it though.

@westnz
Copy link
Collaborator Author

westnz commented Sep 12, 2024

Hey @adamziel
Could the Playground Team please provide an updated script with any changes and features you want to highlight in the new video? Once we have the script, I will collaborate with others to get the ball rolling to create an updated version for Learn and YouTube. 😃

brandonpayton added a commit to WordPress/wordpress-playground that referenced this issue Sep 27, 2024
… WebApp Redesign (#1731)

## Description

Implements a large part of the [website
redesign](#1561):

![CleanShot 2024-09-14 at 10 24
57@2x](https://github.com/user-attachments/assets/f245c7ac-cb8c-4e5a-b90a-b4aeff802e7b)


High-level changes shipped in this PR:

* Multiple Playgrounds. Every temporary Playground can be saved either
in the browser storage (OPFS) or in a local directory (Chrome desktop
only for now).
* New Playground settings options: Name name, language, multisite
* URL as the source of truth for the application state
* State management via Redux

This work is a convergence of 18+ months of effort and discussions. The
new UI opens relieves the users from juggling ephemeral Playgrounds and
losing their work. It opens up space for long-lived site configurations
and additional integrations. We could bring over all the [PR previewers
and demos](https://playground.wordpress.net/demos/) right into the
Playground app.

Here's just a few features unblocked by this PR:

* #1438 – no
more losing your work by accident 🎉
* #797 – with
multiple sites we can progressively build features we'll eventually
propose for WordPress core:
* A Playground export and import feature, pioneering the standard export
format for WordPress sites.
* A "Clone this Playground" feature, pioneering the [Site Transfer
Protocol](https://core.trac.wordpress.org/ticket/60375).
   * A "Sync two Playgrounds" feature, pioneering the Site Sync Protocol
* #1445 – better
git support is in top 5 most highly requested features. With multiple
Playgrounds, we can save your work and get rid of the "save your work
before connecting GitHub or you'll lose it" and cumbersome "repo setup"
forms on every interaction. Instead, we can make git operations like
Pull, Commit, etc. very easy and even enable auto-syncing with a git
repository.
* #1025 – as we
bring in more PHP plumbing into this repository, we'll replace the
TypeScript parts with PHP parts to create a WordPress core-first
Blueprints engine
* #1056 – Site
transfer protocol will unlocks seamlessly passing Playgrounds between
the browser and a local development environment
* #1558 – we'll
integrate [the Blueprints directory] and offer single-click Playground
setups, e.g. an Ecommerce store or a Slide deck editor.
#718.
* #539 – the
recorded Blueprints would be directly editable in Playground and perhaps
saved as a new Playground template
* #696 – the new
interaction model creates space for additional integrations.
* #707 – you
could create a "GitHub–synchronized" Playground
* #760 – we can
bootstrap one inside Playground using a Blueprint and benefit the users
immediately, and then gradually work towards enabling it on
WordPress.org
* #768 – the new
UI has space for a "new in Playground" section, similar to what Chrome
Devtools do
* #629  
* #32
* #104
* #497
* #562
* #580 

### Remaining work

- [ ] Write a release note for https://make.wordpress.org/playground/
- [x] Make sure GitHub integration is working. Looks like OAuth
connection leads to 404.
- [x] Fix temp site "Edit Settings" functionality to actually edit
settings (forking a temp site can come in a follow-up PR)
- [x] Fix style issue with overlapping site name label with narrow site
info views
- [x] Fix style issue with bottom "Open Site" and "WP Admin" buttons
missing for mobile viewports
- [x] Make sure there is a path for existing OPFS sites to continue to
load
- [x] Adjust E2E tests.
- [x] Reflect OPFS write error in UI when saving temp site fails
- [x] Find a path forward for
[try-wordpress](https://github.com/WordPress/try-wordpress) to continue
working after this PR
- [x] Figure out why does the browser get so choppy during OPFS save. It
looks as if there was a lot of synchronous work going on. Shouldn't all
the effort be done by a worker a non-blocking way?
- [x] Test with Safari and Firefox. Might require a local production
setup as FF won't work with the Playground dev server.
- [x] Fix Safari error: `Unhandled Promise Rejection: UnknownError:
Invalid platform file handle` when saving a temporary Playground to
OPFS.
- [x] Fix to allow deleting site that fails to boot. This is possible
when saving a temp site fails partway through.
- [x] Fix this crash:

```ts
		/**
		 * @todo: Fix OPFS site storage write timeout that happens alongside 2000
		 *        "Cannot read properties of undefined (reading 'apply')" errors here:
		 * I suspect the postMessage call we do to the safari worker causes it to
		 * respond with another message and these unexpected exchange throws off
		 * Comlink. We should make Comlink ignore those.
		 */
		// redirectTo(PlaygroundRoute.site(selectSiteBySlug(state, siteSlug)));
```
- [x] Test different scenarios manually, in particular those involving
Blueprints passed via hash
- [x] Ensure we have all the aria, `name=""` etc. accessibility
attributes we need, see AXE tools for Chrome.
- [x] Update developer documentation on the `storage` query arg (it's
removed in this PR)
- [x] Go through all the `TODOs` added in this PR and decide whether to
solve or punt them
- [x] Handle errors like "site not found in OPFS", "files missing from a
local directory"
- [x] Disable any `Local Filesystem` UI in browsers that don't support
them. Don't just hide them, though. Provide a help text to explain why
are they disabled.
- [x] Reduce the naming confusion, e.g. `updateSite` in redux-store.ts
vs `updateSite` in `site-storage.ts`. What would an unambiguous code
pattern look like?
- [x] Find a reliable and intuitive way of updating these deeply nested
redux state properties. Right now we do an ad-hoc recursive merge that's
slightly different for sites and clients. Which patterns used in other
apps would make it intuitive?
- [x] Have a single entrypoint for each logical action such as "Create a
new site", "Update site", "Select site" etc. that will take care of
updating the redux store, updating OPFS, and updating the URL. My ideal
scenario is calling something like `updateSite(slug, newConfig)` in a
React Component and being done without thinking "ughh I still need to
update OPFS" or "I also have to adjust that .json file over there"
- [x] Fix all the tiny design imperfections, e.g. cut-off labels in the
site settings form.

### Follow up work

- [ ] Mark all the related blocked issues as unblocked on the project
board, e.g.
#1703,
#1731, and more –
[see the All Tasks
view](https://github.com/orgs/WordPress/projects/180/views/2?query=sort%3Aupdated-desc+is%3Aopen&filterQuery=status%3A%22Up+next%22%2C%22In+progress%22%2C%22Needs+review%22%2C%22Reviewed%22%2C%22Done%22%2CBlocked)
- [ ] Update WordPress/Learn#1583 with info
that the redesign is now in and we're good to record a video tutorial.
- [ ] #1746
- [ ] Write a note in [What's new for developers? (October
2024)](WordPress/developer-blog-content#309)
- [ ] Document the new site saving flow in
`packages/docs/site/docs/main/about/build.md` cc @juanmaguitar
- [ ] Update all the screenshots in the documentation cc @juanmaguitar 
- [ ] When the site fails to load via `.list()`, still return that
site's info but make note of the error. Not showing that site on a list
could greatly confuse the user ("Hey, where did my site go?"). Let's be
explicit about problems.
- [ ] Introduce notifications system to provide feedback about outcomes
of various user actions.
- [ ] Add non-minified WordPress versions to the "New site" modal.
- [ ] Fix `console.js:288 TypeError: Cannot read properties of undefined
(reading 'apply') at comlink.ts:314:51 at Array.reduce (<anonymous>) at
callback (comlink.ts:314:29)` – it seems to happen at trunk, too.
- [ ] Attribute log messages to the site that triggered them.
- [ ] Take note of any interactions that we find frustrating or
confusing. We can perhaps adjust them in a follow-up PR, but let's make
sure we notice and document them here.
- [ ] Solidify the functional tooling for transforming between `URL`,
`runtimeConfiguration`, `Blueprint`, and `site settings form state` for
both OPFS sites and in-memory sites. Let's see if we can make it
reusable in Playground CLI.
- [ ] Speed up OPFS interactions, saving a site can take quite a while.
- [ ] A mobile-friendly modal architecture that doesn't stack modals,
allows dismissing, and understands some modals (e.g. fatal error report)
might have priority over other modals (e.g. connect to GitHub). Discuss
whether modals should be declared at the top level, like here, or
contextual to where the "Show modal" button is rendered.
- [ ] Discuss the need to support strong, masked passwords over a simple
password that's just `"password"`.
- [ ] Duplicate site feature implemented as "Export site + import site"
with the new core-first PHP tools from
adamziel/wxr-normalize#1 and
https://github.com/adamziel/site-transfer-protocol
- [x] Retain temporary sites between site changes. Don't just trash
their iframe and state when the user switches to another site.

Closes #1719

cc @brandonpayton

---------

Co-authored-by: Brandon Payton <brandon@happycode.net>
Co-authored-by: Bero <berislav.grgicak@gmail.com>
Co-authored-by: Bart Kalisz <bartlomiej.kalisz@gmail.com>
@adamziel
Copy link
Contributor

adamziel commented Oct 8, 2024

Here's a few notable changes since the original video was shot:

@ryanwelcher would you be able to wrangle a script with your best read of the most useful features to highlight?

@westnz
Copy link
Collaborator Author

westnz commented Dec 11, 2024

Hey @adamziel and @ryanwelcher
I wanted to touch base again regarding updating the lesson. 😃
Another option I thought of was for the YouTube team to work on a new lesson. As a crucial platform and versatile tool, Playground needs to be highlighted and promoted to ensure all WordPress users, developers, and designers are aware of its benefits. I’ve added this idea to the document Jamie Marsland shared.

@ironnysh
Copy link

There's a recording of a comprehensive online workshop hosted by @jonathanbossenger and @bgrgicak. Maybe it could be adapted/edited to serve as a tutorial?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: 🚧 Drafts in Progress
Status: Needs Reply
Development

No branches or pull requests

6 participants