Blog: Latest Entries (15):


CSS: Flexbox + Ellispis

Manchmal sind ganz einfache Dinge sehr komplex. CSS-Ellipsis ist an sich einfach. Aber mit Flexbox kann es plötzlich dazu kommen, dass es einfach nicht funktioniert. Alles funktioniert nur die "..." sind nicht zusehen, weil es einfach alles zur Seite rausragt und die Breite hält.


<div class=""flex-container">
<div class="flex-child">
<header>LONG TEXT</header>
</div>
</div>



.flex-child header{
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
}


Die Lösung hier ist [url=]https://css-tricks.com/flexbox-truncated-text/min-width: 0;[/url].

Also:

.flex-child {
min-width: 0;
}

.flex-child header{
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
}


Super schnelle Lösung.. aber wie sollte man da alleine drauf kommen, wenn man nur mal schnell Ellipsis einbauen will?

HP Omen G15 Gaming-Notebook... 0.38GHz

Es sieht gut aus. Bang und Olufsen Design. Keyboard leuchtet schön und es ist für ein Gaming Notebook schön leicht und handlich. Ok man muss erstmal etwas Software runterwerfen, aber dann steht einem und dem Spaß an Spielen nichts mehr im Weg. Genshin Impact installieren starten und die Power geht los.. mit 0,38GHz .. und nicht mehr. Alles ist langsam. Daten laden langsam und alles ruckelt vor sich hin. Ein Ryzen 4800h sollte an sich mehr liefern.
Zum Glück kennt Google 0.38Ghz direkt als Suchbegriff und kann einen direkt in viele Foren leiten, wo genau das Problem besprochen wird.

Also erstmal ein BIOS-Update. Wenn man ein neues Notebook kauft sollte ja klar sein, dass ein BIOS-Update zu den ersten Dingen gehört, die man damit tun würde. Gerade der normale Kunde... normale Noobs lieben BIOS-Updates.

Am Ende läuft wieder alles, die Katze hat sich beruhigt und fühlt sich nicht mehr durch die lauten Lüfter provoziert. Alles läuft nun mit .... 0.38Ghz.

Wichtig! Netzteil abmachen. Dann tacktet die CPU plötzlich auf 1.9GHz hoch.. dann auf 2.9Ghz im Spiel. Netzteil wieder anschließen und es geht auf über 4GHz hoch. Warum? Keine Ahnung liegt wohl irgendwie mit dem Ladevorgang zusammen.

Nun läuft es... aber viel zu viel Spannung für einen ruhigen Abend auf der Couch.. wobei.. was macht so einen Abend gemütlicher als ein BIOS-Update?

(Auch wenn BIOS-Updates heute echt einfach und sicher sind.. der alte Nervenkitzel auf alten Pentium und K6 Zeiten bleibt irgendwie)

Code Reviews

Code Reviews kosten Zeit. Nicht nur ein bisschen sondern wirklich viel Zeit. Ich guck mir alles an und versuche erstmal zu verstehen, was es tut. Wenn ich glaube es verstanden zu haben, am Besten noch mal kurz nachfragen oder in den Task gucken. Code-Style sollten automatisch geregelt sein, wenn dort was nicht stimmt hat ein Tool nicht richtig gearbeitet. Bei der Code Quality muss man sehr genau gucken und zwischen persönlichen Vorlieben und wirklich Sinnhaftigkeit unterscheiden.
Wenn die Verbesserungen reinkommen, gucke ich mir diese Änderungen wieder unter den selben Blickpunkten an. Fällt mir etwas in einem Code-Teil auf der nicht geändert wurde, kann nett fragen, ob der Entwickler das noch mal verbessern könnte. Was ganz sicher machen wird. Kommen die Änderungen wieder und mir fällt wieder etwas auf in einem Teil der von keiner der beiden Änderungen betroffen war, dann... dann ist das mein Problem und ich hab was falsch gemacht oder es ist so unbedeutend, dass es nicht geändert werden muss, ich mir aber für den nächsten Review vornehme darauf zu achten.

Natürlich gibt sehr komplexe Logiken, wo Probleme erst beim 10x rauf gucken auffallen, aber in so einem Fall ist es dann einfach Glück und der genutzten Logik geschuldet... 99% solcher Probleme fallen sonst erst in der Prod-Umgebung auf.

