Inline Tag Navigator
Description
Type inline tags or front matter in the note editor. View your tagged paragraphs and tasks / TODOs in a search panel, or in a generated note. Build a table view / database from notes and tags. Convert between Obsidian tags and Joplin tags.
Additional Information
Links: | |
---|---|
Maintainers: | alondmnt |
Version: | 2.1.4 |
Minimum app version: | 2.10 |
Downloads: This version: | 0 |
Last updated: | N/A |
☸️ Inline Tag Navigator
Type inline #tags or front matter in the note editor. View your tagged paragraphs and tasks / TODOs in a search panel, or in a generated note. Build a table view / database from notes and tags. Convert between Obsidian tags and Joplin tags.
Features
This plugin adds inline tag support (such as #inline-tag) to Joplin in five ways:
- It adds a panel for searching and viewing tagged paragraphs across all your notes. (video)
- Search queries: Search tags using logical operators (AND, OR, NOT), and using free text in the note, title, or notebook name / path.
- Save search queries in notes and sync them across device. (video)
- Tag-by-notes: Search for links or [[wikilinks]] to notes (including backlinks to the current note).
- Tag in front matter: All Markdown front matter fields can be treated as tags. (video, tips)
- Edit tags: Add, replace and remove inline tags via the panel context menu (right-click on a tag).
- Insert tags from the panel into the note editor. (tips)
- Toggle checkboxes / TODOs from the panel, including [x]it! style checkboxes (click, or right-click for 6 task states). (tips)
- Nested tags hierarchy: Search parent tags to find the locations of their children. Example: #parent/child. (video)
- Tag values: Assign values to tags. Example: #tag=value. (tips)
- Tag ranges: Search for a range of tags, according to their lexicographic order. Example: #2024/07 -> #2024/08. (tips)
- Today's date: Search tags by today's date. Examples: #today, #today+1 (tomorrow), #today-10 (ten days ago). (tips)
- Colour tags: Use colour tags to highlight results in the search panel. Example: #color=red. (tips)
- It can generate a note with all tagged paragaraphs that match a saved query (dynamically updated). (video)
- It adds a panel for quickly navigating between inline tags that appear in the current note, or in all notes (video).
- It can convert your existing inline tags to native Joplin tags, so that they are accessible using Joplin's built-in tag search.
- It can convert your existing native Joplin tags to inline tags, so that they are accessible using inline tag search (this plugin). (tips)
After installing the plugin, check the commands listed under Tag Navigator
in the Tools
menu, as well as the corresponding settings section.
Demos
Inline tag search
data:image/s3,"s3://crabby-images/06308/06308a987c6a0796139bbe2e138dd8bf5070d777" alt=""
Saved search queries
data:image/s3,"s3://crabby-images/bbeea/bbeeabfa598fa1dbc977a711e9840551c5e4ebd1" alt=""
Table view / database
data:image/s3,"s3://crabby-images/b12f3/b12f38fa486209626b5789d150ef1af6d7516b5f" alt=""
Navigation panel
data:image/s3,"s3://crabby-images/7d41a/7d41aa30cc3af51dd15566f8a5e7d21b1e2e6b70" alt=""
Tips
- Troubleshooting
- Custom tag definitions
- Tag insertion
- Tag ranges
- Tag values
- Front matter tags
- Table views
- Inline TODOs
- Colour tags
- Keyboard shortcuts
- Converting Joplin tags
Troubleshooting
- If any of the actions on note results does not work (toggling checkboxes, editing tags), this is usually resolved by a database update (Ctrl+Shift+D).
Custom tag definitions
- The definition of a "tag" can be adjusted with user-defined regular expressions.
- Example: Every word in the text may be defined as a tag using a custom regex such as
[A-Za-z0-9]+[\w]*
.
- Example: Every word in the text may be defined as a tag using a custom regex such as
- You may also define an exclusion rule to ignore certain tags.
- Example: Numeric (
#123
) or hexanumeric (#C0FF1E
) tags can be filtered using an exclusion regex such as#(\d+|[a-fA-F0-9]{6})$
.
- Example: Numeric (
Tag insertion
- You may insert a tag into the note editor by:
- Starting to type a tag in the search panel, and pressing
Shift+Enter
. - Right-clicking on a tag in the search panel, and selecting
Insert tag
.
- Starting to type a tag in the search panel, and pressing
Tag ranges
- Tag ranges can be used to search for a range of tags, according to their lexicographic order.
- Example:
#2024/07 -> #2024/08
will search for all tags starting with#2024/07
and up to#2024/08
(inclusive, i.e., returning two months).
- Example:
- You may also use ranges with the
*
wildcard to search for tags starting with a certain prefix or ending with a suffix.- Example:
#prefix* ->
will search for all tags starting with#prefix
. - Example:
*suffix ->
will search for all tags ending withsuffix
.
- Example:
- Tag ranges can be inserted using the "Tag range" input boxes, or by right-clicking on a tag in the query area, and selecting
Edit query
.- Example: Edit a tag or tag range and type
#prefix* ->
to search for all tags starting with#prefix
. - If you type only
#prefix
, the query will be converted to a standard tag search (matching only the tag#prefix
).
- Example: Edit a tag or tag range and type
- Tag ranges can be used to search for tags by today's date.
- Example:
#today ->
will search for all tags starting with#today
. - Example:
#today -> #today+1
will search for all tags starting with#today
and up to#today+1
(inclusive, i.e., returning two days).
- Example:
Tag values
Tag values are a bit similar to nested tags as multiple parts of the tag are treated separately, but are distinct from them as explained below.
- Nested tags like
#parent/child
are shown as two separate tags in panels:#parent
and#parent/child
. - Tag values like
#parent=value
are shown as a single tag in panels:#parent
.- This is useful when you wish to assign many different values to a single tag, and prefer to avoid displaying all of them.
- As with nested tags, you may search for
#parent
, and may also search for#parent=value
, or use tag ranges.- In order to search for a tag value, right-click on a tag in the query area, and select
Edit query
. - You may then add the
=
operator to the tag, and enter the value you would like to search for.
- In order to search for a tag value, right-click on a tag in the query area, and select
- The value operator can be customised in the plugin settings.
- It should also be noted that while nested tags are widely used in note apps, tag values are less common.
Front matter tags
For example, the following YAML front matter, when inserted at the top of the note:
---
nested: tag with spaces
arrayed: [v1, v2, v3]
tags:
- tag1
- tag2
---
will be converted to the following inline tags and values:
#nested=tag_with_spaces
#arrayed=v1
#arrayed=v2
#arrayed=v3
#tag1
#tag2
#frontmatter
These tags will be accessible in the search panel / notes / tables like standard inline tags. The last tag is #frontmatter
and is used to indicate that the tags were extracted from the front matter section of the note.
Table views
- Quickly add new entries to the table by clicking on
New table entry note
in the context menu, toolbar, or Tag Navigator menu.- The new note will contain a front matter template with properties for each column.
- Tables can be customised using the following settings:
Note view: Table view columns
: Set the default number of columns (most common ones) to display in the table view.Note view: Table view notebook path
: Set to true to display the notebook path in the table view.Note view: Note view: Tag case in table view
: Set to "Title Case" / "lowercase".
- Tables can be customised per note using the saved query, by adding an
options
field with any of the following properties:includeCols
- a comma-separated list of columns (tags / properties) to display in the table view
- can be used to slice the table columns, sort them, or add "modified" / "created" timestamps
excludeCols
- a comma-separated list of columns to remove from the table view (even though these properties exist in the listed notes)
sortBy
- a comma-separated list of columns to sort the table by
sortOrder
- a comma-separated list of the words "ascending" / "descending" (or "desc", "descend", etc.) corresponding to the columns in the
sortBy
field
- a comma-separated list of the words "ascending" / "descending" (or "desc", "descend", etc.) corresponding to the columns in the
- example:
{
"query": [
[
{
"tag": "#artist",
"negated": false
}
]
],
"filter": "",
"displayInNote": "table",
"options": {
"includeCols": "title, artist, country, year, modified",
"excludeCols": "notebook, line",
"sortBy": "year",
"sortOrder": "asc"
}
}
Inline TODOs
- Filter results by pending tasks (
"- [ ]"
) or ones done ("- [x]"
). - Add support for additional tags for @mentions, +projects and //due-dates using a custom tag regex such as
(?<=^|\s)([#@+]|\/\/)([^\s#@'\"]*\w)
. - Supported additional checkbox styles (inspired by
[x]it!
).- Set any of them to done by clicking the checkbox in the search panel.
- Toggle between all states by right-clicking on a checkbox.
- You may increase the checkbox size on smaller screens by setting
Search: Panel style
with the CSS.itags-search-checkbox { width: 18px; height: 18px; font-size: 18px }
(adjust as needed). - Furthermore, every checkbox in the text (even ones that are not tagged by any inline #tag) may be defined as a tag using a custom regex such as
(?<=^|\s)([#]|\-\s\[[x\s@\?!~]\])([^\s#'\"]*\w)?
.- You may then use queries to search for tag-tasks based on their state (
- [ ]
,- [x]
,- [@]
, ...).
- You may then use queries to search for tag-tasks based on their state (
Colour tags
- Colour tags can be used to highlight results in the search panel, e.g., according to their priority.
- Example:
#color=MediumSeaGreen
,#color=#008080
or#color=rgb(0, 128, 128)
. - HTML colour names are supported.
- Example:
- You may customise the colour tag in the plugin settings.
- Example: Set it to be
#priority/
, and then tag by#priority/red
.
- Example: Set it to be
- You may select whether to paint the background or the border of the results with the selected colour.
- Set the colour of an entire note by tagging one of its first 2 lines with the colour tag.
- Different sections of the same note may be tagged with different colours. They will be displayed separately in the panel (see an example below).
Keyboard shortcuts
- Default command shortcuts
- These can be set up in Joplin's keyboard shortcut settings.
Key | Action |
---|---|
Ctrl + Shift + T | Toggle search panel |
Ctrl + Shift + I | Focus on search panel (search tag / insert tag) |
Ctrl + Shift + D | Update tag database |
Ctrl + Shift + L | Load search query from current note |
- Tag / note filter (search panel) shortcuts
Key | Action |
---|---|
Enter | Add tag(s) / note to query / note (see config) |
Shift + Enter | Insert first tag to note |
2nd Enter | Search notes based on current query |
Delete | Remove last added tag / note from query |
Esc | Clear the filter (display all tags / notes) |
2nd Esc | Return to note editor |
Arrow-Down | Toggle negation of last tag / note in query |
Arrow-Up | Toggle last operator AND <--> OR |
Converting Joplin tags
- It is recommended (as for any other plugin), before converting all notes:
- Test a few individual notes (one command above the all-note conversion).
- Backup your note database.
- If you would like organise your tags hierarchically (using nested tags) rename your Joplin tags first, before the conversion.
- Example:
#child
->#parent/child
- You may also choose to rename your inline tags after the conversion, using the plugin's
Replace all
command. However, this will create a divergence between your inline and Joplin tags.
- Example:
- Select your preferred conversion settings.
- Converted inline tags will appear at the top / bottom depending on the
Location
advanced setting. - Converted inline tags will have the prefix # depending on the
Tag prefix
advanced setting. - The list of converted inline tags will begin with the text 'tags: ' depending on the
List prefix
advanced setting. - Spaces in Joplin tags will be converted to inline tags depending on the
Space replacement
advanced setting. When converting inline tags back to Joplin spaces will be introduced back to tags. For example: [Joplin:tag with space
] -> [inline:#tag_with_space
] -> [Joplin:tag with space
]
- Converted inline tags will appear at the top / bottom depending on the
- After the conversion all Joplin tags remain assigned to their notes. They are not deleted, and only a single line of text is added to each note.
Companion plugins
- The excellent Inline Tags plugin can autocomplete tags while typing.
- You can highlight tags in the Markdown editor using Rich Markdown (version ≥ 0.14).
- In
Joplin settings --> Rich Markdown --> Advanced Settings --> Custom classes JSON
enter:
[{"name": "rm-tag", "regex": "(?<=^|\\s)#([^\\s#'\"]*\\w)"}]
- In
Joplin settings --> Appearance --> Custom stylesheet for Joplin-wide app styles
add the following to the style sheet:
div.CodeMirror .cm-rm-tag { background-color: #7698b3; color: white !important; padding: 0em 2px; border-radius: 5px; display: inline; }
- On the mobile app, since it is impossible to edit the stylesheet, one could install this Rich Markdown fork (with predefined support for tags and checkboxes) or instead define the name of the tag class to be
"name": "searchMatch"
. This will use the same highlighting style as Joplin search results.
- In
Motivation
- Notes are arguably the atomic blocks of information in Joplin. They can be linked to, tagged, and come up in search results. Joplin is optimised for this, and these features are pretty efficient.
- However, among 100s-1000s of long-form notes (that are hardly "atomic"), it remains challenging to find a small piece of information, idea, or memory.
- Tags can be especially helpful in distinguishing between the content of a text (what it's about) and its form or function (what type of text it is or what purpose it serves). The first is more easily captured by traditional or semantic search. The latter can be conveniently captured by tags, such as #concept, #plan, #memory, #realisation, #idea, #review, #bug, #feature, and others.
- I'd like to experiment here with information retrieval from single paragraphs, or outline items, as atomic blocks of information, using inline tags.
Objectives
- Be able to tag and efficiently search single paragraphs among all notes, using tags and free text.
- Browse the entire content of these paragraphs without having to open each note.
- Make this accessible and user-friendly.