Skip to content

Instantly share code, notes, and snippets.

View waptik's full-sized avatar
💻
Learning JavaScript and ReactJS...

TheVirginBrokey waptik

💻
Learning JavaScript and ReactJS...
View GitHub Profile
@waptik
waptik / bot.ts
Last active July 16, 2024 22:29
This is a minimal codebase of getting grammY to work with nextjs pages directory. Please use this version of `next-connect`: `"next-connect": "^0.13.0",`
import { Bot, Context } from "grammy";
export const bot = new Bot<Context>(process.env.TELEGRAM_BOT_TOKEN ?? "");
@waptik
waptik / compress-base64-imgs.js
Created June 16, 2024 18:48 — forked from 1isten/compress-base64-imgs.js
js compress image (base64) using canvas api
const toBase64 = (file) => new Promise((resolve, reject) => {
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = (e) => resolve(e.target.result);
reader.onerror = (err) => reject(err);
});
const compressBase64 = (src, quality = 0.5) => new Promise((resolve) => {
const img = new Image();
img.src = src;
@waptik
waptik / bot.ts
Last active April 29, 2024 11:27
An example on how to use grammY's Interactive Menus plugin
// I'm using deno
import "https://deno.land/std@0.178.0/dotenv/load.ts";
import { green } from "https://deno.land/std@0.178.0/fmt/colors.ts";
import { itemsMenu } from './menus/example.menu.ts';
const grammy = new Bot<GrammyContext>(Deno.env.get("BOT_TOKEN")||""); // replace `BOT_TOKEN` inside `.env` file with your own telegram bot's token
// attaching the menu to bot to get it to work if not we'll get the following errors inside the terminal
// `Error: Cannot send menu 'bot-items-menu'! Did you forget to use bot.use() for it?`
@waptik
waptik / index.ts
Created July 12, 2021 16:48
A custom extension for tiptap v2 to for image upload
import { Node, nodeInputRule } from "@tiptap/core";
import { mergeAttributes } from "@tiptap/react";
import { uploadImagePlugin, UploadFn } from "./upload_image";
/**
* Tiptap Extension to upload images
* @see https://gist.github.com/slava-vishnyakov/16076dff1a77ddaca93c4bccd4ec4521#gistcomment-3744392
* @since 7th July 2021
*
@waptik
waptik / ngrok_hostname.sh
Created January 21, 2024 22:00 — forked from rjz/ngrok_hostname.sh
Get ngrok hostname from command line
#!/bin/sh
# ngrok's web interface is HTML, but configuration is bootstrapped as a JSON
# string. We can hack out the forwarded hostname by extracting the next
# `*.ngrok.io` string from the JSON
#
# Brittle as all get out--YMMV. If you're still reading, usage is:
#
# $ ./ngrok_hostname.sh <proto> <addr>
#
@waptik
waptik / turbo-workspaces-error.sh
Created January 4, 2024 22:48
cli error message for @turbo/workspaces package when migrating from yarn to pnpm
>>> TURBOREPO
Welcome, let's convert your project.
? Where is the root of your repo? .
? Convert from yarn workspaces to: pnpm workspaces
Converting project from yarn to pnpm.
@waptik
waptik / .gitpod.Dockerfile
Created December 23, 2023 22:28
Current gitpod configuration files for my deno fresh app
FROM gitpod/workspace-full
RUN curl -fsSL https://deno.land/x/install/install.sh | sh
RUN /home/gitpod/.deno/bin/deno completions bash > /home/gitpod/.bashrc.d/90-deno && \
echo 'export DENO_INSTALL="/home/gitpod/.deno"' >> /home/gitpod/.bashrc.d/90-deno && \
echo 'export PATH="$DENO_INSTALL/bin:$PATH"' >> /home/gitpod/.bashrc.d/90-deno
@waptik
waptik / personas.menu.ts
Last active December 18, 2023 18:33
a simple pagination handler in grammY using the menu plugin
let pageIndex = 0;
/**
* A function that generates a paginated menu
*
* @param index The index of the page to generate
* @returns A range of the menu
*/
function personalityMenuRange(
@waptik
waptik / Backsticks.txt
Created November 27, 2023 17:42
Ummmm
Certainly! Here's a TypeScript function that takes a text string as input and returns an array of code snippets found within code blocks wrapped in triple backticks(```) or `<code>`:
```typescript
function extractCodeSnippets(text: string): string[] {
const codeSnippets: string[] = [];
const regex = /```([\s\S]*?)```|<code>([\s\S]*?)<\/code>/g;
let match;
while ((match = regex.exec(text)) !== null) {
const codeSnippet = match[1] || match[2];
@waptik
waptik / 1701015161995.txt
Created November 26, 2023 18:53
chatgpt response from api
Certainly! Here's a TypeScript function that takes a text as input and returns an array of code snippets found within multiple lines code blocks wrapped in triple backticks (```) or `<code>` tags with language tags:
```typescript
function extractCodeSnippets(text: string): { language: string, code: string }[] {
const codeBlockRegex = /```(\w+)\n([\s\S]*?)```|<code(?:\s+class="language-(\w+)")?>([\s\S]*?)<\/code>/g;
const codeSnippets: { language: string, code: string }[] = [];
let match;
while ((match = codeBlockRegex.exec(text)) !== null) {
const [, language1, code1, language2, code2] = match;