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

feat: source editor that supports multiple files #759

Closed

Conversation

aminaopio
Copy link
Contributor

@aminaopio aminaopio commented Oct 30, 2024

What changed / motivation ?

The StyleX website has an empty-ish page for the playground. This tackles one of the issues: A source editor pane that support tabs for multiple files.

Linked PR/Issues

This helps address issue #732

Additional Context

Implemented Change (w/ server running):

feat759.mov

Screenshots:
Screenshot 2024-12-11 at 3 44 48 PM
Screenshot 2024-12-11 at 3 42 48 PM

Pre-flight checklist

@facebook-github-bot facebook-github-bot added the CLA Signed This label is managed by the Facebook bot. Authors need to sign the CLA before a PR can be reviewed. label Oct 30, 2024
@aminaopio aminaopio changed the title Dev-amina-playground feat: source editor that supports multiple files Oct 30, 2024
@aminaopio
Copy link
Contributor Author

@nmn Hey Naman! I'm still working through the functionality for this feature, but I'm having some trouble getting the styling correct. I've added 'overflow: auto,' to the container component, but the result is above. Without that, the header causes the remainder of the text to overflow slightly and the preview pane is not entirely visible. Any suggestions?

Also, it's currently setting default tabs to those provided within playground-utils/files. Is it preferable to only have the src as a tab and then allow the user to create additional tabs? Sorry if these are silly questions, but let me know your thoughts. Thanks in advance!

@aminaopio aminaopio changed the base branch from main to better-playground October 30, 2024 07:13
@nmn
Copy link
Contributor

nmn commented Oct 30, 2024

@aminaopio I suggest building a sidebar instead. Within the sidebar, you can use <details><summary> elements to create a tree view for the entire file-tree.

You can add a single icon button to show the sidebar that can be absolutely positioned appear over the code editor. This way you can avoid dealing with layout issues.

If you continue to deal with issues, lmk, and I'll help with the UI.

@nmn nmn force-pushed the better-playground branch from e962bf8 to 58bd372 Compare November 1, 2024 08:34
@aminaopio aminaopio marked this pull request as ready for review November 6, 2024 09:43
@aminaopio
Copy link
Contributor Author

Hi @nmn, I ended up having to tuck the icon button into a header anyway, but let me know your thoughts. Maybe the UI could use some work....

@nmn
Copy link
Contributor

nmn commented Nov 6, 2024

I have a project with Rollup working properly here:
https://stackblitz.com/edit/sb1-tu4v6l?file=src%2FApp.tsx

  • It's a basic React app with Rollup and livereload
  • It uses a forked version of @stylexjs/rollup-plugin
    • It adds a few lines of code to write the individual transformed JS files and the collected styles from them to a previews folder.

Using this project, you should be able to have a four tab design with the following tabs:

  1. The editor
  2. The transformed JS code of the currently active file
  3. The styles collected from the currently active file
    • OR the final CSS
  4. The preview
    • The preview should "just work".
    • It should not refresh twice on every change

You can probably skip the eslint and typescript parts of the project for now. That should make the setup fairly small.

@aminaopio
Copy link
Contributor Author

aminaopio commented Nov 6, 2024

I have a project with Rollup working properly here: https://stackblitz.com/edit/sb1-tu4v6l?file=src%2FApp.tsx

  • It's a basic React app with Rollup and livereload

  • It uses a forked version of @stylexjs/rollup-plugin

    • It adds a few lines of code to write the individual transformed JS files and the collected styles from them to a previews folder.

Using this project, you should be able to have a four tab design with the following tabs:

  1. The editor

  2. The transformed JS code of the currently active file

  3. The styles collected from the currently active file

    • OR the final CSS
  4. The preview

    • The preview should "just work".
    • It should not refresh twice on every change

You can probably skip the eslint and typescript parts of the project for now. That should make the setup fairly small.

Ok I just looked over this again now that I'm fully awake, and I see what you're saying

@aminaopio
Copy link
Contributor Author

aminaopio commented Nov 6, 2024

However, I'm having some trouble visualizing what you mean by 4 tab design @nmn

  • Do you want each of those tabs to be hidden within the sidebar and take up 100% of the screen when active?

  • Or something like this:

    • image

I was under the impression that what I'm implementing currently is just the multi-file support for the code editor alone

A source editor pane that support tabs for multiple files

@nmn
Copy link
Contributor

nmn commented Nov 6, 2024

We have design options, but what I'm imagining is that the left half of the screen is the code editor (plus a sidebar), and the right half of the screen has tabs to let you see either the JS output, collected styles, generated CSS or preview.

A grid of four corners like in your hand-drawn picture could also work.

@nmn
Copy link
Contributor

nmn commented Nov 6, 2024

I was under the impression that what I'm implementing currently is just the multi-file support for the code editor alone

You can start with that. Do you want me to integrate the Rollup project into my playground PR so you can just rebase on top and do the work on adding tabs for the source editor?

@nmn
Copy link
Contributor

nmn commented Nov 6, 2024

Hey @aminaopio Sorry, I confused the two Playground related PRs. Please carry on with your work on adding tabs.

@aminaopio
Copy link
Contributor Author

Hey @aminaopio Sorry, I confused the two Playground related PRs. Please carry on with your work on adding tabs.

Oh okay all good! I'll start implementing what you suggested once this one gets finished up and merged

You can start with that. Do you want me to integrate the Rollup project into my playground PR so you can just rebase on top and do the work on adding tabs for the source editor?

We can try this out on our own, but may need assistance. I'll get back to you on this one. Thanks!

