Skip to content

NodeBB Footer

Solved Customisation
10 3 2.1k 1
  • Hi Mark,

    I hope you’re well?

    I’m looking to add a footer to the forum, do you know how this is achievable?

    Many thanks

  • Hi Mark,

    I hope you’re well?

    I’m looking to add a footer to the forum, do you know how this is achievable?

    Many thanks

    @jac there’s a widget for the footer area. Have you tried this ?

  • @jac there’s a widget for the footer area. Have you tried this ?

    @phenomlab said in NodeBB Footer:

    @jac there’s a widget for the footer area. Have you tried this ?

    I haven’t yet no mate. I’m currently stuck at the in-laws. 5 positive lateral flow tests later 🤔 I don’t understand it. Everyone here has been so careful, I did tests two days and a day before I left all negative. No one here has been out as they are in vulnerable bracket, I can only think it’s from work where some people don’t adhere to the rules 😑.

  • @phenomlab said in NodeBB Footer:

    @jac there’s a widget for the footer area. Have you tried this ?

    I haven’t yet no mate. I’m currently stuck at the in-laws. 5 positive lateral flow tests later 🤔 I don’t understand it. Everyone here has been so careful, I did tests two days and a day before I left all negative. No one here has been out as they are in vulnerable bracket, I can only think it’s from work where some people don’t adhere to the rules 😑.

    @jac no surprises there mate. Was very unwell Christmas Day but tested negative. 2 days later positive followed by my wife and daughter (who is vulnerable) then my father in law who is also vulnerable.

    I’ve tested negative for two days with LF but still feel really fatigued. My wife is still positive but getting better. My daughter is still positive and has been given the tablet medication also.

  • @phenomlab said in NodeBB Footer:

    o surprises there mate. Was very unwell Christmas Day but tested negative. 2 days later positive followed by my wife and daughter (who is vulnerable) then my father in law who is also vulnerable.
    I’ve tested negative for two days with LF but still feel really fatigued. My wife is still positive but getting better. My daughter is still positive and has been given the tablet medication also.

    @JAC @phenomlab

    Strength to both. I am sending you positive waves.

  • @jac no surprises there mate. Was very unwell Christmas Day but tested negative. 2 days later positive followed by my wife and daughter (who is vulnerable) then my father in law who is also vulnerable.

    I’ve tested negative for two days with LF but still feel really fatigued. My wife is still positive but getting better. My daughter is still positive and has been given the tablet medication also.

    @phenomlab said in NodeBB Footer:

    @jac no surprises there mate. Was very unwell Christmas Day but tested negative. 2 days later positive followed by my wife and daughter (who is vulnerable) then my father in law who is also vulnerable.

    I’ve tested negative for two days with LF but still feel really fatigued. My wife is still positive but getting better. My daughter is still positive and has been given the tablet medication also.

    Wow, so sorry to hear that mate. Wishing you and the family a speedy recovery mate. 🤝🏻

  • @phenomlab said in NodeBB Footer:

    o surprises there mate. Was very unwell Christmas Day but tested negative. 2 days later positive followed by my wife and daughter (who is vulnerable) then my father in law who is also vulnerable.
    I’ve tested negative for two days with LF but still feel really fatigued. My wife is still positive but getting better. My daughter is still positive and has been given the tablet medication also.

    @JAC @phenomlab

    Strength to both. I am sending you positive waves.

    @downpw said in NodeBB Footer:

    @phenomlab said in NodeBB Footer:

    o surprises there mate. Was very unwell Christmas Day but tested negative. 2 days later positive followed by my wife and daughter (who is vulnerable) then my father in law who is also vulnerable.
    I’ve tested negative for two days with LF but still feel really fatigued. My wife is still positive but getting better. My daughter is still positive and has been given the tablet medication also.

    @JAC @phenomlab

    Strength to both. I am sending you positive waves.

    Thanks very much 👍🏻

  • @phenomlab said in NodeBB Footer:

    o surprises there mate. Was very unwell Christmas Day but tested negative. 2 days later positive followed by my wife and daughter (who is vulnerable) then my father in law who is also vulnerable.
    I’ve tested negative for two days with LF but still feel really fatigued. My wife is still positive but getting better. My daughter is still positive and has been given the tablet medication also.

    @JAC @phenomlab

    Strength to both. I am sending you positive waves.

    @downpw many thanks

  • @phenomlab said in NodeBB Footer:

    @jac no surprises there mate. Was very unwell Christmas Day but tested negative. 2 days later positive followed by my wife and daughter (who is vulnerable) then my father in law who is also vulnerable.

    I’ve tested negative for two days with LF but still feel really fatigued. My wife is still positive but getting better. My daughter is still positive and has been given the tablet medication also.

    Wow, so sorry to hear that mate. Wishing you and the family a speedy recovery mate. 🤝🏻

    @jac and you. Hope all is well and you recover quickly

  • @jac and you. Hope all is well and you recover quickly

    @phenomlab said in NodeBB Footer:

    @jac and you. Hope all is well and you recover quickly

    Thanks pal 😁🤝🏻

  • phenomlabundefined phenomlab has marked this topic as solved on

