code block experiments

This commit is contained in:
Erik Winter 2025-01-11 15:25:33 +01:00
parent 1e9f07747d
commit 79b3aac8a4
13 changed files with 61 additions and 31 deletions

View File

@ -19,3 +19,8 @@ highlight_theme = "charcoal"
[extra]
# Put all your custom variables here
list_pages = true
header_nav = [
{ name = "home", url = "/" },
{ name = "about", url = "/" },
]

View File

@ -1,3 +1,3 @@
+++
transparent = true
title = "2020"
+++

View File

@ -1,3 +1,3 @@
+++
transparent = true
title = "2021"
+++

View File

@ -1,3 +1,3 @@
+++
transparent = true
title = "2022"
+++

View File

@ -1,3 +1,3 @@
+++
transparent = true
title = "2023"
+++

View File

@ -1,3 +1,3 @@
+++
transparent = true
title = "2024"
+++

View File

@ -38,7 +38,7 @@ To make it work, I used the following:
Squeezelite is a straightforward player. Just start it with two arguments:
```bash
squeezelite -n Toren -z
$ squeezelite -n Toren -z
```
'Toren' is the name of the player here. It is Dutch for 'tower', this is my big computer. `-z` lets it run as a background daemon.
@ -66,7 +66,9 @@ One special case needs to be added, though. If you start up the player for the f
We can check for the current length of the queue and issue the command if it is zero. Otherwise, execute pause/play on the media player:
```yaml
---
{% details(summary="Click to view a yaml example of the automation") %}
alias: Pause/Play on Squeezelite Toren
description: ""
triggers:
@ -97,7 +99,9 @@ actions:
target:
device_id: xxx
mode: single
```
{% end %}
---
## The Cinnamon applet
@ -106,11 +110,13 @@ Now, the applet is the most difficult part. There should not be a player window
Homeassistant has a REST API that provides all the information. Here is a `curl` command that fetches the information of my player:
```bash
curl -X GET -H "Authorization: Bearer ${HA_TOKEN}" https://homeassistant.local:8123/api/states/media_player.squeezelite_toren | jq .
$ curl -X GET -H "Authorization: Bearer ${HA_TOKEN}" https://homeassistant.local:8123/api/states/media_player.squeezelite_toren | jq .
```
Which returns something like this:
---
```bash
{
"entity_id": "media_player.squeezelite_toren
@ -146,6 +152,8 @@ Which returns something like this:
}
```
---
As one can see, one needs to [create an API token](https://developers.home-assistant.io/docs/api/rest/) to access the REST API of Homeassistant. Our applet will use the same method.
### The actual applet
@ -172,8 +180,9 @@ This folder will need three files:
This is the metadata that helps Cinnamon understand the applet.
---
```json
// metadata.json
{
"uuid": "currentlyplaying@ewintr",
"name": "Currently playing",
@ -183,12 +192,15 @@ This is the metadata that helps Cinnamon understand the applet.
}
```
---
### settings-schema.json
This enables a form where the user of the applet can enter their Homeassistant API key.
---
```json
// settings-schema.json
{
"ha_token": {
"type": "entry",
@ -198,12 +210,15 @@ This enables a form where the user of the applet can enter their Homeassistant A
}
```
---
### applet.js
A Javascript snippets that polls the Homeassistant API about the status of the media player and displays the band and song when playing.
---
```javascript
// applet.js
const Applet = imports.ui.applet;
const Util = imports.misc.util;
const Mainloop = imports.mainloop;
@ -258,4 +273,6 @@ function main(metadata, orientation, panelHeight, instance_id) {
}
```
---
And there you have it: plenty of moving parts, but on the surface it quietly just works.

View File

@ -25,6 +25,8 @@ What to do? On the page is a piece of JavaScript that is very eager to move you
And then I figured that the script would probably not be very sophisticated. It would likely just look at the protocol, not the host or the whole URL. So I asked an AI to generate a nginx configuration snippet that would let nginx function as an HTTPS proxy with a self-signed certificate:
---
```nginx
server {
listen 443 ssl http2 default_server;
@ -60,6 +62,8 @@ server {
}
```
---
Now if I want to access the configuration of my Zyxel:
- Disable the normal default site and enable the one above

View File

@ -1,3 +1,3 @@
+++
transparent = true
title = "2025"
+++

View File

@ -51,6 +51,7 @@ li { margin: 0.4rem 0; }
padding: 4rem 2rem;
}
/*
hr {
text-align: center;
border: 0;
@ -58,6 +59,7 @@ hr {
&:before { content: '/////' }
&:after { content: attr(data-content) '/////' }
}
*/
table { width: 100%; }
@ -77,8 +79,8 @@ code {
pre code {
display: block;
overflow-x: auto;
//white-space: pre-wrap;
padding: 1rem;
white-space: pre-wrap;
//padding: 1rem;
}
blockquote {

View File

@ -3,14 +3,14 @@
{% block content %}
{{ section.content | safe }}
{% if config.extra.list_pages %}
{% if paginator %}
{% set pages = paginator.pages | sort(attribute="date") | reverse %}
{% else %}
{% set pages = section.pages | sort(attribute="date") | reverse %}
{% endif %}
{% set section = get_section(path="_index.md") %}
{% set subsections = section.subsections | sort | reverse %}
{% for s in subsections %}
{% set ss = get_section(path=s) %}
<h2>{{ ss.title }}</h2>
{% set ps = ss.pages | sort(attribute="date") | reverse %}
<ul>
{% for page in pages %}
{% for page in ss.pages %}
<li>
<a href="{{ page.permalink | safe }}">{% if page.date and not config.extra.no_list_date %}{{ page.date }} - {% endif %}{{ page.title }}</a>
<br />
@ -18,8 +18,5 @@
</li>
{% endfor %}
</ul>
{% if paginator %}
<p>{% if paginator.previous %}<a href="{{ paginator.first }}">&lt;&lt; First</a> <a href="{{ paginator.previous }}">&lt; Previous</a>{% endif %} [{{ paginator.current_index }}/{{ paginator.number_pagers }}] {% if paginator.next %}<a href="{{ paginator.next }}">Next &gt;</a> <a href="{{ paginator.last }}">Last &gt;&gt;</a>{% endif %}</p>
{% endif %}
{% endif %}
{% endfor %}
{% endblock content %}

View File

@ -1,7 +1,6 @@
{% extends "base.html" %}
{% block header %}
<p><a href="..">..</a>/{{ page.slug }}</p>
<p class="post-meta"><time datetime="{{ page.date }}">{{ page.date }}</time></p>
<h1>{{ page.title }}</h1>
{% endblock header %}

View File

@ -0,0 +1,6 @@
<details>
<summary>{{ summary }}</summary>
<pre><code>
{{- body -}}
</code></pre>
</details>