Docker mit der PowerShell

Das meiste findet man immer nur für die Bash. Aber wenn man Docker für Windows verwendet braucht man vieles für die PS. Ich habe hier mal ein paar kleine Dinge zusammen getragen.

Alle Container stoppen:
docker ps -aq | foreach {docker stop $_}


Alle (gestoppten) Container entfernen:
docker ps -aq | foreach {docker rm $_}


Alle (ungenutzen) Images entfernen:
docker images -qa | foreach {docker rmi -f $_}


Alle (ungenutzen) Volumes entfernen:
docker volume ls -qf dangling="true" | foreach {docker volume rm $_}


Alle (custom) Netzwerke entfernen:
docker network ls -q --filter type=custom | foreach {docker network rm $_}

Shopware 6: Docker Dev-Environment

Mein momentanes Dev-Setup für Web-Installer Installation von Shopware 6.

Verzeichnisse und Dateien:

containerData/
apache/
Dockerfile
my_vhost.conf
setup.sh
db_vol/
sw/
...
docker-compose.yml


Web-Installer Dateien kommen in das sw-Verzeichnis.

Dockerfile

FROM php:7.2-apache

RUN apt-get update &&\
apt-get install --no-install-recommends --assume-yes --quiet ca-certificates \
curl \
git \
libxml2-dev \
libxslt-dev \
libfreetype6-dev \
libjpeg62-turbo-dev \
libpng-dev \
libcurl4-gnutls-dev \
zlib1g-dev \
&& docker-php-ext-install -j$(nproc) iconv \
&& docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ \
&& docker-php-ext-install -j$(nproc) gd

RUN apt-get install -y libc-client-dev libkrb5-dev \
&& docker-php-ext-configure imap --with-kerberos --with-imap-ssl \
&& docker-php-ext-install imap

