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

Replace deprecated darken with color.adjust for Sass compliance #634

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

uditjainstjis
Copy link

Summary

Changes/explanation

  • darken function was replaced with color.adjust which is supported
  • '{' bracket was added at the missing place
  • Ran the command: sass /css/ion_icon_customization.scss /css/ion_icon_customization.css to generate the compiled css file, which was necessary for "@use keyword" in @use "sass:color" which was used to use color thing to replaced darken the main thing.

Testing

  • Build the site locally with jekyll serve and verify image and list rendering.
  • Check bullet points and image scaling on mobile and desktop views.
  • Ensured now no error is present in the terminal and is clear.

Copy link
Contributor

@quozl quozl left a comment

Choose a reason for hiding this comment

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

  • don't write so much in the pull request alone, what you said should be in the commit message,
  • rewrite your commit message and force push, see our guidance for a checklist,
    • add the problem to the commit message, as the GitHub issue will be lost and the commit message kept,
    • add the solution to the commit message, as the GitHub pull request will be lost and the commit message kept,
  • do not make changes unrelated to your stated intent, be more careful, use interactive add of git if necessary to avoid any changes made by your software tools,

Please fix these things in your existing branch, squash your commits, and then force push to update the pull request.

css/ion_icon_customization.css Show resolved Hide resolved
css/ion_icon_customization.css.map Show resolved Hide resolved
css/ion_icon_customization.scss Show resolved Hide resolved
css/ion_icon_customization.scss Show resolved Hide resolved
css/ion_icon_customization.scss Show resolved Hide resolved
css/ion_icon_customization.scss Show resolved Hide resolved
css/ion_icon_customization.scss Show resolved Hide resolved
css/ion_icon_customization.scss Show resolved Hide resolved
@quozl
Copy link
Contributor

quozl commented Jan 10, 2025

While testing another pull request, I hit the deprecation warning so had a quick look at this.

Made changes as requested and pushed to pr634-test branch as 422361a ("Fix darken() is deprecated on local serve"), then tested.

The test failed as follows;

bundle exec jekyll serve --incremental
Configuration file: /root/www/_config.yml
            Source: /root/www
       Destination: /root/www/_site
 Incremental build: enabled
      Generating... 
       Jekyll Feed: Generating feed for posts
Error: There is no module with the namespace "color".
  ╷
9 │ $facebook-color-hover: color.adjust($facebook-color, $darken-percent);
  │                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  ╵
  /root/www/css/ion_icon_customization.scss 9:24  root stylesheet 
  Conversion error: Jekyll::Converters::Scss encountered an error while converting 'css/ion_icon_customization.scss':
                    There is no module with the namespace "color".
                    ------------------------------------------------
      Jekyll 4.3.4   Please append `--trace` to the `serve` command 
                     for any additional information or backtrace. 
                    ------------------------------------------------
/var/lib/gems/3.2.0/gems/jekyll-sass-converter-3.0.0/lib/jekyll/converters/scss.rb:175:in `rescue in convert': There is no module with the namespace "color". (Jekyll::Converters::Scss::SyntaxError)

        raise SyntaxError, e.message
              ^^^^^^^^^^^^^^^^^^^^^^
        from /var/lib/gems/3.2.0/gems/jekyll-sass-converter-3.0.0/lib/jekyll/converters/scss.rb:159:in `convert'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:105:in `block in convert'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:104:in `each'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:104:in `reduce'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:104:in `convert'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:84:in `render_document'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:63:in `run'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:572:in `render_regenerated'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:564:in `block in render_pages'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:563:in `each'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:563:in `render_pages'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:211:in `render'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:80:in `process'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/command.rb:28:in `process_site'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/commands/build.rb:65:in `build'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/commands/build.rb:36:in `process'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/command.rb:91:in `block in process_with_graceful_fail'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/command.rb:91:in `each'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/command.rb:91:in `process_with_graceful_fail'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/commands/serve.rb:86:in `block (2 levels) in init_with_program'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary/command.rb:221:in `block in execute'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary/command.rb:221:in `each'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary/command.rb:221:in `execute'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary/program.rb:44:in `go'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary.rb:21:in `program'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/exe/jekyll:15:in `<top (required)>'
        from /usr/local/bin/jekyll:25:in `load'
        from /usr/local/bin/jekyll:25:in `<main>'
