Mein Blog hat Geburtstag
… und es wird 23 Jahre. Und es hat noch immer keinen Job, bringt kein Geld nach Hause und sitzt mir auf der Tasche. Aber trotzdem gibt es ein Geschenk. Etwas selbst gebasteltes. Ein komplett neues Frontend.
weiterlesen …… und es wird 23 Jahre. Und es hat noch immer keinen Job, bringt kein Geld nach Hause und sitzt mir auf der Tasche. Aber trotzdem gibt es ein Geschenk. Etwas selbst gebasteltes. Ein komplett neues Frontend.
weiterlesen …Eigentlich macht man sowas an langen Winterabenden. Ich nehme dafür Sommernächte.
Letztes Wochenende habe ich endlich den Bildupload zu Flickr direkt aus dem Blog fertiggestellt. Mit Hilfe von PhpFlickr ist das ziemlich einfach.
Wie die meisten Feature im Blog ist auch dieses keine interne Komponenten sondern eine kleine externe Api auf einer Subdomain, die ich aus dem Blogeditor heraus anspreche. Ich mag es die Kernanwendung relativ kompakt zu halten und alle Feature drumherum werden dann Miroservices.
Wo soll ich anfangen.
Durch Thomas bin ich auf Slash Pages aufmerksam geworden.
Slash pages are common pages you can add to your website, usually with a standard, root-level slug like /now, /about, or /uses.
Ein paar habe ich ja schon, wie /now oder /contact. Dazu gekommen sind ein /colophon und das /changelog und die /blogroll haben eine eigene Seite bekommen.
Wird es noch mehr geben? Ich weiss noch nicht. Die /faq bietet ja schon Antwort auf viele Fragen.
Außerdem habe ich angefangen das Blog ans Fediverse anzuschließen, wie man so schön sagt. Das heißt, man kann dem Blog unter @mk@kniebes.com auf Mastodon folgen.
Das Ganze befindet sich noch in einem frühen Entwicklungsstadium. Man kann folgen und auf Posts reagieren. In Anbetracht meiner Vorliebe für Tippfehler hat das Updaten von Posts die allerhöchste Priorität ;)
Die Darstellung von Reaktionen (Likes, Replies) im Blog selbst ist noch in Arbeit. Ehrlich gesagt weiss ich auch noch nicht wirklich wie ich das darstellen möchte. Tatsächlich den Content aus dem Messages anzeigen oder nur ein Verweis auf die Replies des Users. Vielleicht muss ich mal schauen, wie andere das so machen.
Ab und an mal zu schauen, was es denn für „neue“ Tags gibt loht sich durchaus. HTML ist eine recht lebendige Sprache, die sich permanent weiterentwickelt.
So ist mir auch das Element <search>
aufgefallen und hab’s gleich eingebaut. Macht sich als semantischer Container für ein Formular zur Suche bestimmt besser als ein <aside>
.
Vor einer Weile habe ich mit die Daten von meinem Twitter Account zusenden lassen. Mit eingelegtem Account geht das über:
„Mehr ⇒ Einstellungen und Datenschutz ⇒ Ein Archiv deiner Daten herunterladen“.
Nach einer Weile wird man informiert, dass die Daten zum Download bereit stehen.
Man bekommt so ziemlich alles was zum Account gehört nett verpackt in einer Archiv Seite, die mit Javascript funktioniert. Alles Daten sind in diverse JSON Dateien hinterlegt und die Skripte verpacken diese dann in eine Seite, die Twitter nicht ganz unähnlich ist. Das könnte man im Prinzip hochladen und es würde rein technisch funktionieren. Allerdings sind auch sämtliche private Informationen, die im Account hinterlegt sind auch darin zu finden, zum Beispiel Direkt Messages. Das möchte man vielleicht nicht ;)
Ich habe dann die Datei mit den Tweets (tweets.js) genommen und daraus statische HTML Seiten erzeugt und hochgeladen: twitter-archive.kniebes.io
Für die Lightbox zur größeren Anzeigen von Bildern habe ich die Fullscreen Lightbox benutzt. Hat keine weiteren Abhängigkeiten und die einzelne Javascript Date ist extrem schnell eingebunden.
An und für sich kann ich nun meinen ohnehin auf Privat gestellten Twitter Account nun löschen.
Und ja, ich bin mit bewusst, dass Twitter schon seit einer Weile X heißt.
Die alten Updates werden noch im chronologischen Blog angezeigt, aber es wird keine neuen Updated mehr geben. Alles war ich in einem Wochenupdate schreibe, könnte auch ein separater Blogpost werden.
Wo soll ich die Grenze ziehen? Was kommt in ein Wochenupdate und was wird ein Blogpost? Um dem minimalistischen Charakter dieser Seite gerecht zu werden, habe ich ich mir diese Entscheidung erspart und die Wochenupdates ausrangiert.
Ich habe mal die Blogrolle überarbeitet – war ja schon eine ganze Weile nicht mehr aktuell. Anstelle die Links aus der Datenbank zu holen wird nun mein OPML-File aus NetNewsWire ausgelesen und die Feeds aus den beiden „Blog“-Outlines werden als Linkliste benutzt.
Und ich sehe das ebenso wie Dave Winer: Vor Twitter/X & Co. war es der gängige Weg Verbindungen herzustellen und darüberhinaus eine Quelle für Empfehlungen um neue Blogs kennenzulernen.
Angestiftet durch den Post von Dave Winer habe auch mal das enclosure-Element in den Feed aufgenommen.
<enclosure url="https://photo.kniebes.com/photo/2023/11/28/der-erste-schnee.jpg"
length="5474114"
type="image/jpeg" />
Mir fällte gerade auf, dass wann immer ich über meinen RSS Feed schreibe, den Post in guter RSS Club-Tradition auch nur im Feed aufführe;)
Das langweilig Monatsarchiv war mir schon länger ein Dorn im Auge. Ich habe das etwas aufgepäppelt und es sieht nun ein bisschen wie ein Balkendiagramm aus. In der linken Spalte ist der verlinkte Monat und rechts die Anzahl der Posts in dem Monat. Eigentlich selbstredend.
Es ist zwar mittlerweile eine längere Liste aber nicht so öde wie diese quasi kalendarische Ansicht, die ich zuvor benutzt habe.
Und da ich gerade bei war, ist die Tagcloud nun auch keine Cloud mehr, sondern daran angepasst.
Bei der Änderung meiner Anschrift auf meinen Seiten, bin ich auch wieder auf mein altes Photoblog gestoßen. Eigentlich war das nur noch ein Redirect auf mein aktuelles.
Aber das muss ja nicht so bleiben und so habe ich es technisch wieder lauffähig gemacht. SSL aktiviert und ein paar Fehler gelöst. Allerdings läuft es nach wie vor auf PHP 5.6 und das Layout ist etwas in die Jahre gekommen. Naja, man benötigt schon eine Lupe um auf einem 5K Monitor noch irgendwas lesen zu können. Auf mobiles Geräten ist es kaum benutzbar. Aber das ist halt ziemlich genau 16 Jahre alt. Der erste Eintrag stammt vom 4. Oktober 2007. Damals war mobiles Surfen noch kein echtes Thema.
Ich habe keinesfalls vor, das alte Blog mit neuem Inhalt zu füllen oder das Layout zu überarbeiten damit es etwas zeitgemäßer oder überhaupt zugänglicher wird. Nein, eigentlich habe ich das nur aus nostalgischen Gründen gemacht. Es spiegelt halt meinen ersten Zugang zur digitalen Fotografie wieder.
Vor ein paar Tagen habe ich angefangen mir die bis zu 20 Jahre Einträge im Blog anzuschauen und zu prüfen, wohin die Links noch führen.
Es ist ein bisschen ernüchternd und eher selten, dass Links noch zu ihrem ursprünglichen Ziel führen. Entweder ist Domain ganz verschwunden, die Seite wird mit einem 404 einfach nur nicht mehr gefunden oder - und das finde ich sehr unangenehm - der Link verweist nun auf einen neuen Inhalt, der entweder nur begrenzt oder nichts mit den ursprünglichen Inhalt zu tun hat. Im schlimmsten Fall ist ein Ad-Hub oder sonst irgendeine dumme SEO-Content-Falle für Bots. Ganz eklig dabei: Kryptowährung und NFT SEO-Bullshit.
Alter Propeller! Und das sind echt viele... Also Bullshit und alte Einträge, meine ich.
Das hatte ich schon eine ganze Weile vor, bin aber nie dazu gekommen. Über der Galerie auf der Photoblogseite werden nun zwei Auswahlfelder eingeblendet mit deren Hilfe nach Jahr oder Tag gefiltert werden kann.
Zuvor wurden immer alle Fotos in chronologischer Reihenfolge angezeigt. Die absteigend chronologische Reihenfolge ist geblieben, aber es sind nicht mehr alle.
Bei der Justified Gallery ist es erstmal geblieben und somit ist leider auch noch jQuery dabei. Beides kommt auch noch raus. Ich mag zwar die Justified Gallery, aber wenn ich jQuery benutze, komme ich mir vor wie ein Archäologe. Früher fand ich jQuery wegen der Cross-Browser-Klamotte ganz praktisch. Aber das ist Heute einfach nicht mehr notwendig.
Mein Blog wird Heute 22 Jahre.
Traditionellerweise gibt einen kleinen Rückblick auf das "Leben" meine kleinen Blogs im vorangegangene Jahr.
Der Baustellenreport hat ein Ende gefunden, da die Bauarbeiten an der Hattinger Straße nun abgeschlossen sind.
Inhaltlich gab es eigentlich weiter keine großen Veränderungen. Fotos und ein wenig Gerede über Serien, Filme und was mir in den Sinn kommt. Zwischendurch ein paar unkommentierte Links.
Das Tagging der Posts ist wieder ein wenig weiter vervollständigt worden. Aber es fühlt sich immer noch an wie ein Tropfen auf dem heißen Stein.
Weniger relevante Elemente habe ich auf den statischen Seiten mit web components umgesetzt.
Kommentare via Twitter gibt es leider nicht mehr, da die API nun was kostet. Und weil ich Twitter auch nicht mehr nutzen mag. Auf eine vergleichbare Integration über Mastodon hatte ich noch keine Lust, wird aber früher oder später kommen.
Nach 22 Jahren würde ich immernoch sagen, ein Blog auf eigenem Webspace lohnt. Irgendwelche Social Media Dinger kommen und gehen (besonders Twitter geht gerade) aber ein Blog bleibt.
Wenn Du also irgendwas zu erzählen hast oder irgendeinen kreativen Output hast, gib Deinem Schaffen ein ordentliches Zuhause. Ein Blog.
Nachdem ich Martin Schneiders Artikel Tinkering with Web Components gelesen habe, dachte ich, das wäre ein töfter Ersatz für die "Per E-Mail antworten" Funktion. Leicht abgewandelt wird auch der "Per E-Mail antworten"-Link über einen Share Button über eine Web Component angezeigt.
Und da ich gerade dabei war, gibt es noch drei weitere Web Components:
Seit einer Weile speichere ich auch die Exif Daten der Fotos in der Datenbank und nun habe ich mir mal die Zeit genommen und für jeden Post mit einem Foto, das die Infos hat, Tags für Kamera und Objektiv zu generieren. Das fängt leider erst im Oktober 2021 an. Das sind nicht einmal 2 Jahren von insgesamt 22 Jahren.
Ich bin mir nicht sicher, ob ich den Rest manuell taggen möchte...
Hier sind auf jeden Fall die nigelnagelneuen Tags:
Und natürlicherweise auch in der Wolke zu finden.
SQL zum Erstellen der Relationen zwischen Tag und Post ist dank JSON_EXTRACT relativ einfach:
REPLACE INTO journal_entry_tag (entryId, tagId)
SELECT DISTINCT je.id, 494
FROM journal_image ji
INNER JOIN journal_entry je ON je.content LIKE concat('%',ji.url,'%')
WHERE REPLACE(JSON_EXTRACT(ji.exif, '$.lens'),'"','') LIKE 'Zeiss Planar%';
-- wobei 494 die Id vom Tag "Zeiss Planar T* 1.4/50 ZF.2" ist
Da soll mal jemand sagen: ein Blog wäre kein Hobby ;)