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

Restructure tutorial to separate instructions based on operating system #1796

Open
wants to merge 20 commits into
base: restructure-tutorial
Choose a base branch
from

Conversation

amakarudze
Copy link
Contributor

The tutorial now covers installation guides for 5 platforms, namely, RunCode, ChromeBook, Linux, OS X and Windows. Reading through the installation guide while skipping instructions for 4 platforms you're not using has become tedious. It also makes it difficult to add more platforms or add new content as there are many parts of the tutorial to make edits to.

Separating these installation and deployment instructions by platform makes it easy to address gaps in documentation for each platform. It also makes it easy as it removes the need to read NOTE: If you're not using ... in many places. This is a big change and the first restructuring exercise. Further refactoring may be necessary to reduce repetition.

This pull request addresses #1792 and attempts to shorten the tutorial by grouping OS/platform related content together so that, for example, a Windows user only reads Windows content and a OS X reads only OS X content and so on. Where there are no specific requirements necessary for ChromeBook and RunCode setups, their links have been set to point to Linux instructions.

Changes in this pull request:

  • Changes the structure of the tutorial by separating guidelines/instructions for setup/installation by operating system thereby shortening the amount of content a reader should use. Instructions are grouped under RunCode, ChromeBook, Linux, OSX or Windows and an attendee can choose the platform they are working on and read instructions for only their platform.
  • Installation page now gives user option to choose platform/OS.
  • Menu options for the entire tutorial now appear under each platform.
  • Folders for chromebook, linux, macosx, runcode and windows have been introduced to group content by operating system/platform.
  • Content for Installation, Introduction to Command Line, Python Installation, Python Introduction , Your First Django Project! and Deploy has been separated/rearranged by operating system/platform.
  • Folders introduction_to_command_line, django_installation, django_start_project and python_installation have been refactored to show content by operating system and have been removed.
  • python_introduction/README.md file contents have been split into two parts instructions.md and instructions_part_two.md to remove out parts that are OS specific. The general parts are now included in the README.md for each platform.
  • Remove deploy/README.md
  • SUMMARY.md has been changed to have links grouped by OS/platform.

@amakarudze amakarudze requested a review from a team as a code owner April 28, 2023 07:57
Copy link
Collaborator

@ekohl ekohl left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You also reformat sentences to have hard line breaks at 80 chars. That makes the PR very large and will also mean all translations must update a lot. How hard would it be to undo that line break change?

en/linux/deploy/install_git.md Outdated Show resolved Hide resolved
@amakarudze
Copy link
Contributor Author

You also reformat sentences to have hard line breaks at 80 chars. That makes the PR very large and will also mean all translations must update a lot. How hard would it be to undo that line break change?

So @das-g suggested the semantic line breaks in #1781 as they would make it easy to comment on one sentence. They are not hard to remove, however, I would need to know whether to keep each sentence separate and have no clear defined line break or adjust to 120 or have no clearly defined line break policy at all @ekohl. What's your take on this?

@das-g
Copy link
Member

das-g commented May 9, 2023

So @das-g suggested the semantic line breaks in #1781 as they would make it easy to comment on one sentence.

I suggested semantic line breaks

for newly added paragraphs

in #1781 (comment), by which I meant "for newly added paragraphs only" and for completely new paragraphs, not moved or edited pre-existing ones. Sorry if my phrasing there wasn't clear enough to convey that. We indeed shouldn't mix paragraph reflows (whether to semantic line breaks or any other convention) into PRs that also change something else, as that will obfuscate the diffs and make the changes even harder to review than not having semantic linefeeds to begin with does.)

(We could of course consider converting existing paragraphs to semantic linefeeds in separate pull requests focusing only on that. I hope that Crowdin would usually came up with the same strings when splitting the text into translatable sentences, and would thus either not require re-translation or at least offer the current translation as suggestion.)

@amakarudze amakarudze requested a review from ekohl June 19, 2023 22:41
@elena
Copy link
Member

elena commented Oct 5, 2023

Hi Anna,

