Figured I’d cobble together a quick-n-dirty greasemonkey/tapermonkey script to slighly modify the CSS to feel a little more like old.reddit with RES. Still not quite as compact as I’d like, but it’s getting there.

**edit/update: **

changelog

  • All future versions on github: https://github.com/soundjester/lemmy_monkey/
  • v0.4 - reformatted to remove greater-than signs; added observer to catch and reformat new comments;
  • v0.3 - added script to move the comment collapse button to be in front of user name (thanks @DarkwingDuck); tightened up the code, removed unneeded function call.
  • v0.2 - modified to work on any lemmy instance (thank you, God!)
// ==UserScript==
// @name         Lemmy to Old.Reddit Re-format (Observer)
// @namespace    http://tampermonkey.net/
// @version      0.4
// @description  Reformat widescreen desktop to look more like Reddit
// @author       mershed_perderders, DarkwingDuck
// @match        https://*/*
// ==/UserScript==

(function() {
	'use strict';

	var isLemmy = document.head.querySelector("[name~=Description][content]").content === "Lemmy";

	function GM_addStyle(css) {
		const style = document.getElementById("GM_addStyleBy8626") || (function() {
			const style = document.createElement('style');
			style.type = 'text/css';
			style.id = "GM_addStyleBy8626";
			document.head.appendChild(style);
			return style;
		})();
		const sheet = style.sheet;
		sheet.insertRule(css, (sheet.rules || sheet.cssRules || []).length);
	}

	function MoveCommentCollapseButton(container) {
		var firstTargDiv = container.querySelector(".btn.btn-sm.text-muted");
		var secondTargDiv = container.querySelector(".mr-2");
		//-- Swap last to first.
		container.insertBefore(firstTargDiv, secondTargDiv);
	}

	function ApplyMoveCommentCollapseButton(element) {
		const observer = new MutationObserver(function(mutationsList) {
			for (let mutation of mutationsList) {
				if (mutation.type === 'childList') {
					for (let addedNode of mutation.addedNodes) {
						if (addedNode.matches('.d-flex.flex-wrap.align-items-center.text-muted.small')) {
							MoveCommentCollapseButton(addedNode);
						}
					}
				}
			}
		});

		observer.observe(element, { childList: true, subtree: true });
	}

  //Lemmy to old.Reddit style reformats (to be used for custom stylesheet at a later date)
	if (isLemmy) {
		GM_addStyle(".container-fluid, .container-lg, .container-md, .container-sm, .container-xl {   margin-right: unset !important; margin-left: unset !important;}");
		GM_addStyle(".container, .container-lg, .container-md, .container-sm, .container-xl { max-width: 100% !important; }");
		GM_addStyle(".col-md-4 { flex: 0 0 20% !important; max-width: 20%; }");
		GM_addStyle(".col-md-8 { flex: 0 0 80% !important; max-width: 80%; }");
		GM_addStyle(".col-sm-2 { flex: 0 0 9% !important; max-width: 10%; }");
		GM_addStyle(".col-1 { flex: 0 0 4% !important; max-width: 5%; }");
		GM_addStyle(".mb-2, .my-2 { margin-bottom: 0.3rem !important; }");
		GM_addStyle(".mb-3, .my-3 { margin-bottom: .2rem !important; }");
		GM_addStyle(".mt-3, .my-3 { margin-top: .2rem !important; }");
		GM_addStyle(".thumbnail {   min-height: 100px; max-height: 125px; }");
		GM_addStyle(".vote-bar { margin-top: 15px !important; }");
		GM_addStyle(".comments {  margin-left: 20px; }");

		// Move comment collapse buttons for existing elements
		var divList = document.querySelectorAll(".d-flex.flex-wrap.align-items-center.text-muted.small");
		divList.forEach(MoveCommentCollapseButton);

		// Apply MoveCommentCollapseButton to dynamically loaded elements
		ApplyMoveCommentCollapseButton(document.documentElement);
	}
})();

Screenshot

>

  • God
    link
    fedilink
    English
    21 year ago

    I wanna put this here later, if you get around to doing it before I stop being busy, lmk

    • DarkwingDuck
      link
      fedilink
      English
      4
      edit-2
      1 year ago

      This took way too long.

      var div_list = document.querySelectorAll(".d-flex.flex-wrap.align-items-center.text-muted.small");
      var div_array = [...div_list];
      div_array.forEach(container => {
          var firstTargDiv = container.querySelector(".btn.btn-sm.text-muted");
          var secondTargDiv = container.querySelector(".mr-2");
      
          //-- Swap last to first.
          container.insertBefore (firstTargDiv, secondTargDiv);
      });
      

      Edited because I screwed up and only moved the first comment’s collapse button. Whoopsie.

      @mershed_perderders care to add this?

          • God
            link
            fedilink
            English
            21 year ago

            But I didn’t mention you lol. Or are you talking about another mention?

            • DarkwingDuck
              link
              fedilink
              English
              21 year ago

              I’m sorry, it’s late and I’m a bit tired. Indeed you did not mention me, the reason I got notified is because your comment is a response to mine.

                • God
                  link
                  fedilink
                  English
                  21 year ago

                  @[email protected] @[email protected] what do you guys think would be a good name for a community hosting this kind of augmentations? I was thinking of making something like /c/userscripts or /c/plugins. The latter sounds pretty cool.

                  • mershed_perderdersOP
                    link
                    fedilink
                    English
                    11 year ago

                    I lost this in the comment chain. I think this is a good idea. I think plugins would be good - the next item I want to tackle is an infinite scroll script… pagination is for the birds.

                • God
                  link
                  fedilink
                  English
                  11 year ago

                  Nooo how can you go to bed now! :c (am literally in bed lights off about to sleep) lol

      • God
        link
        fedilink
        English
        21 year ago

        Also, this is super awesome. I will test it as soon as I’m on desktop tomorrow.

        • DarkwingDuck
          link
          fedilink
          English
          3
          edit-2
          1 year ago

          The only issue is this only works on page load, so comments loaded dynamically while you’re on the page already won’t get the collapse button moved.

          • God
            link
            fedilink
            English
            31 year ago

            Ahh. I made something for this. It uses some observer. Well, chatgpt made it. I’ll find it and send it to you in a sec.

          • God
            link
            fedilink
            English
            2
            edit-2
            1 year ago

            Here you go. Check the last lines about the observer. I don’t know how that works. Honestly I didn’t even read it. Chatgpt did that whole part for me. https://sh.itjust.works/post/42893

            It doesn’t work 100% but it works way better than without it.