/var/lib/gems/3.2.0/gems/sass-embedded-1.83.1-x86_64-linux-gnu/lib/sass/compiler/host.rb:86:in `compile_request': There is no module with the namespace "color". (Sass::CompileError)
        from /var/lib/gems/3.2.0/gems/sass-embedded-1.83.1-x86_64-linux-gnu/lib/sass/compiler.rb:171:in `compile_string'
        from /var/lib/gems/3.2.0/gems/sass-embedded-1.83.1-x86_64-linux-gnu/lib/sass/embedded.rb:37:in `compile_string'
        from /var/lib/gems/3.2.0/gems/jekyll-sass-converter-3.0.0/lib/jekyll/converters/scss.rb:160:in `convert'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:105:in `block in convert'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:104:in `each'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:104:in `reduce'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:104:in `convert'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:84:in `render_document'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/renderer.rb:63:in `run'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:572:in `render_regenerated'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:564:in `block in render_pages'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:563:in `each'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:563:in `render_pages'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:211:in `render'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/site.rb:80:in `process'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/command.rb:28:in `process_site'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/commands/build.rb:65:in `build'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/commands/build.rb:36:in `process'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/command.rb:91:in `block in process_with_graceful_fail'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/command.rb:91:in `each'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/command.rb:91:in `process_with_graceful_fail'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/lib/jekyll/commands/serve.rb:86:in `block (2 levels) in init_with_program'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary/command.rb:221:in `block in execute'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary/command.rb:221:in `each'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary/command.rb:221:in `execute'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary/program.rb:44:in `go'
        from /var/lib/gems/3.2.0/gems/mercenary-0.4.0/lib/mercenary.rb:21:in `program'
        from /var/lib/gems/3.2.0/gems/jekyll-4.3.4/exe/jekyll:15:in `<top (required)>'
        from /usr/local/bin/jekyll:25:in `load'
        from /usr/local/bin/jekyll:25:in `<main>'

What do you suggest?

@uditjainstjis
Copy link
Author

The problem is there are delimeters(--- ---) in the first two lines of your code, which isn't recognised by sass causing this random error, those two lines are needed to be removed to remove the errors.
image

@uditjainstjis
Copy link
Author

and while resolving things which you said i am facing an issue, that my code was replacing depreciated to color.adjust same as like yours (without delimeters) , after that errors are gone but when loading the page
[2025-01-11 09:33:54] ERROR '/css/ion_icon_customization.css' not found.
this error comes into the terminal.

When darken is replaced with color.adjust i noticed that on localhost on /css/ion_icon_customization.css shows not found, but with darken func it shows the code, somehow making file not reachable when switching to color.adjust

The problem is darken was depreciated and color.adjust is new, so color.adjust requires the code to be compiled into some file,
that's why in my PR after replacing the function's I ran this command
sass /css/ion_icon_customization.scss /css/ion_icon_customization.css
and created compiled css file, which after then started working nicely and i pushed a PR,
but you said that i should not commit generated file, I am from then facing issue that if I will not commit the generated files ,code won't work and throw the error [2025-01-11 09:33:54] ERROR '/css/ion_icon_customization.css' not found. ,
how to not commit generated files which you said in the message?

@quozl
Copy link
Contributor

quozl commented Jan 12, 2025

Thanks, that's interesting.

Using the master branch at 75b2a0d ("Fix section name wording") and removing the two --- lines from css/ion_icon_customization.scss breaks the automatic sass that provides css/ion_icon_customization.css so it doesn't seem right to do that.

You're not seeing errors because you've turned off that part of the build.

Your branch has one unconverted darken( call.

Your branch does not use the correct syntax; the second argument to color.adjust is to be named $lightness:.

I've made further edits in an attempt to get closer to merge, and pushed 8cb4bf3 to pr624-test branch. Please review this commit in detail; it is derived from your work, and has your name on it.

Please do be careful; a change very much like this broke the site build in November, which you should have seen in the closed pull requests and the commit history. You don't mentioned either of these in your commit messages or pull request, so I'm not sure if you are aware of the problem. Please;

  • read the commit diffs for November, particularly around 16th and 22nd,
  • read the pull request that was merged on the 16th.

(rhetorical; if you've not seen those two sources of information, what are you doing changing this?)

Integrate this information and determine if it is safe to proceed.

@mohanamisra mentioned because of previous commits.

@pikurasa mentioned because of revert.

@MostlyKIGuess
Copy link
Member

Tested and works as intended.

@uditjainstjis
Copy link
Author

@quozl sorry for delayed response, I have carefully looked at pull request of Nov 16 which broke the build and commits of between November 16-22.
I have read commit carefully, on line 34 one in the file "-" is missing before $dark-percent rest everything is good, I have tested locally with jekyll using verbose too there is no harmful error in the console and that commit commit is good to merge to close this PR

@quozl
Copy link
Contributor

quozl commented Jan 16, 2025

Thanks. While that's interesting, it is not syntactically incorrect, and so isn't a cause of build failure. I think we need to better understand what happened, so we don't do it again.

https://github.com/sugarlabs/www/actions/runs/11862112537 is the failed build. Are you able to explain why that build failed and your build won't?

@uditjainstjis
Copy link
Author

Hey @quozl, I’ve identified the reason why the build failed last time, and it’s quite an interesting discovery!

We are replacing the deprecated darken() function with color.adjust(). However, color.adjust() is only supported in Jekyll 4, while our www repository is currently running on Jekyll 3, which caused the build to fail.

To investigate, I deployed the www project by reproducing the environment and GitHub Actions on my own repository. During this process, I discovered that GitHub defaults to Jekyll 3 unless we explicitly configure a Jekyll 4 workflow. Since no Jekyll workflow is currently configured in our www project, the system automatically uses Jekyll 3.

To resolve this and avoid similar build failures in the future when using newer functions, I recommend configuring a Jekyll workflow to explicitly use Jekyll 4. This would ensure we follow best practices and stay compatible with the latest features. What are your thoughts on this approach :) ?

@quozl
Copy link
Contributor

quozl commented Jan 20, 2025

You're saying we can upgrade to Jekyll 4 to fix this? Great! How?

@moodyadi2006
Copy link

You can update from Jekyll 3 to Jekyll 4 in this way :

  1. Firstly Backup Your Site
  2. In your Gemfile, update the Jekyll version to ~> 4.0.
  3. Run bundle update jekyll to apply the changes.
  4. Review and update plugins in your Gemfile for Jekyll 4 compatibility.
  5. Use bundle update to ensure all dependencies are up-to-date.
  6. Compare your _config.yml with Jekyll 4's documentation and adapt to changes (e.g., switch to rouge for syntax highlighting).
  7. Replace jekyll auto with jekyll serve.
  8. Update _config.yml to use highlighter: rouge.
  9. Run bundle exec jekyll serve to test your site and fix any issues related to templates or plugins.
  10. Ensure your hosting or CI/CD pipeline supports Jekyll 4.

In this way you can update and for further information refer to Jekyll's documentation or community forums.

@pikurasa
Copy link
Contributor

Some of those steps are unnecessary for us, since we host on GH and use their server for deployment. Git acts as a backup, and we trust GH to backup whatever they need to keep web hosting services going.

One of the most important considerations would be whether or not our chosen theme and our customizations would work with the upgrade. We probably would need to fix a lot of things. We may even decide that we should move to another theme as part of the upgrade process.

I recommend looking at the upstream code for our theme first, which is hosted here: https://github.com/themefisher/airspace-jekyll

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.

Deprecated function darken being used, causing warning
5 participants