@aminaopio aminaopio force-pushed the dev-amina-playground branch from ff8e109 to 1df2576 Compare December 22, 2024 05:14
resolving conflicts

Better styling in playground component, still needs work

Import FontAwsome Icon library, changed tab input
@aminaopio
Copy link
Contributor Author

  • OPTIONAL: squash the commits in your branch to make rebasing later easier.

Tried to squash as much as I could, but commits from better-playground popped up as well...is that normal?

  1. Rebase with git rebase main. Fix all the conflicts. The more commits you have the longer this will take.

I think it's done?

@nmn
Copy link
Contributor

nmn commented Dec 22, 2024

I'm so sorry. I suggested rebasing on main, but what I meant was rebasing onto better-playground.

Can you re-rebase onto the better-playground branch. It's all the same steps, but with that branch name instead of main.

nmn and others added 13 commits December 22, 2024 12:40
* chore: Update Flow and type defs
* chore: update more dependencies
* chore: update eslint deps
* chore: rollup and types updated
* chore: update terser
* release: v0.9.0-beta.1
* chore: fix babel rollup bundling
* feat: add no-unused eslint rule
* Addressed comments; added tests: named exports, indirect style invoke; added features: non-default export, used style as return, full import pattern support
* feat: add postcss-plugin
* fix postcss-plugin readme text
* remove .ts, .tsx from node_modules @stylexjs/open-props globs in postcss.config.js
* do not rely on internal exports path
* fix: remove redundant @layer stylex
* chore: Clean up Nextjs-example with postcss-plugin
* chore: remove unnecessary 'bright' dep
* chore: add json-scheme types
feat: allow file editing and updates the preview
update reload button

fix: cleanup and improve perf
chore: prettier

feat: loading indicator for sidebar while WC boots

refactor: add filereader to dropzone, error rev

feat: added dropzone to src directory

feat: prevent duplicate filenames - Add check to ensure filenames are unique - Prevent accidental overwriting of existing files

feat: failed to load error message and reload preview button

refactor: reverting back to filesref

fix: ensuring consistency across tab styling

chore: reduce codeChangeTimeout to 1000ms - Fix sidebar files not rendering

fix: resolve sidebar file rendering issue - Allow main.jsx file to be editable

refactor: improve UX by keeping cursor position during changes

refactor: optimize component performance - Reduce re-renders by using useRef for tracking files - Add support for updating multiple files at a time

feat: delete and rename file operations - Add support for deleting and renaming files - Remove deleted files in previews directory - Update UI widths for sidebar, editor, and preview

feat: create and update file operations - Add support for creating and updating files - Fix issue causing the preview to render twice - Improve variable naming for better readability

feat: WIP update rollup project

feat: WIP view preview files

Import FontAwsome Icon library, changed tab input

minor change

added javascript import for codemirror

Implemented src, js, and metadata directories

Better styling in playground component, still needs work

added changes from better-playground

Running prettier/lint, issue unrelated to feature
* feat: add postcss-plugin
* fix postcss-plugin readme text
* remove .ts, .tsx from node_modules @stylexjs/open-props globs in postcss.config.js
* do not rely on internal exports path
* fix: remove redundant @layer stylex
* chore: Clean up Nextjs-example with postcss-plugin
* chore: remove unnecessary 'bright' dep
* chore: add json-scheme types
resolving conflicts

Better styling in playground component, still needs work

Import FontAwsome Icon library, changed tab input
@aminaopio
Copy link
Contributor Author

I'm so sorry. I suggested rebasing on main, but what I meant was rebasing onto better-playground.

That's my bad, I didn't notice

Can you re-rebase onto the better-playground branch. It's all the same steps, but with that branch name instead of main.

We should be good to go @nmn. For future reference, what's the proper way to clean up commit history? Would running git rebase --interactive $commit and manually removing duplicate commits prior to rebasing cause any issues?

@nmn
Copy link
Contributor

nmn commented Dec 23, 2024

@aminaopio I'm still seeing a bunch of conflicts on this PR. I don't think the rebase worked. Are you sure you pulled the latest better-playground branch from the stylex repo?

@nmn
Copy link
Contributor

nmn commented Dec 23, 2024

If this is too challenging, you can try creating a new PR from scratch and copy paste the relevant changes.

@aminaopio
Copy link
Contributor Author

aminaopio commented Dec 23, 2024

@aminaopio I'm still seeing a bunch of conflicts on this PR. I don't think the rebase worked. Are you sure you pulled the latest better-playground branch from the stylex repo?

@nmn So it's been up-to-date:
image
Here are my "remote" repos:
image
The issue starts when I run git rebase better-playground inside of my branch (dev-amina-playground). I get a bunch of errors for about 30~ commits and I had to manually resolve them each time I rebased. (Running git config --global rerere.enabled true at the beginning didn't seem to do anything).
image
Where I may have messed up is that I accepted all the current changes inside of each of those commits instead of the incoming? Additionally, some of those commits have conflicts that only get resolved by resetting them to base. Is that the right thing to do for those cases?

I can go ahead and make a new PR, but not sure where in this process I'm messing up

@Jta26
Copy link
Contributor

Jta26 commented Dec 23, 2024

+1 I recommend a new PR. In the past I've had issues where the Vercel CI job randomly fails when you touch the package-lock file after rebasing

@aminaopio
Copy link
Contributor Author

New PR is here: #826

@aminaopio aminaopio closed this Dec 24, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
CLA Signed This label is managed by the Facebook bot. Authors need to sign the CLA before a PR can be reviewed.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Finish implementing the Playground
10 participants