Memex for public scrapbook/research?

Iā€™m setting up a new blog, thinking about what sections/content I want it to consist ofā€¦ and I realised thereā€™s something I cannot do now but perhaps Memex is closest to giving me the solution (at some point).

The blog will be simple, main column for blogposts, sidebar for a few secondary things. But Iā€™m thinking itā€™d cool if I could also present ā€œless-processedā€ content (perhaps in another column or within sidebar): basically notes/references I store for myself and which are related to the blogā€™s (general) content.

Something like Austin Kleonā€™s tumblr which lives separately from his own blog (see his take on this: ā€œitā€™s a decade of public researchā€). Why not to unite these two kinds of content?

The great thing is that Memex already does what I would like the tool to do: 1. easily store/highlight some text. 2. let me comment on the snippet 3. let me tag the page/snippet.

Now I donā€™t know how far this idea is from reality (hence this thread). Perhaps through Storex itā€™d be possible even now, to connect to, say, Wordpress API?

Itā€™s certainly beyond my beginnerā€™s level coding skills. But Iā€™m courious how the eventual solution could look like, for the time when I will be able to make it work.

And indeed, Iā€™m looking at it from my own, individual use-case perspective. But perhaps something like this, in more collaborative fashion, could become one of the ways how Memex brings home itā€™s ā€œletā€™s get to the (intersubjective) truth & combat disinfomrationā€ goal.

2 Likes

Thanks @kalmir for all this input. Love it!

Indeed some of the ideas you mention here we have already on the roadmap.
The plan is to implement sharing/collab features to afford 3 use cases:

  1. Share a collection and annotated pages
  2. Co-curate collections and reply to annotations
  3. Search inside the collections shared with you

This is on our mid-term roadmap but we need some more funding to make it work.

The use case you are initially mentioning would then be possible too.
However, you could already afford that kind of thing in a different way very soon.

We are right now in talks on how to integrate a bi-directional sync between hypothes.is and Memex via our StorexHub API.
Hypothes.is has a JS script that lets website owners have the Hypothes.is sidebar with annotations.

So what you then could do is basically adding your annotations to Memex and they will automatically appear on your website too, and you donā€™t even have to use Hypothes.is in your day-to-day work.

2 Likes

I hope youā€™ll get the funding! Making Memex useful for groups of people would be great.

As for my use-case, to use hypothes.is as a link will work for me, I mean, itā€™d even much easier than I thought possible. So please let me know here when the funcionality is ready.

3 Likes

@BlackForestBoi Iā€™d love to see Memex & StorexHub pump data into a MD notebook like Athens Research (another open collab project that makes a bi-directional linking markdown notebook, they even call it a Memex but their focus is more on the notebook and research side than on the data collection and annotation end that WorldBrain is focused on

See here for AthensResearch/Athens
vision: https://github.com/athensresearch/athens/blob/master/VISION.md
roadmap/mindmap: https://whimsical.com/TCeXP1dpRkdT8rpMvYci2P
notion: https://www.notion.so/Athens-67e1c6068cb449ff935d10e882fd9b05

they use clojurescript and datascript (which I have worked with professionally in the past, it is ideal for the backlinking notes graph problem they solve and is the same tech behind Roam which is closed-source software they are aiming to provide and opensource alternative for)

another more mature but less full-featured opensource project is called Obsidian). They seem like the perfect fit. Have you heard of these kinds of projects and do you have any thoughts on this? I might be interested in building a StorexHub plugin to do this. Could you please ping me Vincentā€™s contact so I can message him about building StorexHub plugins? Thank you! :blush:

Hey @AUM

Yes heard about these projects and in contact with some of them.

What it the kind of workflow integration you see with Obsidian or Roam?

Vincent is @v.denboer here. Before we involve him, I think to honour his time heā€™d appreciate if we were nailing the use case a bit more clearly so he can give more targeted advice on how to use StorexHub efficiently.

Hi, in my case, I now rely on bracketed links ([[this is link]]) between notes a lot, not just in Roam, but also in DevonThink and previously in TiddlyWiki. I think (or hope) this will become a sort of of standard. Roam is perhaps specific in the fact that it treats tags and links as the same thing. What I would like to be able to do:

