-
Notifications
You must be signed in to change notification settings - Fork 26k
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
Apply code highlighting background to code in HTML headers <h1>
through <h6>
#2771
Apply code highlighting background to code in HTML headers <h1>
through <h6>
#2771
Conversation
...instead of port 4000, since port 4000 interferes with programs such as [NoMachine](https://www.nomachine.com/).
...using the Sublime Text editor [MarkdownTOC](https://github.com/naokazuterada/MarkdownTOC) tool! Here are my user settings for it: ```json { "defaults": { "autoanchor": true, "autolink": true, "bracket": "round", "levels": [1,2,3,4,5,6], "indent": "\t", "remove_image": true, "link_prefix": "", "bullets": ["-"], "lowercase": "only_ascii", "style": "ordered", "uri_encoding": true, "markdown_preview": "" }, "id_replacements": [ { "pattern": "\\s+", "replacement": "-" }, { "pattern": "<|>|&|'|"|&mmistakes#60;|&mmistakes#62;|&mmistakes#38;|&mmistakes#39;|&mmistakes#34;|!|#|$|&|'|\\(|\\)|\\*|\\+|,|/|:|;|=|\\?|@|\\[|\\]|`|\"|\\.|\\\\|<|>|{|}|™|®|©|%", "replacement": "" } ], "logging": false } ```
The Table of Contents in the readme can be viewed here, just above the screenshots: https://github.com/ElectricRCAircraftGuy/minimal-mistakes/tree/upstream-theme_fixes. I made it collapsed by default so it doesn't distract from the main content. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a bit too messy. Changing large chunks of README
that doesn't have much to do with the original intention isn't a good practice, nor do I like it though.
My real question is, is this change really useful to most users? Given that the CSS change is simple enough for one to apply on their own, and that some may argue that the result is not desired, I don't see much value in this PR.
@@ -15,13 +15,42 @@ Minimal Mistakes is a flexible two-column Jekyll theme, perfect for building per | |||
|
|||
**Note:** The theme uses the [jekyll-include-cache](https://github.com/benbalter/jekyll-include-cache) plugin which will need to be installed in your `Gemfile` and added to the `plugins` array of `_config.yml`. Otherwise you'll encounter `Unknown tag 'include_cached'` errors at build. | |||
|
|||
## Table of Contents |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Uh, what's the point of this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's a Table of Contents for the readme. It helps orient people quickly to the topics of interest, and easily jump around. Explore this readme live and interactively here: https://github.com/ElectricRCAircraftGuy/minimal-mistakes/tree/upstream-theme_fixes.
Notice there's an arrow to "click to expand" and view the whole Table of Contents. It's super useful I think. I really like it.
@@ -37,7 +37,8 @@ task :preview do | |||
"destination" => base.join('test/_site').to_s, | |||
"force_polling" => false, | |||
"serving" => true, | |||
"theme" => "minimal-mistakes-jekyll" | |||
"theme" => "minimal-mistakes-jekyll", | |||
"port" => 4001, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This probably wasn't intended to be committed, right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No, this is very much intentional. It solves the NoMachine problem I describe above, and causes no harm to anyone not using NoMachine.
## Development | ||
|
||
To set up your environment to develop this theme, run `bundle install`. | ||
|
||
To test the theme, run `bundle exec rake preview` and open your browser at `http://localhost:4000/test/`. This starts a Jekyll server using content in the `test/` directory. As modifications are made to the theme and test site, it will regenerate and you should see the changes in the browser after a refresh. | ||
To test the theme, run `bundle exec rake preview` and open your browser at [`http://localhost:4001/test/`](http://localhost:4001/test/). This starts a Jekyll server using content in the `test/` directory. As modifications are made to the theme and test site, it will regenerate. Note that you will see the changes in your browser only after doing a manual page refresh. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Still don't quite get the point of this change. The wording seems fine, though.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See bullet 4 in my PR description, where I explained it:
- Update Rakefile to serve jekyll on port 4001 instead of 4000, so as to avoid conflicts with NoMachine. See my answer here for more background and info on this.
For anyone who uses NoMachine, which is a very popular remote login tool, it uses port 4000 too and conflicts with the web server during website testing. This fixes that. For anyone else using NoMachine, it solves their problem without them having to search around a bunch to figure it out, and for everyone else it causes no harm, so is overall a useful change.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I haven't even heard about NoMachine (I use SSH and VS Code). It's not convincing to change the default port because of a software that has no relation with Jekyll. FYI: I have localhost:4000
saved in my browser bookmark for quick access, and this is going to break it.
I agree this is 3 small changes in one PR, but that's kind of hurtful. I've put great effort into making this PR clean, neat, easy to read, easy to understand, and well-described in the PR's description. This PR is 3 small changes in one:
If someone with approval and merge authority wants me to split the PR, I can. Or, they can commandeer the PR and do it. If they want to accept only parts of it, the fastest way is for them to manually pull my branch, fix it up how they want it, and then merge it to the repo. My changes they want do get in, and any they don't, don't.
On all 3 of the main markdown-based interactive sites in the world: Stack Overflow, GitHub, and GitLab, headers with code have the code shaded, like this: I'm a header
|
I don't have any extra access to this repo than you do, but I'm sure @mmistakes's thoughts would be in line with mine. Questions to ask before deciding a feature is useful:
Given the above arguments, I'm in favor of none of these changes. Let the power that be decide - I have no authority. |
This isn't quite true. It depends on your text editor. The ToC I added uses MarkdownTOC, which is a Sublime Text plugin. These markers:
I still disagree with this and think it would do a lot of people good. We could help many people by merging this change. If @mmistakes doesn't implement this change/merge this PR, I hope he at least documents what I've done officially. It took me a long time of research, spread out over months in evenings after work, and on weekends, to figure this and other things out. Again, I, and most others doing Jekyll pages I think, have no prior web or HTML or real CSS experience. |
While maintaining the ToC appears easy for you, it requires one to use Sublime Text and use that specific plugin, which obviously everyone does not. You can say "it's easy according to your workflow", but it doesn't necessarily hold true for someone else. The same holds for your other arguments. The point here is, you speak from your experiences and perspectives, but as a 7.5k-star open-source project, we have to take other users' favor and dependency into account. That something works for you in no way implies it'll also work for someone else. Unless there's a compelling reason to, default settings shouldn't be changed, nor should breaking changes be introduced. That's my $0.02. |
Let's not consider having to update a single optional bookmark in one's browser from http://localhost:4000/test/ to http://localhost:4001/test/ a "breaking change." That's a bit of a stretch. |
I don't want to be too harsh, but here's my view on all three changes. The core: CSS changesThe only change related to the title of this PR is code background is a few lines of new CSS, which could be simplified as such: h1, h2, h3, h4, h5, h6 {
> code {
background: $code-background-color;
}
} After taking a closer look, I noticed that it isn't carefully done. For example, someone using code-in-heading combined with header overlay sees an ugly artifact: So at best this CSS should be relocated inside This is one way the change is breaking, though it can be easily fixed. Again, just because you want this change doesn't mean someone else does. This is resembled by the fact that all your linked issues have no input or interaction from other users (excluding Michael, of course). See #2246 for example: Someone else opened that issue, and 3 more users showed interest in that feature. And more, see how the result is only a few lines of CSS with no complicated nesting or location?
That's not a fault of the theme. Someone with basic knowledge of CSS should be able to achieve this in a few minutes. There are plenty of introductory CSS tutorials online, and it doesn't even cost you an hour to learn the required level of knowledge to be able to figure this out. The Readme ToCI'll basically reiterate my last commment. You said you generated the ToC "easily" with your setup (Sublime Text + a plugin). In order for the same task to become comparably easy for someone else, they have to at best follow your setup, install and open Sublime Text and the plugin to update the ToC, after their own favorite workflow. For example, I use VS Code as my code editor / IDE, and occasioanlly Typora as my Markdown editor. It's nowhere near compelling that I have to add Sublime Text just for this ToC. The port changeI'll put this point first: This repository is not intended for end users who want to build a website with this theme. It is therefore assumed that someone running Changing one bookmark for me surely isn't a great deal of a problem, making more people have to change their bookmarks is. Setting that aside, it's not this theme's fault that the port conflicts with another software, so it makes less sense to "fix it" here than to fix it with Jekyll. Not to mention that NoMachine isn't as popular as other remote desktop (RD) solutions like VNC (default port 5900) and RDP (default port 3389). 4000 is a port just too common for a conflict, so I'd even doubt if a long-running software should use it. Given that the port can be specified per invocation with command-line options, this is not a desirable change to have. Summing upSo basically you squashed 3 unrelated changes into one PR that arguably makes reviewing and cherry-picking more complex than it should, and in addition this PR introduced
I'll copy my word from the previous comment as the last line, with emphasis added:
|
Now your README change is useless. |
This pull request has been automatically marked as stale because it has not had recent activity. This pull request will automatically be closed in 7 days if no further activity occurs. Thank you for all your contributions. |
Bump. @mmistakes |
I'm 100% sure Michael wouldn't like this PR in its current state. The only change I have hope that Michael may appreciate is the color change from |
My views are completely in alignment with @iBug's comments. Fixing the code block background seems like a no brainer to me, but it needs to be the only commit for the pull request. It also needs to be tested across all the skins to make sure it looks good in all the different color schemes. |
This pull request has been automatically marked as stale because it has not had recent activity. This pull request will automatically be closed in 7 days if no further activity occurs. Thank you for all your contributions. |
This is an enhancement or feature.
Fixes #2780.
Summary
Modify
_base.scss
to apply code highlighting background to code in headers. It now looks like this. Notice the code in headers now has a grey background. Before this PR, code in headers would NOT get the grey background, which made it very hard to tell it was code!.
Darken background color from
#fafafa
to$lighter-gray
, since the former is so light it's hard to see.Add Table of Contents to README. See this commit for details: cd2726c.
Update Rakefile to serve jekyll on port 4001 instead of 4000, so as to avoid conflicts with NoMachine. See my answer here for more background and info on this.
Update changelog.
Context