gtoolkit VS reagent

Compare gtoolkit vs reagent and see what are their differences.

gtoolkit

Glamorous Toolkit is the Moldable Development environment. It empowers you to make systems explainable through experiences tailored for each problem. (by feenkcom)

reagent

A minimalistic ClojureScript interface to React.js (by reagent-project)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
gtoolkit reagent
22 41
1,042 4,715
1.2% 0.1%
9.6 1.1
7 days ago 5 months ago
Smalltalk Clojure
MIT License MIT License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

gtoolkit

Posts with mentions or reviews of gtoolkit. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-03-27.
  • Explorative Programming
    2 projects | news.ycombinator.com | 27 Mar 2024
    Your ideas sounded very much like a mixup of Common Lisp with SLIME, Smalltalk interactivity and Unison-like storage of code in a database instead of files.

    I've tried all of them, I think the closest thing I've seen to what you describe, which I also find very attractive, is the GT Smalltalk environment: https://gtoolkit.com/

    Have you tried that? They call this idea "moldable development" as you can "mold" your environment to your needs.

    Even though I loved it, I ended up not using it much, mostly because it's a bit too heavy to keep handy for exploration all the time when needed (it takes like 1GB of RAM even when idle!)... as I already can do most of that with emacs, which is much lighter, I just stick with it.

  • Smalltalk simplicity and consistency vs. other languages (2022) [video]
    3 projects | news.ycombinator.com | 14 Jan 2024
    > This power that Smalltalk systems have where the code runs in a GUI that is also the editor/debugger/etc has deeply fascinated me recently.

    Have you tried emacs?

    > And I'd like to actually understand a tool that I'd have to dive into that deeply, and I think I'll never have the time to truly understand all of the VM, the classes, etc.

    I've recently tried to do that myself with Smalltalk via the Glamorous Toolkit[1] (a beautiful, modern Smalltalk environment based on Pharo). Because the programming environment itself comes with a Book teaching it, you can basically just read it as a normal digital book, but with the superpower that everything is editable and interactive: you can change the book itself, every code example is runnable and you can inspect the result objects right there, change it, modify the view for it... they say it's "moldable development" because you almost literally mold the environment as you write your code and learn about the platform.

    > And I'd like to be able to create applications that run without shipping the entire Smalltalk VM.

    That's why even though I really enjoyed SmallTalk, I can't really see it as anything more than a curiosity. I tried using it at least for my own occasional data exploration because it has good visualisation capabilities and super easy to use HTTP client/JSON parser etc., but the system is so heavy (1GB+ of RAM) that I couldn't justify keeping it open all the time like I do with emacs, on the offchance that I might need to use it for some small task.

    Anyway, perhaps that's something you might be interested in.

    [1] https://gtoolkit.com/

  • An OOP modern language that is enjoyable in terms of syntax?
    1 project | /r/learnprogramming | 10 Dec 2023
    I have been building a drawing and animation system in Pharo (smalltalk) for a few months, using a really neat new UI called glamorous toolkit.
  • Ask HN: What perfect software did you discover of recent?
    4 projects | news.ycombinator.com | 4 Dec 2023
  • Pharo 11, the pure object-oriented language and environment is released!
    7 projects | /r/programming | 11 May 2023
    Last time I tried to "hydrate" thousands of SQL rows into objects and both Pharo and the Glamorous Toolkit froze up. Maybe that is to be expected, but I've done that a million times on the JVM without any problems.
  • Ask HN: Has anyone fully attempted Bret Victor's vision?
    8 projects | news.ycombinator.com | 22 Jan 2023
    In my opinion the idea is more than direct data manipulation. It is about how we get feedback. In drawing, the medium to draw is the same medium to read. In programming, there is often a mismatch - coding on a text file, running on somewhere else, e.g. terminal, browser, remote server. If you count surrounding activities for programming, like versioning, debugging, metering and profiling, even more system is involved. We are not even touching the myriad of SaaS offering each tackling carve out a little pie out of the programming life cycle.

    Back to your question, from my naive understanding, smalltalk seems to be an all in one environment. The Glamorous Toolkit [1] seems to be that environment on steroid. I have no useful experience to share though.

    https://gtoolkit.com/

  • Emacs Is Not Enough
    6 projects | news.ycombinator.com | 14 Jan 2023
    Wrote a review on it on the website, copypasting:

    Glamorous Toolkit[1] promotes the idea of moldable development[2].

    There's a talk on it: Tudor Gîrba - Moldable development.[3]

    The basic idea is to have multiple views and editors for any piece of data in your system (including code). Kind of interesting, but the toolkit looks and acts more like a fancy computational notebook type of environment, but without explicitly being a computational notebook.

    The site on moldable development states its difference with literate programming:

    They are similar in that they both promote the use of narratives for depicting systems. However, Literate Programming offers exactly a single narrative, and that narrative is tied to the definition of the code. Through Moldable Development we recognize that we always need multiple narratives, and that those narratives must be able to address any part of the system (not only static code).

    And that's a sensible viewpoint. But I still see it as an advanced version of a literate programming, all done within an interactive environment.

    The focus of Glamorous Toolkit seems to be on explaining a code base or a certain part of the system via presenting it via a custom tool.

    But I am not too convinced with the top-level development model / workflow it assumes for you. I guess it's too narrowly-focused / opinionated.

    It's also a custom fork of Pharo, so the question of long-term stability is even more unclear than that of Pharo itself.

    I can't say I can compare it to Project Mage in any meaningful way, except it's also a live environment.

    [1] https://gtoolkit.com/

  • But... what is it?
    1 project | /r/emacs | 13 Dec 2022
    Wow, that's very interesting, never heard of it before. In the first link and they've mentioned smalltalk and I remember checking out https://gtoolkit.com which I think has some of the ideas from emacs but is implemented in smalltalk. I always wondered if gtoolkit could fundamentally offer something emacs couldn't (at the principal level) but now that you've lebaled them together, I think I know the answer is no
  • The First Rule of Microsoft Excel: Don’t Tell Anyone You’re Good at It
    4 projects | news.ycombinator.com | 24 Oct 2022
    prolly a bit outside the mainstream but -> https://gtoolkit.com/
  • Glamorous Toolkit: Moldable development environment
    1 project | /r/patient_hackernews | 20 Oct 2022