Highlight text with Memex. Be able to chose words inside the text and create a bracketed link out of them. Add additional links by using the tag feature (tag added within Memex would actually end up being [[another link]]).

( Roam Highlighter works like this but I am not sure if it is able to create link by selecting couple of words. )

And once Roam creates an API, Iā€™d like to sync highlights/links/tags created in Memex into a Roam database.

@kalmir

Thanks for the detailed description of your workflow.

Where would a [[tag]]-link lead to? Would it just be a placeholder for whenever you integrate it into another app or would it ideally link to one of your other apps?

What we have already started implementing and will be fleshed out more in the next month is the copy-paster. (demo)
With that one you can just create your own templates for copy-pasting one (or later many) items into other apps. Now i works for pages but next up would be annotations, and also links to those annotations that end up straight in Memex.
Would that solve parts of your use case?

Yes, I imagined it as just a placeholder. I would like just to be able to export this text, ideally as markdown. And when the time comes, being able to do this automatically via Roam API would be great.

As far as I can tell from the demo, copy-paster seems cool: it would do (for me) the same thing as the Roam highlighter but with the added benefit of doing it within Memex with its browsing history capability.

Yes my use case is very similar to @kalmir 's

@BlackForestBoi Thank you, understandable. Here is my more clearly nailed use case. Iā€™ve gone into great detail here so hope Iā€™m not overloading you. Please ask me for clarification or simplification on any of the below points if necessary. Hopefully this is enough detail for @v.denboer

Memex (+ Proposed Xref StorexHub Plugin) - Web Highlights Referencing in Markdown

Integrated Workflow Overview

  1. I highlight some text on a webpage of quotes about happiness and embed it under a specific heading in a markdown article Iā€™m writing (happiness.md stored in the top level directory of my obsidian vault).
  2. The Xref Plugin snapshots and derives metadata. It creates markdown files for the highlights and snapshots and links these in the article.
  3. I later continue work on the article in Obsidian and fit the embedded highlighted quote into the article text.
  4. The final published article automatically references the author, tags, all other highlights by that author or from that webpage/site, my snapshot of the webpage, my snapshot of the complete HTML of the webpage (snapshots stored in subdirs of obsidian vault), the URL to original webpage.

An example of doing this (the Zettlekasten process) manually for books (or kindle books) is shown by Shu Omi on Youtube using Roam

Detailed Workflow

Memex User Workflow

  1. I am reading a webpage e.g. Dalai Llama's Thoughts on Happiness.html
  2. This sparks a link in my mind to my article I have been writing in Obsidian called happiness.md
  3. I highlight a section of the wepage where Dalai Llama says "Happiness Is not something ready made. It comes from your own actions."
  4. The memex sidebar tags selector is given focus so I can immediately start typing relevant tags and article titles - in this case happiness (which is a markdown file) - Optionally followed by the text of the heading where I want the highlight to be embedded (see the explanation of block-level-reference below).

I will always want to tag or reference a markdown file so the annotation menu should always present after every highlight action. There should be no ā€˜looseā€™ highlights. At the very least if I donā€™t tag they should be automatically tagged or linked using pre-set rules e.g. by looking at the text or the tags of the parent page or included in my daily journal log journal/2020-07-25.md Tags/Articles would include the author Dalai Llama, happiness, spirituality. In Obsidian, tags and links are similar, but tags have no file.

Ideally (from the userā€™s perspective) this entire process could be done from with the browser. So we donā€™t have to switch back and forth between the webpage we are referencing and the relevant article in Obsidian.

So what I need in Memex is to have the filenames of my markdown folder (called ā€˜Vaultā€™ in Obsidian), ideally the headings within these files, and all Obsidian tags, synced via my ā€œXref StorexHub pluginā€ so that whenever I highlight some text I can immediately start typing one of these within the Memex tags dropdown.

This saves a significant amount of time from the copy and paste workflow which would need context-switch from browser to Obsidian, search for the topic file, find the right place in the file to embed the reference (if I have even fleshed out the structure enough for the right place to fit yet) and then paste the text. With the copy paste model we are limited to referencing only the individual highlights with no way to structure all the other highlights in a linear fashion and link source. If the source is destroyed (which is happening more than you expect, especially for content that contravenes the corporatist agenda e.g. alternative health vaccine etc, search Link rot) the highlight could lose the reference to the author, the context and the related materials.

