Skip to content

Instantly share code, notes, and snippets.

jimkang / download-soundcloud-playlist.js
Last active January 1, 2024 22:44
Download everything from a SoundCloud playlist
View download-soundcloud-playlist.js
// Paste this into the console and get ready to click "Save" in response to the save dialog a bunch of times. Or better yet, disable asking where to save in your browser.
var buttons = document.querySelectorAll('.sc-button-more')
var index = 0;
function moreNext() { var more = buttons[index];; ++index; setTimeout(dl, 500); }
function dl() { var dlButton = document.querySelector('.sc-button-download');; if (index < buttons.length) { setTimeout(moreNext, 100);}}
jimkang / make-indexes.js
Last active August 16, 2023 03:20
Create html indexes for images in a folder. Classic! Puts the index files in a directory named `indexes`; you may want to change that.
View make-indexes.js
#!/usr/bin/env node
/* global process */
var fs = require('fs');
var imgFileExts = ['png', 'jpg'];
if (process.argv.length < 3) {
'Usage: node make-index.js <directory with images>'
jimkang / obsidian.desktop
Created May 23, 2023 23:14
Obsidian AppImage desktop shortcut that goes in /usr/share/applications/obsidian.desktop.
View obsidian.desktop
[Desktop Entry]
GenericName=Notes organizer
Comment=Organize notes
Keywords[ru]=текст;текстовый редактор;
jimkang / roll-until-you-get-it.js
Last active February 16, 2023 02:38
Console automation for roll-a-guy
View roll-until-you-get-it.js
function getYourClass(targetClass) { document.getElementById('roll-button').click(); setTimeout(() => { if (document.getElementById('class').textContent !== targetClass) { window.requestAnimationFrame(() => getYourClass(targetClass)); }}, 0) }
// Edit selector to check things other than strength.
function getYourScore(minScore) { document.getElementById('roll-button').click(); setTimeout(() => { if (+document.querySelector('.row:first-child .ability-score-column').textContent < minScore) { window.requestAnimationFrame(() => getYourScore(minScore)); }}, 0) }
jimkang / Contract Killer
Last active October 27, 2021 23:18 — forked from malarkey/Contract Killer
The latest version of my ‘killer contract’ for web designers and developers
View Contract Killer

Contract Killer

The popular open-source contract for web professionals by Stuff & Nonsense

  • Originally published: 23rd December 2008
  • Revised date: March 15th 2016
  • Original post

jimkang /
Created February 19, 2021 03:03
When you download from Bandcamp, the zip file comes with no directory structure, so this gives it one. Explanation:
for file in *.zip
# Filenames can't contain /. So, I wonder
# what Bandcamp would do if they had AC/DC?
unzippath=$(echo "$filename" |sed -e 's/ - /\//')
mkdir -p "$unzippath"
unzip "$filename" -d "$unzippath"
jimkang /
Last active April 5, 2020 19:26
Simple script for getting markdown files in a certain date range (assuming the files use a common Zettelkasten naming convention in which every file starts with YYYY-MM-DD).
if [[ ! $start ]] && [[ ! $end ]]; then
printf "Usage: ./tools/ [start string] [end string]\nEnd string is optional.\n\nExample: To get filenames that come after 2020-03 (anywhere in March) but before 2020-03-29 (assuming files follow this naming convention):\n./tools/ 2020-03 2020-03-29\n";
exit 1;
jimkang /
Created December 2, 2019 14:53
Because I always forget
import pickle
import json
data = pickle.load(open('file.pkl', 'rb'))
out_file = open("out.json", "w")
jimkang / static-ease-values.js
Created November 13, 2019 23:16
Get static cubic easing values. I just ran these in the Node REPL to get the numbers.
View static-ease-values.js
var { easeCubic } = require('d3-ease')
var { range } = require('d3-array')
range(0, 1, 0.05).map(easeCubic).map(n => n.toFixed(2)).join(';')
jimkang / noise.html
Last active September 4, 2019 02:11
Perlin noise SVG filter
View noise.html
<svg width="40" height="40" viewBox="0 0 100 100"
<filter id="displacementFilter">
<feTurbulence type="fractalNoise" baseFrequency="0.75"
numOctaves="2" result="turbulence" stitchTiles="stitch"/>
<rect id="noise-square" width="40" height="40"
style="filter: url(#displacementFilter)"/>