Skip to content

Instantly share code, notes, and snippets.

View wojtekmaj's full-sized avatar
👨‍👩‍👧‍👦
Focusing on personal life

Wojciech Maj wojtekmaj

👨‍👩‍👧‍👦
Focusing on personal life
View GitHub Profile
@wojtekmaj
wojtekmaj / install-and-check.sh
Created May 17, 2024 11:38
Quick eslint-plugin-react-compiler check
yarn add eslint-plugin-react-compiler --dev
node -e "const fs = require('fs'); const eslintrcJson = JSON.parse(fs.readFileSync('.eslintrc.json')); eslintrcJson.plugins = eslintrcJson.plugins || []; eslintrcJson.plugins.push('react-compiler'); eslintrcJson.rules = eslintrcJson.rules || {}; eslintrcJson.rules['react-compiler/react-compiler'] = 'error'; fs.writeFileSync('.eslintrc.json', JSON.stringify(eslintrcJson, null, 2));"
yarn lint
@wojtekmaj
wojtekmaj / ci.sh
Last active May 15, 2024 19:50
React 19 compatibility quick test
npm pkg set resolutions.'@types/react'='npm:types-react@rc'
npm pkg set resolutions.'@types/react-dom'='npm:types-react-dom@rc'
yarn config set enableImmutableInstalls false
yarn up react@rc react-dom@rc
@wojtekmaj
wojtekmaj / use.ts
Last active November 25, 2024 04:51
use() hook you can use in React 18 (stable) today
/// <reference types="react/next" />
import { use as originalUse, useContext } from 'react';
const STATUS = {
PENDING: 'pending',
REJECTED: 'rejected',
FULFILLED: 'fulfilled',
} as const;
type TState<T> =
@wojtekmaj
wojtekmaj / index.ts
Last active October 23, 2023 06:25
GitHub monthly issues stats
import fs from 'node:fs';
import { asyncForEach, asyncForEachStrict } from '@wojtekmaj/async-array-utils';
import chalk from 'chalk';
import { endOfMonth, formatISO, startOfMonth } from 'date-fns';
const CACHE_DIR = '.cache';
const GITHUB_API_URL = 'https://api.github.com';
const GITHUB_TOKEN = process.env.GITHUB_TOKEN;
const DEBUG = process.env.DEBUG === 'true';
@wojtekmaj
wojtekmaj / foreach.sh
Created June 6, 2023 09:04
Run a given script for each Git repository in the given directory
# Sample usage: bash ./foreach.sh ./update-dependencies.sh
script_dir=$(dirname -- "$( readlink -f -- "$0"; )")
echo "Running script $1 for each repository"
# Find all Git repositories, skipping node_modules directories
find . -maxdepth 4 -name ".git" -print0 | while read -d $'\0' repo; do
echo "Processing ${repo%/.git}"
@wojtekmaj
wojtekmaj / add-missing-import-extensions.txt
Last active December 2, 2024 20:04
Visual Studio Code-compatible regular expression to add all missing import extensions
# Find
import\s(([^;]|\n)*)\sfrom\s(['"])(\.{1,2}\/.*)(?<!\.js)(?<!\.(css|pdf|png|jpg|jsx|mjs|mp3|mp4|svg|ttf))(?<!\.(avif|json|webm|webp|woff))(?<!\.woff2)(['"]);
# Replace with
import $1 from $3$4.js$7;
@wojtekmaj
wojtekmaj / jest-to-vitest.sh
Last active December 23, 2024 20:44
Automatically migrate Jest project to Vitest
#!/bin/bash
# Ensure we're working on the latest version of the main branch
git switch main
git fetch
git pull
# Create a new branch
git switch -c vitest
@wojtekmaj
wojtekmaj / webpack-to-vite.sh
Created March 2, 2023 10:53
Automatically migrate Webpack project to Vite
#!/bin/bash
# Ensure we're working on the latest version of the main branch
git switch main
git fetch
git pull
# Create a new branch
git switch -c vite
@wojtekmaj
wojtekmaj / update-dependencies.sh
Created January 5, 2023 00:05
Update all your dependencies in /, /sample, /sample/*, /test directories
#!/bin/bash
# Define function
update_dependencies() {
rm -rf yarn.lock
touch yarn.lock
yarn
yarn dedupe
}
@wojtekmaj
wojtekmaj / update-year-in-licence.sh
Created January 4, 2023 23:58
Find all Git repositories recursively and update year in LICENSE if commit was made in current year
#!/bin/bash
current_year=$(date +%Y)
# Find all Git repositories, skipping node_modules directories
find . -type d -name .git -not -path '*/node_modules/*' -print0 | while read -d $'\0' repo; do
# Go to the repository directory
cd "${repo%/.git}"
# Check the year of the last commit