Did this solution help you?
Did you find the suggested solution useful? Support 💗 Sudonix with a coffee
If your organisation needs deeper expertise around infrastructure, security, or technology leadership, learn more about Phenomlab Ltd. Many of the deeper technical guides behind Sudonix are published there.

Related Topics
  • CSS codes to prevent votes to disappear

    Solved Customisation nodebb
    3
    1 Votes
    3 Posts
    894 Views
    @phenomlab yes, it is thanks a lot…
  • Forum Icons NodeBB

    Solved Customisation icons forum nodebb
    13
    0 Votes
    13 Posts
    2k Views
    @cagatay That matches what I see [image: 1667218162107-4f0f858d-9812-42b1-9f61-ffb13d31dccd-image.png]
  • Fontawesome 5

    Unsolved Customisation fonts css nodebb
    14
    1 Votes
    14 Posts
    3k Views
    @pwsincd hi. Just following up on this thread (I know it’s old) but was curious to understand if it’s still an issue or not ?
  • 5 Votes
    9 Posts
    4k Views
    @phenomlab Very very great Mark Thanks again, It’s perfect now ! –> I share my code that I modified. I’ve added French and English comments. If you see things to change Mark, don’t hesitate. As usual, all the access paths (FA icons, logo) will have to be modified according to your architecture. You can also very well add/remove time slots and change welcome messages to suit your needs. Widgets ACP/HTML Widget Footer Logo <center> <br><br> <img id="thislogo" src="path/to/my/image"> </center> Widget Welcome Message <!-- IF loggedIn --> <div class="getUsername">, <a href="/me"><span class="username"></span></a></div> <!-- ENDIF loggedIn --> CSS – I added the size font-weight: 900; in the CSS because otherwise some FA icon wasn’t displayed correctly and reduce margin : i#thisicon { font-family: "Font Awesome 5 Free"; font-style: normal; margin-right: 8px; font-weight: 900; } .getUsername { padding-top: 20px; text-align: right; } /*Smartphone*/ /*On désactive le message de bienvenue"*/ /*We disable the welcome message"*/ @media all and (max-width: 1024px) { .getUsername { display: none; } } JAVASCRIPT // ------------------------------------------ // Welcome Message avec icône et Footer logo // Welcome Message with icon and Footer logo // ------------------------------------------ $(window).on('action:ajaxify.end', function (data) { //On récupère le username dans le DOM et on l'affiche //We retrieve the username from the DOM and display it function updateUsername() { $('.getUsername .username').text(app.user.username); } if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', updateUsername); } else { updateUsername(); } //On déclare les variables principales (themessage & thehours) ainsi que les variables secondaires correspondants aux plages horaires //We declare the main variables (themessage & thehours) as well as the secondary variables corresponding to the time slots var thehours = new Date().getHours(); var themessage; var wakeup = ('Good day'); var morning = ('Good morning'); var lunch = ('Bon appétit'); var afternoon = ('Good afternoon'); var drink = ('Cheers'); var evening = ('Good evening'); var night = ('Good night'); var welcome = ('Welcome'); var matched = false; //On peux ici tester le résultat du code en spécifiant une heure (!!!IMPORTANT: Commenter une fois le script testé!!!) //Here we can test the result of the code by specifying a time (!!!IMPORTANT: Comment once the script has been tested!!!) //thehours = 20 //On déclare les plages horaires avec les icones FA et les logos //We declare the time slots with FA icons and logos path if (thehours >= 0 && thehours < 6) { themessage = night; theicon = "fa-solid fa-moon"; thelogo = "/assets/customlogo/XXX.png"; } else if (thehours >= 6 && thehours < 8) { themessage = wakeup; theicon = "fa-solid fa-mug-hot"; thelogo = "/assets/customlogo/XXX.png"; } else if (thehours >= 8 && thehours < 12) { themessage = morning; theicon = "fa-solid fa-sun"; thelogo = "/assets/customlogo/XXX.png"; } else if (thehours >= 12 && thehours < 13) { themessage = lunch; theicon = "fas fa-hamburger"; thelogo = "/assets/customlogo/XXX.png"; } else if (thehours >= 13 && thehours < 16) { themessage = afternoon; theicon = "fa-solid fa-sun"; thelogo = "/assets/customlogo/XXX.png"; } else if (thehours >= 16 && thehours < 18) { themessage = welcome; theicon = "fa-solid fa-rocket"; thelogo = "/assets/customlogo/XXX.png"; } else if (thehours >= 18 && thehours < 19) { themessage = drink; theicon = "fa-solid fa-wine-glass"; thelogo = "/assets/customlogo/XXX.png"; } else if (thehours >= 19 && thehours < 20) { themessage = lunch; theicon = "fas fa-pizza-slice"; thelogo = "/assets/customlogo/XXX.png"; } else if (thehours >= 20 && thehours < 24) { themessage = evening; theicon = "fa-solid fa-tv"; thelogo = "/assets/customlogo/XXX.png"; } // Si la page active est un topic, on désactive/cache le message de bienvenue // If the active page is a topic, we deactivate/hide the welcome message if (window.location.href.indexOf("topic") > -1) { console.log("This is a topic, so hide the user welcome message"); $('#thisuser').hide(); } // Sinon, on affiche le message en fonction, l'icone FA et son emplacement (prepend) // Otherwise, we display the message in function, the FA icon and its location (prepend) else { $('.getUsername').prepend("<i id='thisicon' class='" + theicon + "'></i>" + themessage); $("#thislogo").attr("src", thelogo); //$('.getUsername').prepend("<img id='thisicon' src='" + thelogo + "'></>" + themessage); } });
  • creating topic specific widgets

    Solved Customisation nodebb
    16
    10 Votes
    16 Posts
    3k Views
    @crazycells said in creating topic specific widgets: Additionally if hide class exists, why are we re-defining it? We’re not 🤭 I misspelled it - it should be hidden
  • [NODEBB] Help for my custom CSS

    Solved Customisation nodebb css bugfix
    237
    49 Votes
    237 Posts
    80k Views
    @baris said: You should change your selectors so it doesn’t look at the entire document. You probably only want to apply fancybox to stuff inside the #content element which is what changes when the user navigates around the page. So use $('#content a').... for your selectors then the forum logo in the header won’t be selected. I modified the JS Fancybox code now and this code and it seem better // --------------------------------------------- // Fancybox Media Reader (Without Website Logo) // --------------------------------------------- if (top.location.pathname !== '/login') { $(window).on('action:posts.loaded', function(data) { console.log("Polling DOM for lazyLoaded images to apply Fancybox"); $(document).ready(function() { $('#content a').not('.forum-logo').not(".avatar").not(".emoji").not(".bmac-noanimate").each(function() { $('#content a[href*=".jpg"], #content a[href*=".jpeg"], #content a[href*=".png"], #content a[href*=".gif"], #content a[href*=".webp"]').addClass("noanimate"); }); }); }); } if (top.location.pathname !== '/login') { $(document).ready(function() { $(window).on('action:ajaxify.end', function(data) { $('#content a').not('.logo').not(".avatar").not(".emoji").not(".bmac-noanimate").each(function() { $('#content a[href*=".jpg"], #content a[href*=".jpeg"], #content a[href*=".png"], #content a[href*=".gif"], #content a[href*=".webp"]').addClass("noanimate"); data.preventDefault() // Strip out the images contained inside blockquotes as this looks nasty :) $('#content blockquote img').remove(); }); Fancybox.bind( '#content a[href*=".jpg"], #content a[href*=".jpeg"], #content a[href*=".png"], #content a[href*=".gif"], #content a[href*=".webp"]', { groupAll: true, } ); }); }); } // Chat fancybox - fires when chat module loaded and AJAX calls new chat $(document).ready(function() { $(window).on('action:chat.loaded', function(data) { // >>> Se limiter au contenu principal uniquement <<< $('#content img').not('.forum-logo').not(".avatar").not(".emoji").not(".bmac-noanimate").each(function() { var newHref = $(this).attr("src"); $(this).wrap("<a class='fancybox' href='" + newHref + "'/>"); $('#content a[href*=".jpg"], #content a[href*=".jpeg"], #content a[href*=".png"], #content a[href*=".gif"], #content a[href*=".webp"]').addClass("noanimate"); data.preventDefault(); // Strip out the images contained inside blockquotes as this looks nasty :) $('#content blockquote img').remove(); }); Fancybox.bind( '#content a[href*=".jpg"], #content a[href*=".jpeg"], #content a[href*=".png"], #content a[href*=".gif"], #content a[href*=".webp"]', { groupAll: true, } ); }); }); For the logo, I must use overflow: visible !important; on [component="brand/logo"] /* --- Logo --- */ [component="brand/logo"] { max-height: 50px; width: auto; height: auto; max-width: 100%; display: block; object-fit: contain; object-position: left center; overflow: visible !important; } Better result !!
  • NodeBB Discord Plugins

    Unsolved Customisation nodebb discord plugin
    7
    0 Votes
    7 Posts
    2k Views
    @RiekMedia hi. Just following up on this thread (I know it’s old) but was curious to understand if it’s still an issue or not ?
  • Customising NodeBB

    Locked Customisation nodebb
    3
    0 Votes
    3 Posts
    2k Views
    Closing this thread as a duplicate of https://sudonix.com/topic/12/nodebb-customisation