-
Download the script above into a folder where you want to download the videos.
-
Open a terminal and run the below command to install dependancies:
pip install cloudscraper requests beautifulsoup4
import { Client as HubspotClient } from "@hubspot/api-client"; | |
import axios, { AxiosError, AxiosInstance, AxiosRequestConfig, AxiosRequestHeaders } from "axios"; | |
// Helpers | |
import { CrudOps, dynamicAxiosRequest } from "../isomorphic/dynamicAxiosRequest"; | |
import { replaceTemplateValues } from "../templateUtils"; | |
// Constants | |
import { | |
HUBSPOT_CONTACT_ASSOCIATION_ID, |
export default function ProgressBar({ currentLevel }: { currentLevel: number }) { | |
return ( | |
<div className="flex justify-between items-center font-mono relative"> | |
{Array.from({ length: 9 }, (_, i) => i).map((index) => ( | |
<div | |
key={index} | |
className={`absolute h-1 z-0 ${index < currentLevel - 1 ? "bg-white" : "bg-zinc-800"}`} | |
style={{ left: `calc(${(index / 10) * 100}% + 4%)`, width: `11%` }} | |
></div> | |
))} |
const getTasks = (ownerId, after) => | |
hubspotInstance | |
.post("/crm/v3/objects/tasks/search", { | |
after, | |
limit: 100, | |
filterGroups: [ | |
{ | |
filters: [ | |
{ |
{ | |
"$schema": "https://json.schemastore.org/tsconfig", | |
"compilerOptions": { | |
"allowJs": false, | |
"alwaysStrict": true, | |
"baseUrl": ".", | |
"esModuleInterop": true, | |
"forceConsistentCasingInFileNames": true, | |
"incremental": true, | |
"isolatedModules": true, |
{ | |
"user_package_id": "a12802db-834f-48c4-89f2-e4a1558e8bc2", | |
"user_package_state": 0, | |
"redeemable": null, | |
"invoice": { | |
"status": 4, | |
"receipt_no": "II9947171", | |
"id": "8bf6c016-b107-41b9-8218-2c6b90c4aba7", | |
"no": "II9947171" | |
}, |
.nav { | |
--link-one: 160px; | |
--link-two: 160px; | |
--link-three: 160px; | |
--link-four: 160px; | |
--link-five: 160px; | |
--menu-width: calc(var(--link-one) + var(--link-two) + var(--link-three) + var(--link-four) + var(--link-five)); | |
--link-two-left: var(--link-one); |
import firebase from "firebase/app"; | |
import "firebase/database"; | |
export const onceValue = <T>(path: string): Promise<Nullable<T>> => | |
firebase | |
.database() | |
.ref(path) | |
.once("value") | |
.then((snap) => snap.val()); | |
export const firebaseUpdate = (path: string, updateObj: Object) => firebase.database().ref(path).update(updateObj); |
export const saveLiveSwitchRecording = async ( | |
recordingId: string, | |
channelId: string, | |
fileName: string, | |
type: "video" | "audio" | |
) => { | |
const file = makeLiveSwitchRecordingFile(recordingId, channelId, fileName); | |
const format = fileName.substring(fileName.indexOf(".") + 1); | |
const writeStream = file.createWriteStream({ | |
metadata: { |
const getChromeVersion = () => { | |
const raw = navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./) | |
return raw ? parseInt(raw[2], 10) : false | |
} | |
if (getChromeVersion() < 93) { | |
alert('We recommend you use a Chrome browser version 93 or greater otherwise you may experience degraded service.') | |
} |