Thank you for the support that I’ve received during the launch of MAZANOKE—a self-hosted local image optimizer that runs in your browser! It can run offline and is installable as a web app too.

This week, I’ve been addressing the feature that has been a bottleneck for the usability of an image optimizer, namely: batch upload and download.

Project page: https://github.com/civilblur/mazanoke

Highlights v1.0.1 (view release note)

  • Upload multiple files simultaneously
    • Images are processed one at a time to prevent excessive browser resource usage.
  • Download all optimized images as a zip file.
    • Files over 1GB are split into multiple zip files.
    • Large downloads may take time, depending on hardware and browser.
  • Option to clear optimized images from the “Images” section.
  • Convert GIF and SVG to PNG.
    • GIF-to-GIF optimization is not supported.
    • SVG optimization is not planned.
  • markstos@lemmy.world
    link
    fedilink
    English
    arrow-up
    1
    ·
    33 minutes ago

    I’m glad to have some competition for the Frost Oven Squoosh, which is being lightly maintained. I opened some issues in the Mazanoke issue tracker for some features to consider.

    One feature I started on for that project but got stuck on was implementing a STDIN / STDOUT CLI workflow.

    https://github.com/frostoven/Squoosh-with-CLI/issues/10

    As I said there, the goal was a workflow where I take a screenshot, annotate it, optimize it, copy it and paste it into my blog… without creating any intermediate temp files.

    At least on Linux, all the the steps of the pipeline are solved, except for a CLI image compressor that could accept an image STDIN and produce a compressed image on STDOUT.

    • lent9004@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      2
      ·
      edit-2
      4 hours ago

      Even though this squoosh instance seems to be selfhosted, it has Google Analytics tracking (since Google made this app). MAZANOKE does not include any tracking nor require any internet connection at all if you install it as a PWA.

      Edit: Looked at the source code of the fork, and it is applying the same tracking ID (to the big G). As squoosh is apache2 licensed, from my understanding, they should be able to simply remove that off the fork?

  • node815@lemmy.world
    link
    fedilink
    English
    arrow-up
    1
    ·
    7 hours ago

    Thanks for sharing this! I used it today to resize my Very large phone selfie I had to do for a profile image update at work and it did very nicely! Much faster for me to do that then load it in Gimp and scale it down since I was running late for work. : )

  • anguo@lemmy.ca
    link
    fedilink
    English
    arrow-up
    8
    ·
    16 hours ago

    I’m confused, isn’t this running locally? Why are you using the words “upload” and “download”?

    • lent9004@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      13
      ·
      16 hours ago

      That’s a valid question! The app is intended for less tech-savvy people, as such, the terminologies used are to accommodate those users. “Upload” would rather be “Import”, while “Download” would be “Export”.

      I’ve shared the use case in a previous Lemmy post:

      This app is designed to compress smaller batches of images, aimed at casual users who need to compress and convert a few images at a time.

      I created it primarily for friends and family who are less tech-savvy, to help them compress and convert images in a simple, safe, and private way.

      • anguo@lemmy.ca
        link
        fedilink
        English
        arrow-up
        6
        arrow-down
        4
        ·
        14 hours ago

        While I appreciate the sentiment, I do think that despite being well-intentioned this could just contribute to today’s digital illiteracy. It also downplays the app’s privacy, I almost dismissed it as a cloud service the moment I saw that.

        Perhaps you could use “open” and “save”, which is widely understood and probably more appropriate.

        That said, the app is a great initiative, and I’ll certainly give it a look once I get in front of a computer, and probably recommend it to students.

        • rutrum@programming.dev
          link
          fedilink
          English
          arrow-up
          11
          arrow-down
          3
          ·
          14 hours ago

          Just because its run locally, doesnt mean it still isnt a web server. The software could run anywhere and be accessed over the network. The image optimization happens at the server, so download and upload are more accurate.

          • anguo@lemmy.ca
            link
            fedilink
            English
            arrow-up
            3
            arrow-down
            2
            ·
            edit-2
            14 hours ago

            Wait, the optimization does not leave the browser. There isn’t any need for a web server.

            If this can be used as an offline PWA, it doesn’t even need to be ‘self-hosted’, except for keeping it up to date.

            Edited: removed reference to “device”, to avoid confusion.

            • rutrum@programming.dev
              link
              fedilink
              English
              arrow-up
              2
              ·
              edit-2
              6 hours ago

              Yeah, you’re totally right.

              All image processing happens locally.

              And then it mentions that you can just open the index.html directly, which means it uses clientside javascript or wasm and runs on the browser. You are correct!

              On the topic of word choice, you might be right. Save or open might be better.