Skip to content

Instantly share code, notes, and snippets.

@kerams
kerams / 1.md
Last active May 3, 2021
Lazy loading of localization texts in Fable
View 1.md

Lazy loading of localization texts in Fable

Fable 3, Elmish, .NET 5, React, Webpack 5, npm. Demo code at https://github.com/kerams/fable-lazy-load-localization-sample.

At some point during the lifetime of your Fable application you may decide you need to support more than one language (in this post I am concerned with UI texts only, not data that is sent from the server) as well as the ability to switch the desired language on the fly. Let's say you have to support several languages with a ton of text each. Including them in your main application file/bundle will obviously make using them very straightforward and easy, but would prove incredibly wasteful. A single user will hardly use multiple languages, so having them download something they will never see or make use of does not make much sense.

While you could try using a full-fledged framework like react-i18next to handle all your localization needs, I'll detail the simplest means of getting parts of your UI localized tha

@kerams
kerams / Sample.fs
Created May 31, 2020
Reusable debouncer hook for F#/React/Fable based on Feliz.UseElmish
View Sample.fs
// depends on https://www.nuget.org/packages/Feliz.UseElmish
module Debouncer =
type private DebounceState<'a> = {
Value: 'a
OnDone: 'a -> unit
Delay: int }
type private Msg<'a> =
| ValueChanged of 'a
| Debounced of 'a
View Network tests
#!/bin/bash
#
# Network speed testing script put together by `aFriend` from LowEndTalk.
# http://lowendtalk.com/discussion/comment/561833/#Comment_561833
#
function download_benchmark() {
DOWNLOAD_SPEED=`wget -O /dev/null $2 2>&1 | awk '/\/dev\/null/ {speed=$3 $4} END {gsub(/\(|\)/,"",speed); print speed}'`
echo "Got $DOWNLOAD_SPEED : $1 ($2)"
}