For Hacktoberfest event there are 2 of us working through this pull request (hello https://github.com/jwhhh !).

We want to confirm there aren't that many actual material changes?

It appears as though mainly file are rearranged and there are substantially more lines because an character line limit is now being used.

We've spent some time looking here and our strategy is that we will break it up and look at the source and also look at the published page and see if it seems OK.

It is harder to check if there have been any major instructions changes but if we find any of these we will check them also.

Generally we feel good so far about the update, @jwhhh just observed that perhaps some of the relative paths need to be updated and is looking to commit fixes.

Another option could be to release a version 2 beta kind of thing? But overall this is great work we're hoping that we can approve soon!

@amakarudze
Copy link
Contributor Author

Hi Anna,

For Hacktoberfest event there are 2 of us working through this pull request (hello https://github.com/jwhhh !).

We want to confirm there aren't that many actual material changes?

It appears as though mainly file are rearranged and there are substantially more lines because an character line limit is now being used.

We've spent some time looking here and our strategy is that we will break it up and look at the source and also look at the published page and see if it seems OK.

It is harder to check if there have been any major instructions changes but if we find any of these we will check them also.

Generally we feel good so far about the update, @jwhhh just observed that perhaps some of the relative paths need to be updated and is looking to commit fixes.

Another option could be to release a version 2 beta kind of thing? But overall this is great work we're hoping that we can approve soon!

Thanks @elena. I think probably having a version 2 beta would work in this case and leave version 1 as is. Let me work on that for now. I just ran a Django Girls workshop and it was sad participants getting errors because they followed instructions not meant for their platform. Made me wish we had this available sooner rather than later.

Copy link

@anaschwendler anaschwendler left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

General notes:

It looks very tied together! Awesome work @amakarudze !! Looks like great improvement!
In general, I think it works as it should, and also, would be good to open to fix as people use it :) So, we try to catch as much as we can, but to make it perfect, only with more contribs <3

In Chromebook installation I see no Python anywhere, and not in Linux installation, but I see in macOS and Windows?:
image

@@ -1,27 +1,47 @@
---

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we need to do those changes with this PR? 🤔
Otherwise, I would do them separately, just so we can make it slightly smaller 😅

* [Django installation](django_installation/README.md)
* [Django Installation](django_installation/README.md)
* [RunCode - Django installation](runcode/django_installation/README.md)
* [ChromeBook - Django installation](chromebook/README.md#glitch-cloud-ide)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here it points to the section, not README.MD, is it supposed to be?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The Chromebook links have always been like that, pointing to a section in a README.md and not the README.md itself because they are in one file, though different applications are being installed. It's not a change I am introducing, and changing those links would introduce a new change. That's why I left them like that.

{% include "/django_installation/instructions.md" %}
To continue, pick your platform/operating system:
* [RunCode Cloud](../runcode/django_installation/README.md)
* [ChromeBook](../chromebook/README.md#glitch-cloud-ide)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here as well, should we point to README.md only?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same as above.

@fltfx
Copy link
Member

fltfx commented Oct 13, 2024

@elena @anaschwendler @amakarudze Just following up on this PR. It's a year old now, so is all the Cloud 9 chromebook stuff still relevant? Should I merge?

@das-g
Copy link
Member

das-g commented Oct 13, 2024

The cloud 9 stuff will lead to merge conflicts due to #1847. (It doesn't here yet, because this PR here doesn't target branch master but restructure-tutorial and because restructure-tutorial isn't up to date with master at the moment.

@fltfx
Copy link
Member

fltfx commented Oct 14, 2024

@das-g Okay, so is the proposed solution to merge master into restructure-tutorial, then resolve conflicts here, then merge this PR into master ?

@das-g
Copy link
Member

das-g commented Oct 14, 2024

@das-g Okay, so is the proposed solution to merge master into restructure-tutorial, then resolve conflicts here, then merge this PR into master ?

I think so, yeah. Though let's first hear from @amakarudze, whether a change in the direction of this PR is still being pursued. There's some review feedback by anaschwendler that wasn't acted or commented on for almost a year.

@amakarudze
Copy link
Contributor Author

@das-g Okay, so is the proposed solution to merge master into restructure-tutorial, then resolve conflicts here, then merge this PR into master ?

I will act on the feedback from @anaschwendler and also merge the master branch into this branch so I can resolve conflicts here before merging into the master branch. It took a while to get feedback, and I got caught up with many other things during that time. Will make time for this in these few weeks left of the year.

@anaschwendler
Copy link

Hey @amakarudze 👋

Let me know if you would like another round of reviews any time :)
I could do a run-through again before merging; also, let me know if you need any assistance!

See you!

fix: relative image paths in specific os folders
@amakarudze
Copy link
Contributor Author

General notes:

It looks very tied together! Awesome work @amakarudze !! Looks like great improvement! In general, I think it works as it should, and also, would be good to open to fix as people use it :) So, we try to catch as much as we can, but to make it perfect, only with more contribs <3

In Chromebook installation I see no Python anywhere, and not in Linux installation, but I see in macOS and Windows?: image

PythonAnywhere is not there for Chromebooks because that's how Chromebook was set up. There are only instructions for setting up those accounts, and I can only assume they follow Linux instructions after that. I only separated instructions that were OS specific, and Chromebook is only mentioned at installation; at all other steps, it is not mentioned. It's something that can be looked into later.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants