ajnin 3 years ago

My favorite way is how French website "Le Monde Diplomatique" does it : the footnotes appear at the bottom of the screen in context as you scroll so that only those referred in the currently visible text are displayed. It avoids awkwardly clicking on tiny superscript numbers and annoyingly scrolling back and forth between text and footnotes. For an example : https://www.monde-diplomatique.fr/2021/01/PIGEAUD/62633

verdagon 3 years ago

Anyone interested in footnotes might like the way we do it on the Vale site, for example: https://verdagon.dev/blog/making-regions-part-1-human-factor

Some nice things:

* The footnotes are off to the side, so it's closer to the text that mentions it and it doesn't interrupt the flow of the main text.

* It uses colors, so it's pretty fast to visually jump to the right one.

* We keep the numbers too, for colorblind folks (and those using blue-light filters like f.lux)

* It works without javascript!

Our markdown->html renderer makes this happen by slicing up the page horizontally, one slice per header. Each slice then has a wide left column for the main text, and a narrow right column for the footnotes. Then if the user happens have javascript enabled, it position:absolute's the footnotes and lines them up a little more precisely with where they're mentioned.

  • AB1908 3 years ago

    You may want to explore Tufte CSS. My own article about footnotes/sidenotes: https://ab1908.github.io/2021/08/24/footnotes-in-web-content...

    • verdagon 3 years ago

      Stellar article! Was definitely worth a read. The sidenote styles are particularly ingenious, I remember trying to get float+clear to work for this and never could, but looks like it's doable!

      • AB1908 3 years ago

        Glad you liked it! I'm amazed that you liked it cause it was my first semi-serious blog post haha.

    • breck 3 years ago

      Oh this is beautiful. Thanks for the link.

      • AB1908 3 years ago

        Many thanks, my friend

  • breck 3 years ago

    I like this. The nice thing about the Scroll implementation is that it's designed with extensibility in mind. I expect one day someone builds a `sidenotes` keyword.

    I think the colors idea is good too. Some stuff for us to play with in the future.

    Thanks for sharing!

woodruffw 3 years ago

At the risk of Dropboxing myself: what is the advantage of this over the existing Markdown syntax for footnotes[1]? It looks very similar, but with a harder to parse grammar.

[1]: https://www.markdownguide.org/extended-syntax/

  • breck 3 years ago

    > At the risk of Dropboxing myself

    This made me laugh. I appreciate you.

    > but with a harder to parse grammar

    Grammar is actually quite simple once you've mastered the Grammar language (https://pldb.com/languages/grammar.html) which has almost no documentation and is full of bugs.

    > what is the advantage of this over the existing Markdown syntax for footnotes[1]

    I can't speak definitively yet. I think it will be better but I need to use it for a few months to be sure. There are some subtle things I think will be important.

    • woodruffw 3 years ago

      Thank you for sharing that!

      In case I came across as overly negative: I think the overall syntax and project here are very cool. I’ll be following your work!

  • tux 3 years ago

    WOW I didn't even know markdown has footnotes will definantly come in handy for one of my projects. Thank you!

    • bmacho 3 years ago

      It doesn't have footnotes. Some supersets do.

      • woodruffw 3 years ago

        Right, but it's worth noting that those supersets are very common. I'd say it's actually less common to run into a "barebones" Markdown implementation these days than to run into a GFM or close-to-GFM one.

      • teekert 3 years ago

        Yes, for example in Hugo [0] I can do this:

        This is some text with a footnote.[^1]

        [^1]: And that's the footnote.

        [0] https://gohugo.io/

  • SPBS 3 years ago

    it looks like it aggregates all footnote definitions into one where it can be printed with the keyword 'notes' (hardcoding? too clever? what if you want to separate footnotes?)

richsu-ca 3 years ago

Something different. I have been using Markdown Footnotes extension [1] and found its syntax to be natural to Markdown.

Here's the same sample as OP in Markdown Footnotes syntax. There is a link to the rendered page [2].

https://gist.githubusercontent.com/richsuca/f5a14ed9cb76e7ad...

[1] https://python-markdown.github.io/extensions/footnotes/ [2] https://gist.github.com/richsuca/f5a14ed9cb76e7ad2f4f6b11361...

  • breck 3 years ago

    Thanks for the comparison! Really appreciate it.

    I think I'll copy some of the style from yours. I really like the smaller font size for the notes, the different font color, and in particular the link back to where the note was used! Double linked list, I love it!

    Stylistically I like the more minimal look of (the lack of brackets, and I think n may change link color to black): https://ab1908.github.io/2021/08/24/footnotes-in-web-content...

iprathik 3 years ago

Clicking on the number should ideal take me to footnote but it isn't. Instead its redirecting to a different page taking about scroll

  • CGamesPlay 3 years ago

    Yeah, possibly demo broken, but I don't understand how this is supposed to be a new way to do footnotes at all. Looks like a broken Markdown footnote to me.

sillysaurusx 3 years ago

I like the URL syntax. It's a clean separation between typing a sentence and attaching a link within that sentence. Nicely done.

chrstphrknwtn 3 years ago

All I get is a blank window in Safari.

  • macintux 3 years ago

    Works on my iPad. Any JS restrictions in your browser?

    • chrstphrknwtn 3 years ago

      Nope, just JS errors

      [Error] SyntaxError: Unexpected token '='. Expected an opening '(' before a method's parameter list. (anonymous function) (libs.js:16558)

      [Error] ReferenceError: Can't find variable: AbstractTreeComponent Global Code (app.js:4)

      [Error] ReferenceError: Cannot access uninitialized variable. (anonymous function) (try.scroll.pub:17)

      • breck 3 years ago

        Interesting. Which model # iPad and iOS version?

        • chrstphrknwtn 3 years ago

          macOS 13.0.1 (22A400) Safari 16.1 (18614.2.9.1.12)

          • macintux 3 years ago

            Very odd. I'm running the same versions on my (Intel) laptop, and the JavaScript console is error/warning-free.

chrismorgan 3 years ago

I’ve been designing a lightweight markup language of my own in recent months, and yesterday I finally settled on a syntax that I like for notes: links (which must always be delimited in my language), but with a leading caret, which will never be present in properly-serialised URLs. (The URL ^x should be encoded %5Ex—the URL parser will accept the caret, but it’s marked as invalid if anyone cares, and the serialiser would turn it into %5E.)

This makes perfect sense, because notes semantically really are links from one piece of content to another.

My URLs must always be delimited in angle brackets <…>, and links can be either <url> or [contents <url>]. (I haven’t settled on a syntax I like for reference-style links.) This fits in very nicely with caret starting note references. You can have [spanned notes <^…>] and spanless notes<^…>. (I also reckon on the identifier being optional, so that <^> would be valid, just using the next note body.) This syntax is generically useful for sidenotes, footnotes, endnotes and other presentations of notes—in general, I reckon note presentation should be a presentational rather than a content concern.

(Aside: what people on the web call “footnotes” are almost always actually endnotes. Endnotes are typically ergonomically poor in both print and screen media. Something along the lines of proper footnotes or inline-expandable notes mostly requires JavaScript, though with effort, restrictions about whether the content can contain blocks, and perhaps careful tip-toeing around HTML parser implementation details (or deliberately using XML syntax if you’re bold enough) and a mild disregard for nominal validity, you can do it even semantically reasonably without JavaScript.)

I reckon most notes should be spanned. To demonstrate what I mean, https://chrismorgan.info/blog/rust-ownership-the-hard-way/ shows three types of sidenotes: spanned with an inline source marker, unspanned with an inline source marker, and full block asides which are unspanned. To see my vision most clearly you’ll need a large enough viewport; on small viewports, I currently have the notes inline, with the third type aside, and I’m not happy with the in-flow placement of the asides, which is mostly a paragraph or so above the ideal place, but wanted it to all be pure CSS.

Then I started wondering, how many potentially viable characters are there like this, that can’t appear at the start of properly-serialised URLs? Could they be purpose for something else? You start with all Unicode scalar values, then remove (a) all URL code points <https://url.spec.whatwg.org/#url-code-points>, because they’re valid in URLs; (b) C0 and C1 control codes because non-printables is an extremely terrible idea for normal people; (c) `#`, as it’s used to begin fragments; (d) `%`, as it’s used for percent-encoding bytes. This leaves: "<>[\]^`{|} and space. Most of them would be a bad idea for various reasons, even if they’d work; ^ and | are the only two that seem reasonable to me.

So, ^ for notes. Haven’t thought of anything that fits similarly that pipe could certainly be used for. Could possibly use it for reference-style links, but that’d still be clunky (I would like to support […] matching, not needing [… <|refname>)).

acqbu 3 years ago

Breck, you're a good programmer, just like Terry A Davis!

  • breck 3 years ago

    How dare you call me only a “good” Programmer.

    - Sent from TempleOS