Skip to content

Instantly share code, notes, and snippets.

Avatar
If you find a bug in my code, I've probably haven't had enough coffee yet...

Erik Hellman ErikHellman

If you find a bug in my code, I've probably haven't had enough coffee yet...
View GitHub Profile
@ErikHellman
ErikHellman / TextFieldText.dart
Last active Apr 2, 2020
Testing the TextField decoration
View TextFieldText.dart
import 'package:flutter/material.dart';
final Color darkBlue = Color.fromARGB(255, 18, 32, 47);
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
@ErikHellman
ErikHellman / LoginScreenWithCompose.kt
Created Dec 16, 2019
A simple demo of using Jetpack Compose to build a Login screen
View LoginScreenWithCompose.kt
package se.hellsoft.jetpackcomposeintro
import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import androidx.compose.Composable
import androidx.compose.Model
import androidx.compose.state
import androidx.compose.unaryPlus
import androidx.ui.core.*
import androidx.ui.foundation.shape.border.Border
@ErikHellman
ErikHellman / KittyLog.kt
Last active Sep 4, 2019
A super tiny wrapper for Android Log utility that allows log printing in unit tests. For a more advanced log wrapper for Android, see https://github.com/JakeWharton/timber/
View KittyLog.kt
/*
Licensed under Apache 2.0 (https://www.apache.org/licenses/LICENSE-2.0.txt)
This is a tiny log utility for Android Logcat. It allows logs to be used in code that is unit
tested on host (without Android framework available).
The only advantage with this utility above Timber is that it doesn't require any setup.
For real-world, production application I strongly recommend using Timber (see https://github.com/JakeWharton/timber/) instead.
*/
@file:Suppress("unused")
@ErikHellman
ErikHellman / KittyLog.kt
Created Aug 19, 2019
A super tiny wrapper for Android Log utility.
View KittyLog.kt
@file:Suppress("unused")
package se.hellsoft.coroutineantipatterns
import android.util.Log
internal const val TAG = "KittyLog"
fun logi(message: String, throwable: Throwable? = null) {
try {
@ErikHellman
ErikHellman / NonBlockingEchoServer.kt
Last active Aug 16, 2019
A very simple example of an echo-server using the non-blocking Java I/O APIs
View NonBlockingEchoServer.kt
package se.hellsoft.nonblocking.echo
import java.net.InetSocketAddress
import java.nio.ByteBuffer
import java.nio.channels.SelectionKey
import java.nio.channels.Selector
import java.nio.channels.ServerSocketChannel
import java.nio.channels.SocketChannel
/**
@ErikHellman
ErikHellman / ImageFormatName.kt
Last active Aug 8, 2019
Kotlin functions for getting the name of an ImageFormat or PixelFormat Integer.
View ImageFormatName.kt
fun imageFormatName(format: Int): String = when (format) {
ImageFormat.DEPTH16 -> "DEPTH16"
ImageFormat.DEPTH_JPEG -> "DEPTH_JPEG"
ImageFormat.DEPTH_POINT_CLOUD -> "DEPTH_POINT_CLOUD"
ImageFormat.FLEX_RGBA_8888 -> "FLEX_RGBA_8888"
ImageFormat.FLEX_RGB_888 -> "FLEX_RGB_888"
ImageFormat.HEIC -> "HEIC"
ImageFormat.JPEG -> "JPEG"
ImageFormat.NV16 -> "NV16"
ImageFormat.NV21 -> "NV21"
@ErikHellman
ErikHellman / WebViewServer.kt
Last active Feb 1, 2020
This class is no longer needed now that Google provides WebViewAssetLoader (see https://developer.android.com/reference/kotlin/androidx/webkit/WebViewAssetLoader)
View WebViewServer.kt
/*
MIT License
Copyright (c) 2019 Erik Hellman
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
@ErikHellman
ErikHellman / WebViewServer.kt
Created Apr 8, 2019
A simple "web server" for handling intercepted WebView requests on Android and deliver local content.
View WebViewServer.kt
@file:Suppress("unused")
package se.hellsoft.webviewserver
import android.content.res.AssetManager
import android.net.Uri
import android.webkit.WebResourceRequest
import android.webkit.WebResourceResponse
import java.io.ByteArrayInputStream
import java.io.File
@ErikHellman
ErikHellman / generateSelector.js
Last active Jan 10, 2019
Generate a selector for an element.
View generateSelector.js
// Create a path to an element of the form 2/1/1/34 (index of each child)
function getDomPath(el) {
const stack = [];
while (el.parentNode != null) {
console.log(el.nodeName);
let sibCount = 0;
let sibIndex = 0;
for (let i = 0; i < el.parentNode.childNodes.length; i++) {
const sib = el.parentNode.childNodes[i];
if (sib === el) {
@ErikHellman
ErikHellman / LitElementDialogExample.js
Last active Aug 7, 2020
Basic dialog example with LitElement
View LitElementDialogExample.js
import { LitElement, html } from '@polymer/lit-element'
import { classMap } from 'lit-html/directives/classMap'
class MyDialog extends LitElement {
constructor () {
super()
this.opened = false
}
You can’t perform that action at this time.