Notepad/enter/Coding Tips (Classical)/Project Vault/Obsidian/Obsidian Guides/Digital Garden Plugin.md

149 lines
5.5 KiB
Markdown
Raw Blame History

This file contains invisible Unicode characters!

This file contains invisible Unicode characters that may be processed differently from what appears below. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to reveal hidden characters.

Digital Garden is the Obsidian plugin that lets me publish changes from my local obsidian here directly to the web on my personal website. Below are some helpful tips & tricks I've collected to streamline the process.
----
## Appearances:
#### Digital Garden Themes:
- 80's Neon - dark mode
- ![[Pasted image 20230816173235.png]]
- Terminal
- ![[Pasted image 20230816174402.png]]
- Bubble Space
- ![[Pasted image 20230817142703.png]]
- Everblush
- ![[Pasted image 20230817143911.png]]
- MagicUser
- ![[Pasted image 20230822101036.png]]
- Molecule
- ![[Pasted image 20230822102448.png]]
- Notation
- ![[Pasted image 20230822102804.png]]
- Origami
- ![[Pasted image 20230822103145.png]]
- NotSwift
- ![[Pasted image 20230904232536.png]]
## Custom Code
---
For further tweaks and customization, adding in your own CSS is helpful. Digital Garden docs provides a helpful guide to notes icon customizing and how to find this in the source files.
### Commands
Helpful commands in digital garden front-matter placed at the top of a note.
- **Hide file from file tree :** If you want to hide a note from the filetree, you can do so by setting dg-hide to true.
```
---
dg-hide: true
---
```
- **Pinning notes to filetree :** If you want certain notes to be at the top of the folder its in, you can use the dg-pinned attribute. Setting this to true will make the note be on top of the folder it is currently in
```
---
dg-pinned: true
---
```
- **Custom Links:** This plugin supports setting custom links to a note, if you prefer something else than the default behaviour. This is done by adding a dg-permalink attribute to the frontmatter of your file. As an example, the top of your file could look like this:
```
---
dg-publish: true
dg-permalink: "mynote"
---
```
This will make the URL to your note be "{Your-Garden-Name}.netlify.app/mynote/". You can still use normal obsidian links as before to link to it. These will be automatically corrected once you publish a note with the permalink attribute. Same goes for deleting the attribute. Doing so will result in the note using the default URL. All links in other notes should automatically be corrected and still work.
- **Permalinks with arbitrary level of folders deep:**
```
---
dg-permalink: "category/2022/mynote/"
---
```
- **File path :** If you want your note to appear in a different file structure than what you have in your vault, you can use the dg-path attribute, like so:
```
---
dg-path: "Advanced/Features.md"
---
```
More details about this is available in [05 Other Settings#Rewrite path for single note.](https://dg-docs.ole.dev/getting-started/05-other-settings/#rewrite-path-for-single-note)
- **Metatags :** Setting metatags for a note can be done by adding a dg-metatags attribute like so:
```
dg-metatags:
description: "some description"
"og:image": "https://example.com/someimage.png"
```
Note that there is a single space before the "description" field, **not** a tab.
- **Adding custom title & image in metadata :** This feature can be used if you want custom titles and images when sharing links in social media. Using the example below will add a title and an image that will be used when sharing the link in social media.
```
dg-metatags:
"og:title": "Title Appearing on Social Media Site"
"og:image": "https://example.com/someimage.png"
```
Read more about the [Open Graph Protocol](https://ogp.me/)
---
---
### CSS
- **Body classes :** You can set custom classes to the body tag for your published notes, by using the 'dg-content-classes' attribute.
```
dg-content-classes: cards
```
This will add a "cards" class to your note, allowing you to customize each note with specific classes.
You can also change the frontmatter key used to specify this in [the appearance settings](https://dg-docs.ole.dev/getting-started/04-appearance-settings/#css-settings). So, for example, if you are using [Minimal Theme's cssClasses](https://github.com/kepano/obsidian-minimal#css-helper-classes) you can change the key to 'cssClasses', meaning you don't have to specify the classes twice.
- **Customizing Icons.**
Navigate to `repo/src/site/img` to drop the icon .svg file there and then navigate to `repo/src/site/styles` to edit the `custom-style.css` file.
###### via [Digital Garden Docs. ](https://dg-docs.ole.dev/advanced/note-specific-settings/#note-icons) - Changing and adding icons
You can change and add your own icons the following way:
The ideal way to change the default icons is by adding the svgs in the img folder and setting the appropriate css vars in body in a [custom css file](https://dg-docs.ole.dev/advanced/adding-custom-components/#dynamic-css-scss):
```css
body {
--note-icon-1: url(/img/your-custom.svg);
--note-icon-2: url(/img/tree-2.svg);
--note-icon-3: url(/img/tree-3.svg);
--note-icon-fallback: url(/img/default-note-icon.svg);}
}
```
To add new icons, let's say, for 'stone', add a snippet like this (and add the relevant svg) in a [custom css file](https://dg-docs.ole.dev/advanced/adding-custom-components/#dynamic-css-scss):
```css
body.title-note-icon .cm-s-obsidian > header > h1[data-note-icon="stone"]::before,
body.filetree-note-icon .filename[data-note-icon="stone"]::before,
body.links-note-icon .internal-link[data-note-icon="stone"]::before,
body.backlinks-note-icon .backlink[data-note-icon="3"]::before {
background-image: url(/img/stone.svg);
}
```
For reference, this is a [fantastic example repository ](https://github.com/uroybd/topobon/blob/main/src/site/styles/custom-style.scss)for how one user made their Obsidian to [a digital garden. ](https://hermitage.utsob.me)