idiomorph
notabase
idiomorph | notabase | |
---|---|---|
14 | 10 | |
590 | 682 | |
6.3% | - | |
7.6 | 7.7 | |
28 days ago | 2 months ago | |
JavaScript | TypeScript | |
BSD 2-clause "Simplified" License | GNU Affero General Public License v3.0 |
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.
idiomorph
-
A Response to "Have Single-Page Apps Ruined the Web?"
in plain htmx, you can target an area that doesn't disrupt a playing video (e.g. the comments box appending to the comments) or you can use a morphing algorithm that disrupts the DOM less.
i have my own morphing algorithm (and a corresponding htmx plugin that allows you to use it) called idiomorph:
https://github.com/bigskysoftware/idiomorph/
i've also been working with the chrome team to get a feature added they are calling "atomic moves":
https://github.com/whatwg/dom/issues/1255
this would allow us to move elements around in the DOM without losing things like play state or focus or whatever
very excited for this last idea, I think it will be a huge boon for the web in general, not just for htmx
-
The Aha Stack
for htmx 2.0 i'm integrating this functionality into the core
it's based on the head morphing algorithm of idiomorph:
https://github.com/bigskysoftware/idiomorph/
which 37Signals is going to integrate into Turbo for v8:
https://twitter.com/ben_pylo/status/1717975035669876790
[1] - https://htmx.org/essays/locality-of-behaviour/
-
Htmx is part of the GitHub Accelerator
i certainly hope not
the 2.0 would drop IE support, remove the older SSE and WebSocket support, and switch a couple of defaults (e.g, using template wrapping for parsing partial content, which handles troublesome elements like table rows better, but isn't available in IE) so it would be a breaking change (not for most folks, but still, breaking for some) which I only like to do w/ major versions.
we may have one major addition: a morph swap based on idiomorph:
https://github.com/bigskysoftware/idiomorph/
i'm on the fence on that one: it is currently available as an extension and maybe doesn't belong in the core, still thinking about it
so, in comparison with most libraries, 2.0 is going to be very minor
-
Htmx Is the Future
maybe I'm too close to it, but htmx feels like a hack to address things that really should be part of the HTML spec
if browsers got into the game I would assume they could do things much faster and integrate things like preload (https://htmx.org/extensions/preload/) and idiomorph (https://github.com/bigskysoftware/idiomorph/) much more cleanly w/ the rest of the browser infrastructure
- htmx is in the first cohort of the GitHub Accelerator! | The GitHub Blog
- Writing JavaScript without a build system
-
Ask HN: What have you created that deserves a second chance on HN?
idiomorph:
https://github.com/bigskysoftware/idiomorph
it's an updated take on the DOM morphing algorithm of morphdom, and it uses what i call "ID sets" to allow the morphing algorithm to "see" children in the DOM when making morphing decisions in the parents, which means you don't need to annotate the DOM with as many ids
here is a demo showing how it outperforms morphdom when ids are sparse/deep:
https://github.com/bigskysoftware/idiomorph#demo
-
Ask HN: What's Your Proudest Hack?
my trick for making the `htmx:confirm` event act like it is blocking:
https://github.com/bigskysoftware/htmx/blob/a3c414dcee94fd03...
basically, redesign the arguments for a function such that I can call it again at a given spot with one parameter changed and, to a first order approximation, it acts as if the function is resumable.
I've used this hack in many places now, just recently in idiomorph to allow head elements to load before the rest of the content is morphed:
https://github.com/bigskysoftware/idiomorph/blob/e6dfc189fa3...
-
Moving from React to htmx on a real-world SaaS application
That being said, htmx is about 3000 lines of mostly-understandable JavaScript. Really, the only two somewhat ugly parts of the code are history support and the somewhat fancy swapping model that enables CSS transitions. And it's basically baked at this point. I plan on adding a merge-style swap (https://github.com/bigskysoftware/idiomorph), better head merging and cleaning up some rough edges in htmx 2.0, but the core API shouldn't change at all and for most people 2.0 will be the same as a point release. At that point, htmx will be done done, and just another tool to use when building websites.
- Show HN: Idiomorph, a new DOM morphing algorithm
notabase
-
Ask HN: What have you created that deserves a second chance on HN?
https://notabase.io - a note-taking app for networked thinking.
It supports page stacking, linked references, block references, a graph view, and all that good stuff. Think of it as similar to Roam Research / Obsidian.
It's also open source so you can self-host it. Here's the code: https://github.com/churichard/notabase
I'm hoping to add support for shareable links soon. Open to other ideas or feedback!
-
What is the best school planner app that could sync with PC?
you can check out this page https://alternativeto.net/software/joplin/?platform=online but the best I could find are - https://www.taskade.com/ https://standardnotes.com/ https://notesnook.com/ https://bundlednotes.com/ https://diaroapp.com/ https://notabase.io/ https://boostnote.io/ etc.
- Self hosted app with web clipper feature
-
Switching Rich Text Editors, Part 1: Picking Tiptap
When evaluating rich text editors for the note-taking app I started about a year ago (https://notabase.io), I ended up going with Slate because of its flexible schema and customizable plugin architecture.
I sort of regret that choice now. I ran into a lot of bugs when integrating it which I had to manually work around; issues go months without being addressed; and there still isn't good cross-platform support, especially for Android. With a more active contributor base, Slate could be a fantastic library, but I get the feeling that it's in maintenance mode now, with not many major changes in the past year and a v1.0 still far in the future.
Tiptap looks like it might be a good choice now, but I find it off-putting that I can't insert links in the demo editor on Tiptap's website (https://tiptap.dev), especially for my use case (a note-taking app whose core concept revolves around links).
-
Ask HN: What is your “I don't care if this succeeds” project?
I'm working on an open source note-taking app called Notabase [1]. It's built primarily for my use - I just never liked most existing note-taking apps and wanted to make one that fit the way that I think. I made it open source [2] so other people can build on top of my ideas, and released a hosted version so that other people can use it if they like it. It would be nice if other people found it helpful, but regardless it's something that I intrinsically enjoy working on.
[1]: https://notabase.io
-
Show HN: MdSilo – A knowledge silo runs in your web browser
You can try Notabase https://notabase.io/, which is better for self-hosting.
if you prefer mdSilo, need to toggle the Offline mode false in code and use the third-part services: vercel and supabase
What are some alternatives?
hyperview - Server-driven mobile apps with React Native
budibase - Budibase is an open-source low code platform that helps you build internal tools in minutes 🚀
subtls - A proof-of-concept TypeScript TLS 1.3 client
dflex - The sophisticated Drag and Drop library you've been waiting for 🥳
smc - Simple Memory Check
slate - A completely customizable framework for building rich text editors. (Currently in beta.)
tnds-tomasi-notebooks - Notebook usati per il corso di TNDS
rich-markdown-editor - The open source React and Prosemirror based markdown editor that powers Outline. Want to try it out? Create an account:
star-history - The missing star history graph of GitHub repos - https://star-history.com
tiptap - The headless rich text editor framework for web artisans.
datasette - An open source multi-tool for exploring and publishing data
quill - Quill is a modern WYSIWYG editor built for compatibility and extensibility.