My ā€˜Xrefā€™ StorexHub Plugin/App Task

The solid lines represent bi-directional-links with the [[filename]] syntax. The dashed line represents a block-level-embed (a feature implemented by Obsidian) using the syntax ![[filename#heading]]. This allows referencing a specific MD heading (as denoted by the hashtag syntax).

Task Steps

  1. Notice via StorexFlow that Memex has saved a new annotation

  2. Kick off a snapshot task:

    1. Snapshot the webpage and all associated media and store web/snapshots/llama_happiness_20200725.html - I do this using some web-scraping code (in a symlinked folder that is mirrored or partially mirrored to say S3/IPFS e.g. Fleek.co Storage)
    2. Store the cleaned webpage body text in markdown in web/snapshots/llama_happiness_20200725.md. Include YAML front-matter with metadata.
    3. Generate YAML front-matter with metadata (tags, date, title, authors, links to snapshots and original url), insert this at the top of both snapshots and highlights markdown files.
  3. Append to highlights file: the highlighted text with tags under a markdown heading (#) in the format (#citekey @page-position-reference).

  4. Append to (or insert at relevant heading) of happiness.md a block-level-reference to said heading of highlights file.

  5. The web/highlights/llama_happiness.md references by bi-directional-link the complete bodytext in web/snapshots/llama_happiness_20200725.md which in-turn references a complete HTML snapshot made using python archiver in the same snapshots folder.

Obsidian Workflow

Later onā€¦ In Obsidian I continue working on my article that now includes the embedded highlight. My commentary made in the memex annotation is available and I can work the highlight into the article text to make it relevant.

See below for a working example using kindle highlights.

Publishing Workflow

When I publish the article to static HTML using say Gatsby, there is a link in the highlighted quote, to all my highlights on that page (the HTML page generated from web/highlights/llama_happiness.md), my fulltext MD snapshot also generated as a readable HTML, the complete HTML archive snapshot in case the original is down, and the actual original URL. Metadata is available like my link to the author [[Dalai Llama]] which contains further links like the Wikipedia page on Dalai Lllama. Both these pages (internal and Wikipedia links) are viewable directly within the static website article by hovering over the links to see a popover for a short summary + metadata without losing context and having to open another tab, as is done on gwern.net

Why Markdown and Why Obsidian?

I have gone with Obsidian because Roam is inherently broken regarding privacy. Your notes are stored on their Firebase servers in plaintext. Obsidian lets me keep my notes in markdown locally, a much more similar philosophy to that of Memex. Sadly Obsidian is not yet open sourced, I have spoken to the developers but they donā€™t seem keen on open sourcing the code. For now I have simply blocked all traffic from Obsidian.app and its helper app via a firewall. However, since Markdown is an open format and I can easily port my markdown files to any other editor software like Zettlr. I have written code to easily transform markdown into other formats. Bidirectional links are used by many apps now. So, the only Obsidian specific notation is the block referencing, which may indeed become standard, otherwise I can easily transform that notation to whatever standard format is established with a single line of code.

Markdown Database Model

Lately my use of Markdown files in Obsidian has grown to not only include my notes and articles but a collection of plaintext markdown (MD) files that I am using more as easily accessible source files to derive a powerful graph database.

File Structure

I am using YAML front-matter in all MD files.

In Roam, embeds are more specific as they are using a UID to the database key for each individual block including those below heading level. They are using an in-browser datalog graph db called Datascript, and treat each line as a separate block e.g. - or * in markdown - so actually this is not the complete markdown and is more of an outliner, i.e. there is no way to write a plaintext block without a bullet at the front of it.

Plain Markdown also inherently has a hierarchical structure that could reference below heading level, e.g. individual bullet-points, but we would need a new system that uses IDs to accomodate this.

At present everything is working fine with only header level embeds. I have adapted my note format so that the things I need to reference are directly below a single heading with a programmatically generated unique identifier see image below.

Working Example in Obsidian Using Kindle Highlights

Currently, instead of web/, I have implemented this for kindle/ (see below for example) and local pdf/ files that I programmatically scrape. These MD files in the kindle/ and pdf folders contain similar virtual containers which link to the content (PDF or .mobi files) which is snapshotted locally.

The snapshots of the actual media such as webpages, PDF, ebooks, videos, podcasts etc that I am storing locally in symlinked folders that are in .gitignore replicated by duplicity or rsync to an encrypted S3/IPFS or my other computers). This is so my vault doesnā€™t get too large to fit comfortably in git, but large media files can be easily referenced.

Reference this snapshotted local media, (via the local path and associated S3/IPFS address) within the virtual container MD file along with metadata such as: summary, tags, description. Other related notes can be determined by searching for other MD files with backlinks pointing to this metadata file.

The quotes/highlights (which for a video would be a section of that video) can be referenced in a MD file with my commentary. Either of these (the highlight or my commentary) can be further referenced by block-level-embeds in my final articles, books etc.

In the left pane see the virtual container markdown file that I have programmatically generated by scraping my amazon kindle reader website. In the Web use case, this would the same format as the virtual container for memex website highlights generated by the Xref StorexHub plugin/app i.e. the highlights file.

On the right panes (top is source, bottom is preview) is the article happiness.md, see an example of two quotes I have referenced and embedded in an work-in-progress article about happiness. The block-reference notation is used to directly embed the quote in the article (this inherently contains a link to all this bookā€™s highlights), and the bi-directional-link notation is used to link to my page with commentary about the whole book, and the author, Paramahamsa Yogananda.

The block references are autocompleted in obsidian so it is very easy to reference individual blocks if I know the header (cite-key + @kindle-position-key). cite-key is generated by combining the author year and title in a way similar to Bibtexā€¦ Iā€™ve not had any conflicts so far but when it comes to websites (as opposed to books) Iā€™d imagine youā€™d need to find more intelligent unique keys to reference such as domain, date etc.

Future expansions for multimedia referencing, example using Youtube

  • Be able to highlight sections of a Youtube Video by selecting text within the transcript (already possible with Memex, plus the transcript contains timecodes already) or a specific section of the timeline slider.
  • The video and full transcript is snapshotted (i already have code to do this), highlighted transcript text is processed exactly like highlighted quotes but the heading is referenced by start-end timecode in. seconds.
  • The video is split to take just the highlighted section (I have code for this)
2 Likes

Wow, thanks for describing your workflow in such a detail!

1 Like

Wowza @AUM!

As far as I can see this workflow would already be possible with the current capabilities of StorexHub and Memex.

One thing I see missing, but that is coming hopefully within the next month is links that point straight back to the highlight that you can embed.

You should be able however to already programmatically alter any annotation and add references and new tags to it as you wish.

I talked to @v.denboer and he mentioned that there are still a few base work things to do on StorexHub to make your general developer and user experience smoother. (like packaging StorexHub as an Electron app, or creating a simple visual interface for the connector recipes)
We are right now focused on getting the sharing features out of the door, so we canā€™t put effort into this ourselves, however if you are interested you can also give it a spin yourselves to make it more user friendly.

1 Like

however if you are interested

Has your reply been truncated? It looks like you might have wanted to say something after this?

I have workarounds for the time being, and am also quite occupied with projects so donā€™t want to spread myself too thin. Happy to give StorexHub the time to become more stable before we build anything significant.

Thank you :slight_smile:

Thanks @AUM.

indeed my reply has been truncuated.

Btw. I was in our call today - seems like you may have missed it.
Let me know if you want another call - just book one via the calendar.

Apologies for missing our call. Iā€™m going to keep iterating on my prototype before I reach out to you again. I think some of my questions will become clear over time. Thanks for your help.

1 Like

Thatā€™s great. Connecting with Hypothes.is sounds really promising. Plugins for popular content management systems will boost visibility hugely.

3 Likes

Hey, this is great! Iā€™m also using Obsidian for all my personal knowledge management, for example for epub highlights to create interconnected book notes.

Athens Research looks very interesting, will have a closer look! :slight_smile:

I also just summarized my current workflow ā€œproblemsā€ on the Obsidian forum, might be interesting:

My workflow goal would be something like this:

Key features:

  • searchable history of all websites I visit and all text I highlight
  • link to ideas and concepts in those highlights, i.e. reuse it in something like Obsidian
  • feed this knowledge base (selectively obviously) into a spaced repetition learning plugin that makes me review notes to improve recall
3 Likes