reagent

Posts with mentions or reviews of reagent. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-03-21.
  • Ludic: New framework for Python with seamless Htmx support
    27 projects | news.ycombinator.com | 21 Mar 2024
    Generating `HTML` from lisps has poisoned any other approach for me, see for example https://www.neilvandyke.org/racket/html-writing/, https://reagent-project.github.io/, and https://edicl.github.io/cl-who/
  • Produce HTML from S-Expressions
    5 projects | news.ycombinator.com | 30 Aug 2023
    Hiccup syntax for Clojure uses hash maps (curly braces) for attrs, e.g. `{:style {:background "red" :margin "1em"}`

    See Reagent which uses Hiccup synta: https://reagent-project.github.io/

        (defn simple-component []
  • A History of Clojure (2020) [pdf]
    22 projects | news.ycombinator.com | 10 Aug 2023
    * Single-Page App: shadow-cljs for the build concerns (https://github.com/thheller/shadow-cljs), Reagent with Re-frame for complex/large app (https://reagent-project.github.io and https://github.com/day8/re-frame). Even if we now prefer using HTMX (https://htmx.org) and server-side rendering (Hiccup way of manipulating HTML is just amazing, https://github.com/weavejester/hiccup).
  • Leaving Clojure - Feedback for those that care
    8 projects | /r/Clojure | 23 Jun 2023
  • Clojure is a product design tool
    8 projects | news.ycombinator.com | 22 Jun 2023
    The API documentation lists the most commonly and rarely used parts before going into detail and there are many usage examples.

    Reagent has a nice intro tutorial (classic todo-app): http://reagent-project.github.io and many other helpful tutorials and resources for beginners: https://cljdoc.org/d/reagent/reagent/1.2.0/doc/documentation...

    However, since Reagent is still stuck with class-components for more complex behavior and relies on Hiccup, which is nice but has a performance cost compared to pure React, I am unsure about its future. Like some others in the Clojure community, I have moved to thin React wrappers like Helix and use Refx to integrate those with re-frame. It may be a bit confusing right now for beginners since there is no “golden path”.

    Also, unfortunately, many smaller libraries are poorly documented and it seems like it is expected from the developer to dig into the source code to find out what’s going on.

    What I found the most difficult as a beginner was how to setup a project in ClojureScript in the first place, like all the configuration in shadow-cljs, how it interacts with deps.edn, how it integrates with npm, the REPL, etc. But dev/build config has always been a weak spot for me, so it might be just that.

    Overall, I still very much enjoy working with Clojure(Script), more than in any other language. Anyone who likes Lisps and functional programming should give it a try (and be sure to watch Rich Hickeys amazing talks!).

  • Ask HN: How can a BE/infra developer handle the FE side of personal projects?
    7 projects | news.ycombinator.com | 13 Jun 2023
    have you tried cljs and reagent? it’s a different vibe.

    my bootstrap: https://github.com/nathants/aws-gocljs

    the project: https://reagent-project.github.io/

  • What are the enduring innovations of Lisp? (2022)
    2 projects | news.ycombinator.com | 1 Jun 2023
  • Building a website like it's 1999... in 2022
    6 projects | /r/programming | 19 Mar 2023
    Clojure people have been doing this for a decade or so. It’s really so much better to work with. All started with Hiccup and when React came along you got Reagent and many more developments building on the idea.
  • React.dev
    21 projects | news.ycombinator.com | 16 Mar 2023
    > But Reagent supports functional components as well, with hooks and all.

    I addressed this already: while reagent is able to emit function components, there is a performance penalty to this.[1]

    > I also very much like Hiccup, and so do many of us, because code is data and data is code, and Helix has decided not to support that.

    Hiccup is convenient to write, but it is a constant run-time cost and a significant storage cost given that you have to store long series of constructors to cljs.core.PersistentVector in your bundle, have the JS runtime actually construct the vector, then pass it through a Hiccup interpreter to finally produce DOM nodes and throw away the persistent vector, only to repeat this entire process again on re-render.[2]

    > Helix has decided not to support that.

    That is simply not true. From the Helix documentation[2],

    > If you want to use libraries like sablono, hicada or even hx hiccup parser, you can easily add that by creating a custom macro.

    These are all Hiccup interpreters you can readily use.

    IME there is very little difference between using the $ macro in Helix and writing Hiccup. I do not really miss Hiccup when I use Helix, and you still have data as code ;)

    While this is from an unrelated project, there are benchmarks[3] done against Reagent that demonstrate the sheer overhead it has. In practice it is not a big problem if you rarely trigger a re-render, but otherwise it is a non-trivial cost, and if you want to use modern React features (like Suspense), there is a lot of r/as-element mingling going on, converting cases, etc. that simply make Reagent feel more tedious to use than Helix.

    Also, the newer UIx2, which largely borrows from Helix, is "3.2x faster than Reagent" according to one of the contributors.[4]

    I think it'd be worthwhile to benchmark all of these libraries against each other and record the data in one place. Maybe I'll get around to doing it this weekend :)

    ---

    [1] https://github.com/reagent-project/reagent/blob/master/doc/R...

    [2] https://github.com/lilactown/helix/blob/master/docs/faq.md#w...

    [3] https://github.com/roman01la/uix#benchmarks

    [4] https://github.com/pitch-io/uix/pull/12

  • React is a fractal of bad design
    12 projects | news.ycombinator.com | 7 Mar 2023
    Reagent is peak React. All the good stuff without any of the hook and readability problems the article describes.

    No affiliation, happy user for years.

    https://github.com/reagent-project/reagent

What are some alternatives?

When comparing gtoolkit and reagent you can also consider the following projects:

moose - Multiphysics Object Oriented Simulation Environment

helix - A simple, easy to use library for React development in ClojureScript.

quokka - Repository for Quokka.js questions and issues

re-frame - A ClojureScript framework for building user interfaces, leveraging React

vim-buffet - IDE-like Vim tabline

shadow-cljs - ClojureScript compilation made easy

Moose - MOOSE - Platform for software and data analysis.

fulcro-rad-demo - A demo for Fulcro RAD using either SQL or Datomic databases.

iceberg - Iceberg is the main toolset for handling VCS in Pharo.

storybook.js-with-shadow-cljs

seaside - The framework for developing sophisticated web applications in Smalltalk.

hyperscript - Create HyperText with JavaScript.