Skip to content
  • Recent
  • Tags
  • Popular
  • Users
  • Search
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse

Lay Theme Forum

  1. Home
  2. General Discussion
  3. Change color of fixed sitetitel/menu when scrolling down page (according to changing row-background)

Change color of fixed sitetitel/menu when scrolling down page (according to changing row-background)

Scheduled Pinned Locked Moved General Discussion
16 Posts 4 Posters 2.0k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • mariusjopenM Offline
    mariusjopenM Offline
    mariusjopen
    Global Moderator
    wrote on last edited by mariusjopen
    #4

    Dear @maarschalk
    I did not test it – but this should work:

    <script>
        var offset = 50;
        var $blackRows;
        var $nav;
        
        Frontend.GlobalEvents.on("newpageshown", function(layoutObj, type, obj){
            $blackRows = jQuery(".blackrow");
            $nav = jQuery("nav");
            $nav.removeClass("white");
        });
        
        jQuery(document).on("scroll", function(){
            $blackRows.each(function(){
                var rect = this.getBoundingClientRect();
                if(rect.top - offset < 0 && rect.bottom - offset > 0){
                    $nav.addClass("white");
    
    
    jQuery( ".sitetitle span" ).text( "NEW TITLE" );
    
                    return false;
                }else{
                    $nav.removeClass("white");
    
    jQuery( ".sitetitle span" ).text( "OLD TITLE" );
    
                }
            });
        });
    </script>
    

    Let me know :-)

    Marius

    www.mariusjopen.world

    1 Reply Last reply
    0
    • M Offline
      M Offline
      maarschalk
      wrote on last edited by
      #5

      Thank you Marius

      One more question: which custom css code should I use for the sitetitle?

      I'm using this one for the menu itself:

      nav.primary a{
      transition: all 200ms ease;
      }

      nav.primary.white a{
      color: white;
      opacity: 1;
      }

      1 Reply Last reply
      0
      • mariusjopenM Offline
        mariusjopenM Offline
        mariusjopen
        Global Moderator
        wrote on last edited by
        #6

        Dear @maarschalk
        you can right click on the website to inspect it.

        There you can see all the classes you can use.

        Hope that helps :-)

        Best!

        Marius

        www.mariusjopen.world

        1 Reply Last reply
        0
        • M Offline
          M Offline
          maarschalk
          wrote on last edited by
          #7

          Hi Marius,

          for some reason, it does'nt seem to work. Either I'm making a mistake in selecting the right class, or a minor thing is wrong in the code?

          Best,
          Bart

          1 Reply Last reply
          0
          • mariusjopenM Offline
            mariusjopenM Offline
            mariusjopen
            Global Moderator
            wrote on last edited by
            #8

            Dear @maarschalk

            I will talk with Armin about that and see what the issue is.

            Best!

            Marius

            www.mariusjopen.world

            1 Reply Last reply
            0
            • mariusjopenM Offline
              mariusjopenM Offline
              mariusjopen
              Global Moderator
              wrote on last edited by
              #9

              Dear @maarschalk

              I debugged the code and it works.

              You need to give a row the class blackrow.

              <script>
                  var offset = 50;
                  var $blackRows;
                  var $nav;
                  
                  Frontend.GlobalEvents.on("newpageshown", function(layoutObj, type, obj){
                      $blackRows = jQuery(".blackrow");
                      $nav = jQuery(".navbar");
                      $nav.removeClass("white");
                      $sitetitle = jQuery(".sitetitle span");
                  });
                  
                  jQuery(document).on("scroll", function(){
              
                      $blackRows.each(function(){
                          var rect = this.getBoundingClientRect();
                          if(rect.top - offset < 0 && rect.bottom - offset > 0){
                              $nav.addClass("white");
                              $sitetitle.text( "NEW TITLE" );
                              return false;
                          }else{
                              $nav.removeClass("white");
                              $sitetitle.text( "OLD TITLE" );
                          }
                      });
                  });
              </script>
              
              .blackrow {
                  background: black;
              }
              
              .white {
                  background: red;
              }
              

              Hope you get it to work!

              Best!

              Marius

              www.mariusjopen.world

              1 Reply Last reply
              0
              • M Offline
                M Offline
                maarschalk
                wrote on last edited by
                #10

                @mariusjopen said in Change color of fixed sitetitel/menu when scrolling down page (according to changing row-background):

                .blackrow {
                background: black;
                }

                .white {
                background: red;
                }

                Yes, thanks a lot for the effort Marius!!

                Best,
                Bart

                1 Reply Last reply
                0
                • mariusjopenM Offline
                  mariusjopenM Offline
                  mariusjopen
                  Global Moderator
                  wrote on last edited by
                  #11

                  Dear @maarschalk

                  great! A pleasure!

                  Marius

                  www.mariusjopen.world

                  1 Reply Last reply
                  0
                  • D Offline
                    D Offline
                    domphilcox
                    wrote on last edited by
                    #12

                    Hey Marius / Armin, I've been trying to apply the most recent code shared but with no joy. I have no experience in writing JQuery or JS from scratch but have managed to use many of the snippets you have kindly shared in the past. Given that this thread is six years old, I wonder if you could let me know if it should still work as described or if it's no out of date. Any help would be greatly appreciated. Thanks v much.

                    1 Reply Last reply
                    0
                    • arminunruhA Offline
                      arminunruhA Offline
                      arminunruh
                      Global Moderator
                      wrote on last edited by
                      #13

                      can you send your website address, /wp-admin/ username and password and a link to this topic to info@laytheme.com?

                      1 Reply Last reply
                      0
                      • arminunruhA Offline
                        arminunruhA Offline
                        arminunruh
                        Global Moderator
                        wrote on last edited by arminunruh
                        #14

                        put this js into lay options -> custom css & html -> custom html at bottom

                        <script>
                            var offset = 50;
                            var $blackRows;
                            
                            var $nav = jQuery(".laynav");
                            var $sitetitle = jQuery(".sitetitle");
                            
                            var checkIfOnABlackRow = function(){
                                $blackRows.each(function(){
                                    var rect = this.getBoundingClientRect();
                                    if(rect.top - offset < 0 && rect.bottom - offset > 0){
                                        $nav.addClass("white");
                                        $sitetitle.addClass("white");
                                        return false;
                                    }else{
                                        $nav.removeClass("white");
                                        $sitetitle.removeClass("white");
                                    }
                                });        
                            }
                            
                            window.laytheme.on('newpageshown', function(){
                                $blackRows = jQuery(".blackrow");
                                checkIfOnABlackRow();
                            })
                            
                            jQuery(document).on("scroll", function(){
                                checkIfOnABlackRow();
                            });
                        </script>
                        

                        by putting this into html at bottom we make sure the site title dom element and nav dom element can be selected cause they were loaded previously.

                        if we'd put this code into <head then we'd need to wait for jquery document ready or use newpageshown event to select these elements, it doesn't make a huge difference

                        and put this css into "custom css":

                        .white {
                            color: white !important;
                        }
                        
                        .white svg path{
                             fill: white;
                        }
                        

                        so your code almost worked.

                        the thing is your site title is a svg, so we need to target the paths of the css to get a fill of white. your css to do that didn't work.

                        also i improved the js a little so it also checks if we are on a black row when we land on a page, instead of just on scroll.

                        and you gave the rows a class of "blackrow" which u did correctly, by right clicking an empty spot in the row, choosing "set html class & id" and entering: blackrow for the class

                        1 Reply Last reply
                        0
                        • D Offline
                          D Offline
                          domphilcox
                          wrote on last edited by
                          #15

                          Yes, Armin! You're a legend. To not only look into this, but the tidy up the code AND explain where I went wrong and why it wasn't work, that's incredibly generous of you. I have a feeling your code will be used on plenty of sites in the future. Thanks again.

                          1 Reply Last reply
                          0
                          • arminunruhA Offline
                            arminunruhA Offline
                            arminunruh
                            Global Moderator
                            wrote on last edited by
                            #16

                            oh thanks a lot!! :) <3

                            1 Reply Last reply
                            0
                            • arminunruhA arminunruh referenced this topic on
                            • D domphilcox referenced this topic on
                            • arminunruhA arminunruh referenced this topic on
                            Reply
                            • Reply as topic
                            Log in to reply
                            • Oldest to Newest
                            • Newest to Oldest
                            • Most Votes


                            I also code custom websites or custom Lay features.
                            šŸ’æ Email me here: šŸ’æ
                            info@laytheme.com

                            Our Web Development company: 100k.studio

                            Want to tip me? https://www.paypal.com/paypalme/arminunruh

                            Before you post:
                            1. When using a WordPress Cache plugin, disable it or clear your cache.
                            2. Update Lay Theme and all Lay Theme Addons
                            3. Disable all Plugins
                            4. Go to Lay Options → Custom CSS & HTML, click "Turn Off All Custom Code", click "Save Changes"

                            This often solves issues you might run into

                            When you post:
                            1. Post a link to where the problem is
                            2. Does the problem happen on Chrome, Firefox, Safari or iPhone or Android?
                            3. If the problem is difficult to explain, post screenshots / link to a video to explain it
                            Online Users
                            A
                            alasdair17
                            Forgot your key, lost your files, need a previous Lay Theme or Addon version? Go to www.laykeymanager.com
                            laytheme.com
                            • Login

                            • Don't have an account? Register

                            • Login or register to search.
                            • First post
                              Last post
                            0
                            • Recent
                            • Tags
                            • Popular
                            • Users
                            • Search