RUN docker-php-ext-install pdo_mysql \
&& docker-php-ext-install json \
&& docker-php-ext-install dom \
&& docker-php-ext-install curl \
&& docker-php-ext-install zip \
&& docker-php-ext-install intl \
&& docker-php-ext-install xml \
&& docker-php-ext-install xsl
RUN rm -rf /var/lib/apt/lists/*

#RUN pecl install xdebug-2.8.0 && docker-php-ext-enable xdebug
#RUN echo 'zend_extension="/usr/local/lib/php/extensions/no-debug-non-zts-20151012/xdebug.so"' >> /usr/local/etc/php/php.ini
#RUN echo 'xdebug.remote_port=9000' >> /usr/local/etc/php/php.ini
#RUN echo 'xdebug.remote_enable=1' >> /usr/local/etc/php/php.ini
#RUN echo 'xdebug.remote_host=host.docker.internal' >> /usr/local/etc/php/php.ini

RUN echo 'memory_limit = 512M' >> /usr/local/etc/php/php.ini

RUN a2enmod rewrite

# copy conf-file to /etc/apache2/sites-enabled/000-default.conf
RUN mkdir /files;
COPY ./setup.sh /files/setup.sh
ENTRYPOINT ["sh", "/files/setup.sh"]


my_vhost.conf

<VirtualHost *:80>
ServerName localhost
ServerAlias www.localhost

DocumentRoot "/var/www/html/public"

RewriteEngine On
RewriteMap lc int:tolower

<Directory "/var/www/html/public">
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
DirectoryIndex index.php
</Directory>
</VirtualHost>


setup.sh

/usr/sbin/apache2ctl -D FOREGROUND


docker-compose.yml

version: '3.3'

services:
sw_mysql:
image: bitnami/mysql:5.7
environment:
MYSQL_ROOT_PASSWORD: root
MYSQL_DATABASE: sw
MYSQL_USER: sw
MYSQL_PASSWORD: sw
volumes:
- ./db_vol/:/bitnami/mysql/data

sw_http:
build: ./containerData/apache
volumes:
- ./containerData/apache/my_vhost.conf:/etc/apache2/sites-enabled/000-default.conf:rw
- ./sw:/var/www/html:rw,delegated
ports:
- 80:80
- 443:443

mail:
image: mailhog/mailhog
ports:
- 8025:8025

adminer:
image: adminer
ports:
- 8082:8080
depends_on:
- sw_mysql


Ich musste mir eine sw2-Datenbank anlegen über root/root, aber an sich sollte es wie in meinem SW5-Environment auf mit der sw-Datenbank und sw/sw gehen.

Docker: PHP IMAP installieren

Wenn man Probleme hat die PHP IMAP-Erweiterung unter Docker zu installieren, kann dieses helfen:


RUN apt-get install -y libc-client-dev libkrb5-dev \
&& docker-php-ext-configure imap --with-kerberos --with-imap-ssl \
&& docker-php-ext-install imap


Bei mir und meiner Shopware 6 Dev-Umgebung hat es jedenfalls gut geholfen.

Es gab beim Bauen des Images vorher diesen Fehler:

utf8_mime2text() has new signature, but U8T_CANONICAL is missing. This should not happen. Check config.log for additional information.

JavaScript: Prettier Formatierung in PHPStorm

Es gibt viele Code-Styling Presets die man einfach in PHPStorm einstellen kann, wie PSR-2 für PHP. Für JavaScript gibt es da wenige und z.B. Prettier wird auch erstmal via NPM installiert.

Dann kann das Problem kommen, dass man Node nicht unter Windows laufen lässt sondern in WSL. Aber da hat PHPStorm zum Glück eine eine fertige Framework-Integration für.

bbcode-image


Damit kann Prettier auch für die normale Reformatierung von PHPStorm mit JS-Dateien ausgewählt werden.

JavaScript Syntax für PHP-Devs

array_merge:

let a = [23, 42, 69];
let b = [112, 256 ...a];


isset() oder ??:

let data = {a: 2, b: 3};
let result = a?.c ?? 0;


Object-Felder als Arguments verwenden:

let data = [
{
id: 0,
name: 'test'
}
];

data.forEach(
({id, name}, idx) => {
console.log(id + ' is named as ' + name + ' and has the index ' + idx);
}
);


Webcams.. teuer, oft schlecht

Ich hatte lange Zeit eine Microsoft Lifecam HD-3000 als einzige Webcam. Dann kam Corona, Homeoffice und Kontakteinschränkungen. Die Webcam der ThinkPads sind aber wirklich schlecht und der Winkel nie ideal, wenn man mit einem externen Monitor arbeitet. Wo sonst Audio bei Discord reichte, wollte man gerne auch die Personen mal wieder sehen und alle möglichen Leute fragen auch wegen Webcams.
Die Microsoft Webcam ist schon wirklich viele Jahre alt und war teilweise für 20 Euro zu haben. Plötzlich lagen die Preise bei 40-60 Euro. Viel zu viel für die Qualität, die die Webcam liefert, war meine Einschätzung. Logitech Webcams waren noch viel stärker im Preis gestiegen. Es gab noch Webcams für 20-30 Euro, die auch HD liefern sollten. Mit Rabatt dachte ich, könne man da nicht viel falsch machen. Doch die Webcams hatten am Ende doch einige Probleme:

- Defekte Zeilen im Sensor
- Schlechte Farbdarstellung
- Mittelmässige Schärfe
- Zwar kippbar aber nicht drehbar (also schnell eine eigene Halterung dafür gedruckt)
- Zu wenig Weitwinkel beim Objektiv

Was ich noch liegen hatte, war eine ganz brauchbare IP Kamera. Aber da die nur per Ethernet angeschlossen werden können, ja keine alternative zu einer Webcam.. oder?

Doch! Windows kann auch ONVIF IP Kameras nun einbinden und diese als normale Kamera nutzen. In der Kamera-App, in Skype und allgemein.

bbcode-image


Man muss unter den Geräten einfach ein neues hinzufügen und kann dort nach IP Kameras suchen lassen. Wie hier beschrieben.

bbcode-image


Gut geeignet für Meetingräume oder auch wenn man größere fest installierte Dinge präsentieren möchte. Durch S- oder C-Mount sind Objektive auch austauschbar.

Am Ende kommt nun aber eine teurere Microsoft Webcam zum Einsatz. Wenn das Bild der alten und der neuen Webcam nebeneinander sieht, ist der 60 Euro Unterschied wirklich deutlich zu sehen und man hat auch wieder mehr Weitwinkel.

Lib-Lizenzen auflisten

Lizenzen einsammeln die man in seinen Projekten benutzt kann manchmal nötig sein. Gerade wenn man Software für andere
entwickelt, kann sich der Kunde dafür interessieren, weil den es ja einschränken könnte, wie er die Software verwendet.

Das geht mit diesen Libs relativ einfach.

PHP:

composer global require comcast/php-legal-licenses
~/.config/composer/vendor/bin/php-legal-licenses generate


NPM:

sudo npm install -g license-checker
license-checker --development --csv > licenses.csv

Smarte Heizkörpersteuerung

Im Homeoffice bin ich faul. Ich will da entspannt arbeiten und so viel schaffen. Ich hab keine Lust mich da noch groß mit dem ganzen Drumherum zu kümmern. Da würde ich am Liebsten alles zu 100% automatisieren. Der erste Schritt ist nun die Heizung. Ich will nicht morgens hoch und abends runter regeln. Wenn ich lüfte will ich auch nicht ganz runter drehen müssen. Ein Grund dafür ist, dass der Heizkörper unter einer Dachschrägen ist und man immer sehr gebückt dahin gehen muss und er Thermostat in der Ausrichtung auch noch sehr schlecht zu lesen ist.

Ich hab mit für ein Thermostat mit DECT-Anbindung von AVM entschieden. Das Fritz!DECT 301. Einmal weil wir eine Fritzbox und DECT für die Telefone schon nutzen und weil man doch relativ einfach und genau die Zeiten über die Fritzbox steuern kann ohne noch eine extra App nutzen zu müssen. Das Home-Office ist für den Versuch ideal, da die Nutzungszeiten sehr genau definiert sind. Es soll etwas vorher warm werden und etwas nach Feierabend wieder kühler werden (falls dann doch mal eine Überstunde ansteht). Zur Mittagszeit in der Pause kann es auch ruhig kühler werden. Natürlich wird es nicht sofort kalt, also wird wohl zu Mittag nicht mehr geheizt aber die Temperatur nur minimal zu der Zeit sinken.

bbcode-image


Die bis zu 30% Kostenersparnis sehe eher sehr skeptisch. Aber eine geringe Kostenersparnis erhoffe ich mir dann doch.

Die Zukunft aussitzen

Wenn man sich die Nachrichten und entsprechende Magazine im TV ansieht (ich sage nur das N in RTL steht für Niveau) hat man das Gefühl die Kinder und Jugendlichen wären gerade um deren Lebensinhalt betrogen worden. Alles was sie lieben und tun wollen ist gerade durch Corona nicht mehr möglich... weil.. die Schulen sind geschlossen. Es scheint kein höheres Ziel mehr zu geben als die Schulen wieder zu öffnen. War noch Ende letzten Jahres ein Inzidenzwert über 30 was schlimmes und über 50 schon eine Katastrophe ist heute ein Wert von 100 schon ideal um alles wieder zu öffnen. Das der Handel ächzt, der lokale Einzelhandel, weil sie sich das Tempo in dem alle Pleite machen etwas erhöht hat und der Online-Handel, weil die mit ihren neuen Projekten und den Arbeitspensum nach kommen, ist man gerade gewohnt. Aber nun springen die Schulen in die selbe Kerbe. Denk doch mal einer an die Kinder!
Ich weiß nicht was mit den Kindern geschehen ist. Früher war vor dem PC, der Konsole, etc sitzen jetzt nicht so schlimm. Man hat per ICQ und Email kommuniziert und hatte auch entsprechende Online-Plattformen. Niemand saß weinend zu hause, weil man nicht in die Schule konnte. Sich zu hause Dinge beizubringen, war auch nicht gerade selten. Das was einen interessierte hat man sowie so nie in der Schule gelernt. QBasic, Turbo Pascal, C und Delphi... das gab es nicht wirklich in der Schule und wenn man damit in der Schule zu tun hatte nicht weil man es dort gelernt hatte sondern weil man es schon konnte. Werden die Kinder vorgeschoben? Klar. Warum? Weil man seine Schwächen dann nicht offenbaren muss. Remote-Learning. Das ist ein Thema mit dem man sich zum Glück nicht mehr beschäftigen muss, weil es gibt ja Impfstoffe. Im Sommer war Corona ja auch schon vorbei und man musste sich deswegen nicht mehr damit beschäftigen. Falls einen jetzt der Impfstoff wieder das Argument kaputt macht, bleibt ja noch das Leiden der Kinder und da darf man ja nicht widersprechen.

Jetzt wird darüber gejammert, dass die Kinder zu viel mit dem Internet zu tun haben und das wäre ja gefährlich. Ganz moderne Ansichten... Niemand hat einen Plan und es wird damit reagiert, dass man in den Angriff geht und alles nieder macht, was zeigen könnte, das die Schule gerade total abgehängt ist. In der Arbeitswelt ist innerhalb von nicht mal einen Jahr Home-Office schon zu einem Standard geworden. Die meisten würden nie wieder einen Arbeitgeber nehmen, wo Homeoffice nicht, wenn auch nur 1-2 Tage pro Woche, nicht möglich ist bzw. abgelehnt wird. Also die Arbeitswelt macht gerade riesige Schritte nach vorne. Die Schule soll die Kinder auf die Arbeitswelt auch vorbereiten. Genu das passiert gerade nicht mehr. Die Arbeitswelt geht nach vorne und die Schule versucht jedes Stolpern nach vorne im Keim zu ersticken. Das hat nichts mit den Lehrern zu tun. Schon Anfang der 2000er hätten einige Leherer gerne umfassende Plattformen im Internet gehabt.
Die Plattformen kommen langsam. Aber mehr Kapazitäten und Rewrites des Codes scheinen wohl zu viel verlangt zu sein. Warum bezahlt man keine Entwickler die sich an den Projekten beteiligen und damit alle voran bringen? Eine brauchbare und skalierbare Lernplattform wäre etwas womit sich Deutschland hervor tun könnte. In der Schule könnte Oberstufen-Kurse Plugins dafür entwickeln und damit ein Ökosystem schaffen, dass sich selbst weiter entwickelt. Self-enablement der Schulen.

Ich bin sehr gespannt, ob wirklich bis zum bitteren Ende versucht wird nichts zu tun und wann endlich mal Konzepte für die Zukunft vorgelegt werden. Die 90er sind vorbei und die Zukunft kam jetzt ("leider") schneller als viele gedacht haben.

PHP: UTF-8 Check einfach

Um schnell zu prüfen, ob ein String schon UTF-8 encoded ist kann man die mb_string Erweiterung nutzen.


mb_detect_encoding($str, 'UTF-8', true) != 'UTF-8'


oder


!mb_detect_encoding($str, 'UTF-8', true)


Damit kann man dem Problem begegnen, dass ein doppeltes UTF-8 Encoding in PHP einfach den String kaputt macht und weil die Funktion selbst nicht prüft, ob ein Encoding überhaupt nötig ist.

Dinge der letzten Wochen in der Kurzform

Ich hatte für meinen Blog leider die letzten Monate wenig Zeit. Viel zu tun bei der Arbeit, daneben und auch noch ein Homeoffice einrichten inkl. Renovierung. Deswegen hier in einer sehr kurzen Form was ich so mal sagen wollte:

* API-Platform: mähhh... ein Springboot finde ich besser und flexibler
* Next.js: React für PHP-Developer... so mag ich React
* Shopware und Translations: s_article_tranlsations ist nur Caching und s_core_translations ist alt und nicht hübsch
* Bootstrap 5: endlich da und sieht aus wie Bootstrap 4 in noch besser (kein JQuery mehr!)
* Sunlu SPLA: totaler Schrott gefühlt... nicht stabil genug
* Webcams: 300%ige Preissteigerungen.. ich war/bin beeindruckt
* Confluence: Ich habe lange mit geweigert und überlegt, aber nun nutze ich auch Confluence für mich selbst
* Cyberpunk 2077: Gutes Spiel, aber gerade aus Entwicklersicht sehr interessant. wie der Release lief und wie die QK/QS doch grandios in einigen Fällen scheitern kann
* Angebot vor paar Wochen - 150 EUR 4K Samsung Monitor: Super für den Preis, zerkratzt leider leicht, ideal für das Homeoffice
* DECT Thermostate: lohnt sich sowas und würde es im Homeoffice(-Dachgeschoss) wirklich Kosten sparen? China Wifi Lösungen sind zwar günstiger aber die AVM-Lösung sieht für mich besser aus, weil es keine Cloud braucht. Integration mit Alexa?

Older posts:

Möchtest Du AdSense-Werbung erlauben und mir damit helfen die laufenden Kosten des Blogs tragen zu können?