@crazycells thatโs as good a test as any ๐
New "messenger style" conversation view
-
@phenomlab said in New "messenger style" conversation view:
@crazycells you shouldnโt need to reload the page? (At least, not a hard refresh)
yeah, what I mean is that the โdaylightโ does not stay on the page as the theme (a bug?), although the rest of the themes stay active when I reload the page.
-
@crazycells does this only happen with daylight ?
-
@phenomlab said in New "messenger style" conversation view:
@crazycells does this only happen with daylight ?
Yes, I changed them one by one, it only happens with โdaylightโ.
Can you please send a screenshot of your page with the daylight theme? -
@crazycells I think I see what you mean - do you see something like this, where the CSS does not appear to be applied?
Hereโs where it gets interesting - I am using SCSS variable
--self-post
for this specific setting, and it does not seem to be appliedNotice the โโself-post is not definedโ. And you are right - this only seems to be happening with the
daylight
theme, which is odd. -
@crazycells I think I see the issue - itโs related to caching. Can you open sudonix.com in an incognito session, and let me know if you experience the same issue?
Either way, itโs something I need to fix.
-
@phenomlab said in New "messenger style" conversation view:
@crazycells I think I see the issue - itโs related to caching. Can you open sudonix.com in an incognito session, and let me know if you experience the same issue?
Either way, itโs something I need to fix.
Yes, incognito session solves the issue
-
@crazycells thanks for confirming. Looks like Iโll need to write in a function that creates a random string meaning the css canโt be cached.
Interestingly, this same function was included in the original iteration I worked on for @DownPW but it was removed in this version because it wasnโt deemed necessary - but clearly is !
-
@crazycells This got the better of me over the weekend, so I decided to look into this a bit more. Itโs not just caching, but the fact that NodeBB uses lazyLoad to prevent the DOM from being overloaded (this is why it is so fast). The issue here is that this specific view requires the injection of a new class to replace those that have none set.
As the DOM is already loaded, the required classes are not being added unless the page is being reloaded using the F5 key. Obviously, this is undesirable, so Iโve had to modify another function that I have which looks for lazyLoaded images added to the DOM on content update, then injects the fancybox function so that they can be handled in the same way as those already in the DOM.
Extending this function means the injection of required classes for those that are missing on lazyLoad is then possible. The function looks like the below
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() { $('a').not('.forum-logo').not(".avatar").not(".emoji").not(".bmac-noanimate").each(function() { $('a[href*=".jpg"], a[href*=".jpeg"], a[href*=".png"], a[href*=".gif"], a[href*=".webp"]').addClass("noanimate"); }); }); /* This is where the messenger view type classes need to be injected if they are missing */ $(document).ready(function() { if (!$('li[component="post"]').hasClass('.topic-owner-post') || (!$('li[component="post"]').hasClass('.self-post'))) { console.log("Adding required classes for messenger type view"); $('li[component="post"]').addClass('topic-response-post'); } }); }); }
Arguably, it would be a much simpler affair if these classes existed in the core, but they sadly do not, so the above function is necessary.
-
@phenomlab if there is no need to change the core codes, can we make new messenger style to in my site?
-
@cagatay Yes, but as I mentioned before, this really needs to be done in a development environment first as itโs quite disruptive to change CSS values constantly whilst users are trying to use the site.
-
@phenomlab i do not have dev side of my site. My users traffic also not good so i can get my all css as copy and you can try to new messenger style to my site, if there is any failure, donโt worry, you donโt have to feel responsible โฆ
-
@cagatay Before we do this, what package do you have? If you have a VPS for example, creating a dev instance isnโt that hard, and itโs a recommended standard.
-
@phenomlab yes i have vps at hetzner.
-
@cagatay if it has enough power, you could create a replica of your site in a subdomain and use that for development. Essentially, itโs a copy of the production site but with itโs open file set and database so they behave like individual instances.
-
@phenomlab Sorry, I donโt have that much technical knowledge.
-
@cagatay I can assist with this if you like, or if youโre ok with working on the production site then this is also ok.
What exactly are you looking to get in terms of results ?
-
@phenomlab iโd like to that my messenger style same as your site.
-
@cagatay keeping the existing theme, or the design of a new one ?
-
@phenomlab keeping the existing theme, to tell the truht this is not a theme, i just changed some css style.
-
@cagatay on, makes sense. If youโre sure that youโd like for code to be written and executed on your production instance, then we can start this next week.