@edwinvakayil/calligraphy 1.3.0 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/animation.d.ts +5 -2
- package/dist/index.d.ts +62 -36
- package/dist/index.esm.js +359 -73
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +359 -73
- package/dist/index.js.map +1 -1
- package/dist/types.d.ts +62 -36
- package/package.json +1 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../node_modules/tslib/tslib.es6.js","../../fonts.ts","../../animation.ts","../../Context.tsx","../../Typography.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","/**\n * A curated list of popular Google Fonts.\n * Pass any valid Google Font name to the `font` prop — if it's in this list,\n * it will be auto-injected via a <link> tag. For unlisted fonts, add them here\n * or import them manually in your project.\n */\nexport const GOOGLE_FONTS: string[] = [\n // Serif\n \"Playfair Display\",\n \"Merriweather\",\n \"Lora\",\n \"EB Garamond\",\n \"Libre Baskerville\",\n \"Cormorant Garamond\",\n \"DM Serif Display\",\n \"Crimson Text\",\n \"Source Serif 4\",\n \"Fraunces\",\n\n // Sans-serif\n \"Inter\",\n \"Roboto\",\n \"Open Sans\",\n \"Nunito\",\n \"Poppins\",\n \"Raleway\",\n \"Outfit\",\n \"DM Sans\",\n \"Manrope\",\n \"Plus Jakarta Sans\",\n \"Figtree\",\n \"Syne\",\n \"Albert Sans\",\n\n // Display / Expressive\n \"Bebas Neue\",\n \"Oswald\",\n \"Anton\",\n \"Barlow Condensed\",\n \"Righteous\",\n \"Abril Fatface\",\n \"Dela Gothic One\",\n \"Space Grotesk\",\n \"Unbounded\",\n \"Big Shoulders Display\",\n\n // Mono\n \"JetBrains Mono\",\n \"Fira Code\",\n \"Source Code Pro\",\n \"Space Mono\",\n \"IBM Plex Mono\",\n];\n\nconst injectedFonts = new Set<string>();\n\n/**\n * Builds a Google Fonts URL for a given font family.\n * Requests weights 300, 400, 500, 600, 700, 800 — italic variants included.\n */\nexport function buildFontUrl(fontFamily: string): string {\n const encoded = fontFamily.replace(/ /g, \"+\");\n return `https://fonts.googleapis.com/css2?family=${encoded}:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,700&display=swap`;\n}\n\n/**\n * Injects a Google Fonts <link> into <head> once per unique URL.\n * Safe to call multiple times — deduped via a Set.\n */\nexport function injectFont(url: string): void {\n if (typeof document === \"undefined\") return; // SSR guard\n if (injectedFonts.has(url)) return;\n\n const link = document.createElement(\"link\");\n link.rel = \"stylesheet\";\n link.href = url;\n document.head.appendChild(link);\n injectedFonts.add(url);\n}\n\n/**\n * Pre-load a set of fonts eagerly (e.g. at app root).\n * Usage: preloadFonts([\"Playfair Display\", \"Inter\"])\n */\nexport function preloadFonts(families: string[]): void {\n families.forEach((f) => {\n if (GOOGLE_FONTS.includes(f)) {\n injectFont(buildFontUrl(f));\n } else {\n console.warn(\n `[@edwinvakayil/calligraphy] \"${f}\" is not in the bundled GOOGLE_FONTS list. ` +\n `Add it to the list or import it manually.`\n );\n }\n });\n}","import { HeroAnimation } from \"./types\";\n\nconst STYLE_ID = \"rts-hero-animations\";\n\nconst CSS = `\n@keyframes rts-rise { from{opacity:0;transform:translateY(32px)} to{opacity:1;transform:translateY(0)} }\n@keyframes rts-clip { from{clip-path:inset(0 100% 0 0)} to{clip-path:inset(0 0% 0 0)} }\n@keyframes rts-pop { 0%{opacity:0;transform:scale(0.75)} 60%{opacity:1;transform:scale(1.04)} 100%{transform:scale(1)} }\n@keyframes rts-blur { from{opacity:0;filter:blur(14px);transform:scale(1.04)} to{opacity:1;filter:blur(0);transform:scale(1)} }\n@keyframes rts-flip { from{opacity:0;transform:perspective(600px) rotateX(30deg) translateY(20px)} to{opacity:1;transform:perspective(600px) rotateX(0) translateY(0)} }\n@keyframes rts-swipe { from{opacity:0;transform:translateX(60px)} to{opacity:1;transform:translateX(0)} }\n@keyframes rts-bounce { 0%{opacity:0;transform:translateY(-60px)} 60%{opacity:1;transform:translateY(10px)} 80%{transform:translateY(-5px)} 100%{transform:translateY(0)} }\n@keyframes rts-type { from{width:0} to{width:100%} }\n@keyframes rts-blink { 50%{border-color:transparent} }\n@keyframes rts-word-rise { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }\n@keyframes rts-letter-in { from{opacity:0;transform:translateX(-16px) rotate(-4deg)} to{opacity:1;transform:none} }\n\n/* ── New modern animations ─────────────────────────────────────────────── */\n\n@keyframes rts-velvet { from{opacity:0;transform:translate(-12px,20px) skewX(4deg)} to{opacity:1;transform:translate(0,0) skewX(0deg)} }\n@keyframes rts-curtain { from{clip-path:inset(0 0 100% 0)} to{clip-path:inset(0 0 0% 0)} }\n@keyframes rts-morph { 0%{opacity:0;transform:scaleY(0.3) scaleX(1.3) translateY(10px)} 60%{opacity:1;transform:scaleY(1.08) scaleX(0.97)} 100%{transform:scaleY(1) scaleX(1)} }\n@keyframes rts-ground { from{transform:translateY(110%);opacity:0} to{transform:translateY(0);opacity:1} }\n@keyframes rts-cascade { from{opacity:0;transform:translateY(-28px) translateX(10px) rotate(8deg)} to{opacity:1;transform:none} }\n@keyframes rts-spotlight { 0%{opacity:0;letter-spacing:0.3em;transform:scaleX(1.15)} 100%{opacity:1;letter-spacing:-0.03em;transform:scaleX(1)} }\n@keyframes rts-ink { 0%{opacity:0;transform:translateY(6px) scale(0.96)} 100%{opacity:1;transform:translateY(0) scale(1)} }\n@keyframes rts-hinge { from{opacity:0;transform:perspective(400px) rotateY(-40deg) translateX(-20px)} to{opacity:1;transform:perspective(400px) rotateY(0) translateX(0)} }\n@keyframes rts-stretch { 0%{opacity:0;transform:scaleX(0.05)} 60%{transform:scaleX(1.04)} 100%{opacity:1;transform:scaleX(1)} }\n@keyframes rts-peel { from{clip-path:inset(100% 0 0 0)} to{clip-path:inset(0% 0 0 0)} }\n\n/* ── Whole-element classes (no splitting needed) ───────────────────────── */\n.rts-rise { animation: rts-rise 0.9s cubic-bezier(0.16,1,0.3,1) both }\n.rts-clip { animation: rts-clip 1.1s cubic-bezier(0.77,0,0.18,1) both }\n.rts-pop { animation: rts-pop 0.7s cubic-bezier(0.34,1.56,0.64,1) both }\n.rts-blur { animation: rts-blur 1s cubic-bezier(0.16,1,0.3,1) both }\n.rts-flip { animation: rts-flip 0.9s cubic-bezier(0.16,1,0.3,1) both; transform-origin: center bottom }\n.rts-swipe { animation: rts-swipe 0.8s cubic-bezier(0.16,1,0.3,1) both }\n.rts-bounce { animation: rts-bounce 0.9s cubic-bezier(0.36,0.07,0.19,0.97) both }\n.rts-typewriter { overflow: hidden; white-space: nowrap; border-right: 2px solid currentColor; width: 0; animation: rts-type 1.6s steps(22,end) both, rts-blink 0.7s step-end 1.6s 3 }\n.rts-morph { animation: rts-morph 0.8s cubic-bezier(0.34,1.56,0.64,1) both }\n.rts-spotlight { animation: rts-spotlight 1s cubic-bezier(0.16,1,0.3,1) both }\n.rts-stretch { animation: rts-stretch 0.9s cubic-bezier(0.34,1.56,0.64,1) both }\n\n/* ── Per-word / per-character span classes ─────────────────────────────── */\n.rts-word { display:inline-block;opacity:0;transform:translateY(24px);animation:rts-word-rise 0.7s cubic-bezier(0.16,1,0.3,1) both }\n.rts-letter { display:inline-block;opacity:0;transform:translateX(-16px) rotate(-4deg);animation:rts-letter-in 0.5s cubic-bezier(0.16,1,0.3,1) both }\n.rts-velvet-word { display:inline-block;opacity:0;animation:rts-velvet 0.65s cubic-bezier(0.16,1,0.3,1) both }\n.rts-curtain-word { display:inline-block;overflow:hidden;animation:rts-curtain 0.7s cubic-bezier(0.77,0,0.18,1) both }\n.rts-ground-wrap { display:inline-block;overflow:hidden;vertical-align:bottom }\n.rts-ground-inner { display:inline-block;animation:rts-ground 0.65s cubic-bezier(0.16,1,0.3,1) both }\n.rts-cascade-ch { display:inline-block;opacity:0;animation:rts-cascade 0.45s cubic-bezier(0.34,1.56,0.64,1) both }\n.rts-ink-word { display:inline-block;opacity:0;animation:rts-ink 0.9s cubic-bezier(0.16,1,0.3,1) both }\n.rts-hinge-word { display:inline-block;opacity:0;transform-origin:left center;animation:rts-hinge 0.6s cubic-bezier(0.16,1,0.3,1) both }\n.rts-peel-word { display:inline-block;overflow:hidden;animation:rts-peel 0.6s cubic-bezier(0.77,0,0.18,1) both }\n`;\n\nexport function injectAnimationStyles(): void {\n if (typeof document === \"undefined\") return;\n if (document.getElementById(STYLE_ID)) return;\n const style = document.createElement(\"style\");\n style.id = STYLE_ID;\n style.textContent = CSS;\n document.head.appendChild(style);\n}\n\n// ─── Whole-element class map ──────────────────────────────────────────────────\n\nconst WHOLE_CLASS_MAP: Partial<Record<HeroAnimation, string>> = {\n rise: \"rts-rise\",\n clip: \"rts-clip\",\n pop: \"rts-pop\",\n blur: \"rts-blur\",\n flip: \"rts-flip\",\n swipe: \"rts-swipe\",\n bounce: \"rts-bounce\",\n typewriter: \"rts-typewriter\",\n morph: \"rts-morph\",\n spotlight: \"rts-spotlight\",\n stretch: \"rts-stretch\",\n};\n\n/** Returns the CSS class for whole-element animations, or \"\" for split ones. */\nexport function getAnimationClass(animation: HeroAnimation): string {\n return WHOLE_CLASS_MAP[animation] ?? \"\";\n}\n\n/** True if the animation needs the HTML to be split into word/char spans. */\nexport function isSplitAnimation(animation: HeroAnimation): boolean {\n return !(animation in WHOLE_CLASS_MAP);\n}\n\n// ─── HTML builders for split animations ──────────────────────────────────────\n\nfunction wrapWords(\n html: string,\n cls: string,\n delayStep: number\n): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n return tokens\n .map((tok, i) => {\n const delay = (i * delayStep).toFixed(2);\n if (tok.startsWith(\"<em>\")) {\n return `<em><span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok.slice(4, -5)}</span></em>`;\n }\n return `<span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok}</span>`;\n })\n .join(\" \");\n}\n\nfunction wrapChars(html: string, cls: string, delayStep: number): string {\n const result: string[] = [];\n let inEm = false;\n let delay = 0;\n let i = 0;\n while (i < html.length) {\n if (html.startsWith(\"<em>\", i)) { inEm = true; i += 4; continue; }\n if (html.startsWith(\"</em>\", i)) { inEm = false; i += 5; continue; }\n const ch = html[i];\n if (ch === \" \") { result.push(\" \"); i++; continue; }\n const span = `<span class=\"${cls}\" style=\"animation-delay:${delay.toFixed(2)}s\">${ch}</span>`;\n result.push(inEm ? `<em>${span}</em>` : span);\n delay += delayStep;\n i++;\n }\n return result.join(\"\");\n}\n\nfunction wrapGround(html: string, delayStep: number): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n return tokens\n .map((tok, i) => {\n const delay = (i * delayStep).toFixed(2);\n const inner = tok.startsWith(\"<em>\")\n ? `<em>${tok.slice(4, -5)}</em>`\n : tok;\n return `<span class=\"rts-ground-wrap\"><span class=\"rts-ground-inner\" style=\"animation-delay:${delay}s\">${inner}</span></span>`;\n })\n .join(\" \");\n}\n\nexport function buildSplitHTML(animation: HeroAnimation, html: string): string {\n switch (animation) {\n case \"stagger\": return wrapWords(html, \"rts-word\", 0.07);\n case \"letters\": return wrapChars(html, \"rts-letter\", 0.04);\n case \"velvet\": return wrapWords(html, \"rts-velvet-word\", 0.08);\n case \"curtain\": return wrapWords(html, \"rts-curtain-word\",0.10);\n case \"ground\": return wrapGround(html, 0.09);\n case \"cascade\": return wrapChars(html, \"rts-cascade-ch\", 0.05);\n case \"ink\": return wrapWords(html, \"rts-ink-word\", 0.10);\n case \"hinge\": return wrapWords(html, \"rts-hinge-word\", 0.09);\n case \"peel\": return wrapWords(html, \"rts-peel-word\", 0.10);\n default: return html;\n }\n}\n\n// Legacy named exports kept for backwards compatibility\nexport const buildStaggerHTML = (html: string) => buildSplitHTML(\"stagger\", html);\nexport const buildLettersHTML = (html: string) => buildSplitHTML(\"letters\", html);","import React, { createContext, useContext, useMemo } from \"react\";\nimport { HeroAnimation } from \"./types\";\nimport { injectFont, buildFontUrl, GOOGLE_FONTS } from \"./fonts\";\n\n// ─── Theme shape ──────────────────────────────────────────────────────────────\n\nexport interface TypographyTheme {\n /** Default Google Font for all Typography components */\n font?: string;\n\n /** Default accent color for <em> italic spans in Display / H1 */\n accentColor?: string;\n\n /** Default italic setting for Display / H1 heroes */\n italic?: boolean;\n\n /** Default entrance animation for Display / H1 heroes */\n animation?: HeroAnimation;\n\n /** Default text color applied to all variants */\n color?: string;\n}\n\n// ─── Defaults ─────────────────────────────────────────────────────────────────\n\nconst DEFAULT_THEME: Required<TypographyTheme> = {\n font: \"\",\n accentColor: \"#c8b89a\",\n italic: false,\n animation: \"rise\",\n color: \"\",\n};\n\n// ─── Context ──────────────────────────────────────────────────────────────────\n\nconst TypographyContext = createContext<Required<TypographyTheme>>(DEFAULT_THEME);\n\n// ─── Provider ─────────────────────────────────────────────────────────────────\n\nexport interface TypographyProviderProps {\n theme: TypographyTheme;\n children: React.ReactNode;\n}\n\nexport const TypographyProvider: React.FC<TypographyProviderProps> = ({\n theme,\n children,\n}) => {\n const resolved = useMemo<Required<TypographyTheme>>(\n () => ({\n font: theme.font ?? DEFAULT_THEME.font,\n accentColor: theme.accentColor ?? DEFAULT_THEME.accentColor,\n italic: theme.italic ?? DEFAULT_THEME.italic,\n animation: theme.animation ?? DEFAULT_THEME.animation,\n color: theme.color ?? DEFAULT_THEME.color,\n }),\n [theme.font, theme.accentColor, theme.italic, theme.animation, theme.color]\n );\n\n // Pre-load the theme font as soon as the provider mounts\n if (resolved.font && GOOGLE_FONTS.includes(resolved.font)) {\n injectFont(buildFontUrl(resolved.font));\n }\n\n return (\n <TypographyContext.Provider value={resolved}>\n {children}\n </TypographyContext.Provider>\n );\n};\n\n// ─── Hook ─────────────────────────────────────────────────────────────────────\n\n/**\n * Returns the resolved theme from the nearest TypographyProvider.\n * Falls back to DEFAULT_THEME if used outside a provider.\n */\nexport function useTypographyTheme(): Required<TypographyTheme> {\n return useContext(TypographyContext);\n}","import React, {\n CSSProperties,\n Children,\n isValidElement,\n useRef,\n useEffect,\n useInsertionEffect,\n} from \"react\";\nimport { TypographyProps, VariantTagMap, VariantStyleMap } from \"./types\";\nimport { GOOGLE_FONTS, buildFontUrl, injectFont } from \"./fonts\";\nimport {\n injectAnimationStyles,\n getAnimationClass,\n isSplitAnimation,\n buildSplitHTML,\n} from \"./animation\";\nimport { useTypographyTheme } from \"./Context\";\n\n// ─── Static maps ─────────────────────────────────────────────────────────────\n\nconst variantTagMap: VariantTagMap = {\n Display: \"h1\",\n H1: \"h1\",\n H2: \"h2\",\n H3: \"h3\",\n H4: \"h4\",\n H5: \"h5\",\n H6: \"h6\",\n Subheading: \"h6\",\n Overline: \"span\",\n Body: \"p\",\n Label: \"label\",\n Caption: \"span\",\n};\n\nconst variantStyleMap: VariantStyleMap = {\n Display: {\n fontSize: \"clamp(2.5rem, 6vw, 5rem)\",\n fontWeight: 800,\n lineHeight: 1.05,\n letterSpacing: \"-0.03em\",\n },\n H1: {\n fontSize: \"clamp(2rem, 4vw, 3rem)\",\n fontWeight: 700,\n lineHeight: 1.1,\n letterSpacing: \"-0.02em\",\n },\n H2: {\n fontSize: \"clamp(1.5rem, 3vw, 2.25rem)\",\n fontWeight: 700,\n lineHeight: 1.2,\n letterSpacing: \"-0.015em\",\n },\n H3: {\n fontSize: \"clamp(1.25rem, 2.5vw, 1.75rem)\",\n fontWeight: 600,\n lineHeight: 1.25,\n letterSpacing: \"-0.01em\",\n },\n H4: {\n fontSize: \"clamp(1.1rem, 2vw, 1.375rem)\",\n fontWeight: 600,\n lineHeight: 1.3,\n letterSpacing: \"-0.005em\",\n },\n H5: {\n fontSize: \"clamp(1rem, 1.5vw, 1.125rem)\",\n fontWeight: 600,\n lineHeight: 1.35,\n letterSpacing: \"0em\",\n },\n H6: {\n fontSize: \"1rem\",\n fontWeight: 600,\n lineHeight: 1.4,\n letterSpacing: \"0em\",\n },\n Subheading: {\n fontSize: \"1.125rem\",\n fontWeight: 500,\n lineHeight: 1.5,\n letterSpacing: \"0.005em\",\n },\n Overline: {\n fontSize: \"0.6875rem\",\n fontWeight: 700,\n lineHeight: 1.6,\n letterSpacing: \"0.12em\",\n textTransform: \"uppercase\" as CSSProperties[\"textTransform\"],\n },\n Body: {\n fontSize: \"1rem\",\n fontWeight: 400,\n lineHeight: 1.7,\n letterSpacing: \"0.01em\",\n },\n Label: {\n fontSize: \"0.875rem\",\n fontWeight: 500,\n lineHeight: 1.5,\n letterSpacing: \"0.02em\",\n },\n Caption: {\n fontSize: \"0.75rem\",\n fontWeight: 400,\n lineHeight: 1.6,\n letterSpacing: \"0.03em\",\n },\n};\n\n// ─── Constants ───────────────────────────────────────────────────────────────\n\nconst INSTRUMENT_SERIF_URL =\n \"https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&display=swap\";\n\n// ─── Helpers ─────────────────────────────────────────────────────────────────\n\nfunction childrenToHTML(children: React.ReactNode): string {\n return (\n Children.map(children, (child) => {\n if (typeof child === \"string\" || typeof child === \"number\") {\n return String(child);\n }\n if (isValidElement(child) && child.type === \"em\") {\n const inner =\n typeof child.props.children === \"string\" ? child.props.children : \"\";\n return `<em>${inner}</em>`;\n }\n return \"\";\n })?.join(\"\") ?? \"\"\n );\n}\n\nfunction renderChildrenWithEmStyles(\n children: React.ReactNode,\n italic: boolean,\n accentColor: string,\n headingFont?: string\n): React.ReactNode {\n const italicStyle: CSSProperties = {\n fontFamily: \"'Instrument Serif', serif\",\n fontStyle: \"italic\",\n fontWeight: 400,\n color: accentColor,\n };\n const noItalicStyle: CSSProperties = {\n fontFamily: headingFont ? `'${headingFont}', sans-serif` : \"inherit\",\n fontStyle: \"normal\",\n fontWeight: \"inherit\" as any,\n color: \"inherit\",\n };\n\n return Children.map(children, (child, i) => {\n if (isValidElement(child) && child.type === \"em\") {\n return (\n <em key={i} style={italic ? italicStyle : noItalicStyle}>\n {child.props.children}\n </em>\n );\n }\n return child;\n });\n}\n\nfunction applyEmStylesDOM(\n container: HTMLElement,\n italic: boolean,\n accentColor: string,\n headingFont?: string\n): void {\n const apply = (el: HTMLElement) => {\n if (italic) {\n el.style.fontFamily = \"'Instrument Serif', serif\";\n el.style.fontStyle = \"italic\";\n el.style.fontWeight = \"400\";\n el.style.color = accentColor;\n } else {\n el.style.fontFamily = headingFont ? `'${headingFont}', sans-serif` : \"inherit\";\n el.style.fontStyle = \"normal\";\n el.style.fontWeight = \"inherit\";\n el.style.color = \"inherit\";\n }\n };\n container.querySelectorAll<HTMLElement>(\"em\").forEach(apply);\n container.querySelectorAll<HTMLElement>(\"em > span\").forEach(apply);\n}\n\n// ─── Component ───────────────────────────────────────────────────────────────\n\nexport const Typography: React.FC<TypographyProps> = ({\n variant = \"Body\",\n font: fontProp,\n color: colorProp,\n animation: animationProp,\n italic: italicProp,\n accentColor: accentColorProp,\n align,\n className,\n style,\n children,\n as,\n truncate,\n maxLines,\n ...rest\n}) => {\n const theme = useTypographyTheme();\n const isHero = variant === \"Display\" || variant === \"H1\";\n const ref = useRef<HTMLElement>(null);\n\n // Prop wins; fall back to theme; fall back to built-in default\n const font = fontProp ?? (theme.font || undefined);\n const color = colorProp ?? (theme.color || undefined);\n const animation = isHero ? (animationProp ?? theme.animation ?? undefined) : undefined;\n const italic = italicProp ?? theme.italic;\n const accentColor = accentColorProp ?? theme.accentColor;\n\n // ── useInsertionEffect: inject <link> and <style> tags ────────────────────\n //\n // WHY useInsertionEffect instead of plain render-phase calls:\n //\n // 1. Server safety — useInsertionEffect (like all effects) is never called\n // on the server, so document.createElement / document.head never run\n // during SSR. The isBrowser guard in ssr.ts is a belt-and-suspenders\n // backup, but the effect boundary is the real guarantee.\n //\n // 2. Correctness — React 18 concurrent mode can call the render function\n // multiple times before committing. Doing DOM work in render can fire\n // those side-effects redundantly or out of order. useInsertionEffect\n // fires synchronously before the browser paints, once per commit.\n //\n // 3. No FOUC — because it fires before paint (earlier than useLayoutEffect),\n // the <style> tag is in the DOM before any text is visible, so there is\n // no flash of unstyled / wrong-font text.\n\n useInsertionEffect(() => {\n // Instrument Serif — always pre-load for hero so toggling italic is instant\n if (isHero) {\n injectFont(INSTRUMENT_SERIF_URL);\n }\n // Heading Google Font\n if (font && GOOGLE_FONTS.includes(font)) {\n injectFont(buildFontUrl(font));\n }\n // Animation keyframe stylesheet\n if (animation && isHero) {\n injectAnimationStyles();\n }\n }, [isHero, font, animation]);\n\n // ── useEffect: re-stamp inline styles on <em> after DOM updates ───────────\n useEffect(() => {\n if (!isHero || !animation || !ref.current) return;\n applyEmStylesDOM(ref.current, italic, accentColor, font);\n }, [italic, accentColor, font, animation, isHero]);\n\n const Tag = (as ?? variantTagMap[variant]) as React.ElementType;\n\n // ── Animation path: build inner HTML ─────────────────────────────────────\n\n let animClass = \"\";\n let heroHTML: string | null = null;\n\n if (animation && isHero) {\n const rawHTML = childrenToHTML(children);\n if (isSplitAnimation(animation)) {\n heroHTML = buildSplitHTML(animation, rawHTML);\n } else {\n heroHTML = rawHTML;\n animClass = getAnimationClass(animation);\n }\n }\n\n // ── Computed container styles ─────────────────────────────────────────────\n\n const computedStyle: CSSProperties = {\n ...variantStyleMap[variant],\n ...(font ? { fontFamily: `'${font}', sans-serif` } : {}),\n ...(color ? { color } : {}),\n ...(align ? { textAlign: align } : {}),\n ...(truncate\n ? { overflow: \"hidden\", textOverflow: \"ellipsis\", whiteSpace: \"nowrap\" }\n : {}),\n ...(maxLines && !truncate\n ? {\n display: \"-webkit-box\",\n WebkitLineClamp: maxLines,\n WebkitBoxOrient: \"vertical\" as CSSProperties[\"WebkitBoxOrient\"],\n overflow: \"hidden\",\n }\n : {}),\n margin: 0,\n padding: 0,\n ...style,\n };\n\n // ── Render: animation path (dangerouslySetInnerHTML) ──────────────────────\n\n if (heroHTML !== null) {\n return (\n <Tag\n key={animation}\n ref={ref}\n className={[animClass, className].filter(Boolean).join(\" \")}\n style={computedStyle}\n dangerouslySetInnerHTML={{ __html: heroHTML }}\n {...rest}\n />\n );\n }\n\n // ── Render: standard path ────────────────────────────────────────────────\n\n const processedChildren = isHero\n ? renderChildrenWithEmStyles(children, italic, accentColor, font)\n : children;\n\n return (\n <Tag\n ref={ref}\n className={className}\n style={computedStyle}\n {...rest}\n >\n {processedChildren}\n </Tag>\n );\n};\n\nexport default Typography;"],"names":["createContext","useMemo","_jsx","useContext","Children","isValidElement","useRef","useInsertionEffect","useEffect"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../node_modules/tslib/tslib.es6.js","../../fonts.ts","../../animation.ts","../../Context.tsx","../../Typography.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","/**\n * A curated list of popular Google Fonts.\n * Pass any valid Google Font name to the `font` prop — if it's in this list,\n * it will be auto-injected via a <link> tag. For unlisted fonts, add them here\n * or import them manually in your project.\n */\nexport const GOOGLE_FONTS: string[] = [\n // Serif\n \"Playfair Display\",\n \"Merriweather\",\n \"Lora\",\n \"EB Garamond\",\n \"Libre Baskerville\",\n \"Cormorant Garamond\",\n \"DM Serif Display\",\n \"Crimson Text\",\n \"Source Serif 4\",\n \"Fraunces\",\n\n // Sans-serif\n \"Inter\",\n \"Roboto\",\n \"Open Sans\",\n \"Nunito\",\n \"Poppins\",\n \"Raleway\",\n \"Outfit\",\n \"DM Sans\",\n \"Manrope\",\n \"Plus Jakarta Sans\",\n \"Figtree\",\n \"Syne\",\n \"Albert Sans\",\n\n // Display / Expressive\n \"Bebas Neue\",\n \"Oswald\",\n \"Anton\",\n \"Barlow Condensed\",\n \"Righteous\",\n \"Abril Fatface\",\n \"Dela Gothic One\",\n \"Space Grotesk\",\n \"Unbounded\",\n \"Big Shoulders Display\",\n\n // Mono\n \"JetBrains Mono\",\n \"Fira Code\",\n \"Source Code Pro\",\n \"Space Mono\",\n \"IBM Plex Mono\",\n];\n\nconst injectedFonts = new Set<string>();\n\n/**\n * Builds a Google Fonts URL for a given font family.\n * Requests weights 300, 400, 500, 600, 700, 800 — italic variants included.\n */\nexport function buildFontUrl(fontFamily: string): string {\n const encoded = fontFamily.replace(/ /g, \"+\");\n return `https://fonts.googleapis.com/css2?family=${encoded}:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,700&display=swap`;\n}\n\n/**\n * Injects a Google Fonts <link> into <head> once per unique URL.\n * Safe to call multiple times — deduped via a Set.\n */\nexport function injectFont(url: string): void {\n if (typeof document === \"undefined\") return; // SSR guard\n if (injectedFonts.has(url)) return;\n\n const link = document.createElement(\"link\");\n link.rel = \"stylesheet\";\n link.href = url;\n document.head.appendChild(link);\n injectedFonts.add(url);\n}\n\n/**\n * Pre-load a set of fonts eagerly (e.g. at app root).\n * Usage: preloadFonts([\"Playfair Display\", \"Inter\"])\n */\nexport function preloadFonts(families: string[]): void {\n families.forEach((f) => {\n if (GOOGLE_FONTS.includes(f)) {\n injectFont(buildFontUrl(f));\n } else {\n console.warn(\n `[@edwinvakayil/calligraphy] \"${f}\" is not in the bundled GOOGLE_FONTS list. ` +\n `Add it to the list or import it manually.`\n );\n }\n });\n}","import { HeroAnimation } from \"./types\";\n\nconst STYLE_ID = \"rts-hero-animations\";\n\nconst CSS = `\n/* ─── Easing tokens (reused across all keyframes) ──────────────────────────\n All durations are tuned for perceptual smoothness:\n - spring = cubic-bezier(0.16,1,0.3,1) — soft, natural overshoot\n - snap = cubic-bezier(0.77,0,0.18,1) — fast-in, crisp-out\n - bounce = cubic-bezier(0.34,1.56,0.64,1)— elastic overshoot\n - cinema = cubic-bezier(0.4,0,0.2,1) — material easing\n ──────────────────────────────────────────────────────────────────────── */\n\n/* ── Batch 1 — originals ─────────────────────────────────────────────────── */\n@keyframes rts-rise {from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}\n@keyframes rts-clip {from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0% 0 0)}}\n@keyframes rts-pop {0%{opacity:0;transform:scale(0.75)}60%{opacity:1;transform:scale(1.04)}100%{transform:scale(1)}}\n@keyframes rts-blur {from{opacity:0;filter:blur(14px);transform:scale(1.04)}to{opacity:1;filter:blur(0);transform:scale(1)}}\n@keyframes rts-flip {from{opacity:0;transform:perspective(600px) rotateX(30deg) translateY(20px)}to{opacity:1;transform:perspective(600px) rotateX(0) translateY(0)}}\n@keyframes rts-swipe {from{opacity:0;transform:translateX(60px)}to{opacity:1;transform:translateX(0)}}\n@keyframes rts-bounce {0%{opacity:0;transform:translateY(-60px)}60%{opacity:1;transform:translateY(10px)}80%{transform:translateY(-5px)}100%{transform:translateY(0)}}\n@keyframes rts-type {from{width:0}to{width:100%}}\n@keyframes rts-blink {50%{border-color:transparent}}\n@keyframes rts-word-rise {from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}\n@keyframes rts-letter-in {from{opacity:0;transform:translateX(-16px) rotate(-4deg)}to{opacity:1;transform:none}}\n\n/* ── Batch 2 — modern ────────────────────────────────────────────────────── */\n@keyframes rts-velvet {from{opacity:0;transform:translate(-12px,20px) skewX(4deg)}to{opacity:1;transform:none}}\n@keyframes rts-curtain {from{clip-path:inset(0 0 100% 0)}to{clip-path:inset(0 0 0% 0)}}\n@keyframes rts-morph {0%{opacity:0;transform:scaleY(0.3) scaleX(1.3) translateY(10px)}60%{opacity:1;transform:scaleY(1.08) scaleX(0.97)}100%{transform:none}}\n@keyframes rts-ground {from{transform:translateY(110%);opacity:0}to{transform:translateY(0);opacity:1}}\n@keyframes rts-cascade {from{opacity:0;transform:translateY(-28px) translateX(10px) rotate(8deg)}to{opacity:1;transform:none}}\n@keyframes rts-spotlight {0%{opacity:0;letter-spacing:0.3em;transform:scaleX(1.15)}100%{opacity:1;letter-spacing:-0.03em;transform:scaleX(1)}}\n@keyframes rts-ink {0%{opacity:0;transform:translateY(6px) scale(0.96)}100%{opacity:1;transform:none}}\n@keyframes rts-hinge {from{opacity:0;transform:perspective(400px) rotateY(-40deg) translateX(-20px)}to{opacity:1;transform:perspective(400px) rotateY(0) translateX(0)}}\n@keyframes rts-stretch {0%{opacity:0;transform:scaleX(0.05)}60%{transform:scaleX(1.04)}100%{opacity:1;transform:none}}\n@keyframes rts-peel {from{clip-path:inset(100% 0 0 0)}to{clip-path:inset(0% 0 0 0)}}\n@keyframes rts-fold {from{opacity:0;transform:rotateZ(-8deg) translateY(18px)}to{opacity:1;transform:none}}\n@keyframes rts-shear {from{opacity:0;transform:skewY(8deg) translateY(12px)}to{opacity:1;transform:none}}\n/* ripple — elastic scale from compressed point, outward wave delay */\n@keyframes rts-ripple-w {\n 0% {opacity:0;transform:scale(0.4) translateY(20px)}\n 55% {opacity:1;transform:scale(1.08) translateY(-3px)}\n 75% {transform:scale(0.97) translateY(1px)}\n 100%{opacity:1;transform:scale(1) translateY(0)}\n}\n/* cinch — character pinches on scaleX then snaps open with skew */\n@keyframes rts-cinch {\n 0% {opacity:0;transform:scaleX(0) skewX(20deg)}\n 50% {opacity:1;transform:scaleX(1.12) skewX(-4deg)}\n 75% {transform:scaleX(0.95) skewX(1deg)}\n 100%{opacity:1;transform:scaleX(1) skewX(0)}\n}\n/* tiltrise — words rise while untilting from a sideways lean */\n@keyframes rts-tiltrise {\n 0% {opacity:0;transform:translateY(36px) rotate(-6deg) skewX(8deg)}\n 65% {opacity:1;transform:translateY(-3px) rotate(0.5deg) skewX(-1deg)}\n 100%{opacity:1;transform:translateY(0) rotate(0) skewX(0)}\n}\n@keyframes rts-cardflip {from{opacity:0;transform:perspective(300px) rotateX(-90deg)}to{opacity:1;transform:perspective(300px) rotateX(0)}}\n@keyframes rts-conv-l {from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}\n@keyframes rts-conv-r {from{opacity:0;transform:translateX( 40px)}to{opacity:1;transform:translateX(0)}}\n@keyframes rts-splitrise-t{from{opacity:0;transform:translateY(-24px)}to{opacity:1;transform:translateY(0)}}\n@keyframes rts-splitrise-b{from{opacity:0;transform:translateY( 24px)}to{opacity:1;transform:translateY(0)}}\n\n/* ── Batch 3 — new mechanics ─────────────────────────────────────────────── */\n\n/* tectonic: words slam from alternating sides with skew — unique X+skew combo */\n@keyframes rts-tec-l{from{opacity:0;transform:translateX(-55px) skewX(-7deg)}to{opacity:1;transform:none}}\n@keyframes rts-tec-r{from{opacity:0;transform:translateX( 55px) skewX( 7deg)}to{opacity:1;transform:none}}\n\n/* stratify: each word enters from deep Z with blur — different from blur (which is whole-el) */\n@keyframes rts-strat{\n from{opacity:0;transform:perspective(900px) translateZ(-200px) rotateX(10deg);filter:blur(6px)}\n to {opacity:1;transform:perspective(900px) translateZ(0) rotateX(0); filter:blur(0)}\n}\n\n/* unfurl: line expands from center — horizontal center-clip, not edge-clip */\n@keyframes rts-unfurl{from{clip-path:inset(0 50% 0 50%)}to{clip-path:inset(0 0% 0 0%)}}\n\n/* gravityWell: chars fall from sky with precise physics micro-rotation */\n@keyframes rts-gwell{\n 0% {opacity:0;transform:translateY(-72px) scale(1.18) rotate(-3.5deg)}\n 52% {opacity:1;transform:translateY(7px) scale(0.98) rotate(0.4deg)}\n 78% {transform:translateY(-3px) scale(1.005) rotate(0)}\n 100%{opacity:1;transform:none}\n}\n\n/* orbit: words grow from dot, rotating on Z — scale+rotation combo, unique */\n@keyframes rts-orbit{\n from{opacity:0;transform:scale(0.12) rotate(-28deg)}\n 58% {opacity:1;transform:scale(1.07) rotate(2.5deg)}\n 100%{opacity:1;transform:none}\n}\n\n/* liquid: per-word squash then overshoot spring — scaleY+scaleX cross-axis */\n@keyframes rts-liquid{\n 0% {opacity:0;transform:scaleY(0.08) scaleX(1.5) translateY(28px)}\n 40% {opacity:1;transform:scaleY(1.12) scaleX(0.94) translateY(-4px)}\n 65% {transform:scaleY(0.97) scaleX(1.015)}\n 100%{opacity:1;transform:none}\n}\n\n/* noiseFade: 3 random opacity waveforms per word — signal-lock feel */\n@keyframes rts-nf0{0%{opacity:0}22%{opacity:.7}44%{opacity:.1}66%{opacity:.95}88%{opacity:.4}100%{opacity:1}}\n@keyframes rts-nf1{0%{opacity:0}18%{opacity:.8}38%{opacity:.15}58%{opacity:1}78%{opacity:.5}100%{opacity:1}}\n@keyframes rts-nf2{0%{opacity:0}28%{opacity:.3}50%{opacity:.9}70%{opacity:.05}88%{opacity:.85}100%{opacity:1}}\n\n/* slab: scaleX from-left stamp — fastest entrance, print-press energy */\n@keyframes rts-slab{\n 0% {opacity:0;transform:scaleX(0) skewX(8deg)}\n 52% {opacity:1;transform:scaleX(1.05) skewX(-1deg)}\n 100%{opacity:1;transform:none}\n}\n\n/* thread: chars ride individual sine-wave Y offsets set via CSS var */\n@keyframes rts-thread{from{opacity:0;transform:translateY(var(--ty,18px))}to{opacity:1;transform:translateY(0)}}\n\n/* billboard: whole-line rotateY — different axis from flip (rotateX) */\n@keyframes rts-billboard{\n from{opacity:0;transform:perspective(800px) rotateY(-32deg) translateX(-24px);filter:blur(3px)}\n to {opacity:1;transform:perspective(800px) rotateY(0) translateX(0); filter:blur(0)}\n}\n\n/* ═══════════════════════════════════════════════════════════════════════════\n CLASS DECLARATIONS — all animations use animation-fill-mode: both so\n the element stays at its final state without needing JS cleanup.\n ═══════════════════════════════════════════════════════════════════════════ */\n\n/* ── Batch 1 whole-element ───────────────────────────────────────────────── */\n.rts-rise {animation:rts-rise 0.9s cubic-bezier(0.16,1,0.3,1) both}\n.rts-clip {animation:rts-clip 1.1s cubic-bezier(0.77,0,0.18,1) both}\n.rts-pop {animation:rts-pop 0.7s cubic-bezier(0.34,1.56,0.64,1) both}\n.rts-blur {animation:rts-blur 1s cubic-bezier(0.16,1,0.3,1) both}\n.rts-flip {animation:rts-flip 0.9s cubic-bezier(0.16,1,0.3,1) both;transform-origin:center bottom}\n.rts-swipe {animation:rts-swipe 0.8s cubic-bezier(0.16,1,0.3,1) both}\n.rts-bounce {animation:rts-bounce 0.9s cubic-bezier(0.36,0.07,0.19,0.97) both}\n.rts-typewriter {overflow:hidden;white-space:nowrap;border-right:2px solid currentColor;width:0;animation:rts-type 1.6s steps(22,end) both,rts-blink 0.7s step-end 1.6s 3}\n\n/* ── Batch 2 whole-element ───────────────────────────────────────────────── */\n.rts-morph {animation:rts-morph 0.8s cubic-bezier(0.34,1.56,0.64,1) both}\n.rts-spotlight {animation:rts-spotlight 1s cubic-bezier(0.16,1,0.3,1) both}\n.rts-stretch {animation:rts-stretch 0.9s cubic-bezier(0.34,1.56,0.64,1) both}\n\n/* ── Batch 3 whole-element ───────────────────────────────────────────────── */\n.rts-unfurl {animation:rts-unfurl 0.95s cubic-bezier(0.77,0,0.18,1) both}\n.rts-billboard {animation:rts-billboard 0.95s cubic-bezier(0.16,1,0.3,1) both;transform-origin:left center}\n\n/* ── Per-word / per-char spans (batch 1+2) ───────────────────────────────── */\n.rts-word {display:inline-block;opacity:0;transform:translateY(24px);animation:rts-word-rise 0.7s cubic-bezier(0.16,1,0.3,1) both}\n.rts-letter {display:inline-block;opacity:0;transform:translateX(-16px) rotate(-4deg);animation:rts-letter-in 0.5s cubic-bezier(0.16,1,0.3,1) both}\n.rts-velvet-word {display:inline-block;opacity:0;animation:rts-velvet 0.65s cubic-bezier(0.16,1,0.3,1) both}\n.rts-curtain-word {display:inline-block;overflow:hidden;animation:rts-curtain 0.7s cubic-bezier(0.77,0,0.18,1) both}\n.rts-ground-wrap {display:inline-block;overflow:hidden;vertical-align:bottom}\n.rts-ground-inner {display:inline-block;animation:rts-ground 0.65s cubic-bezier(0.16,1,0.3,1) both}\n.rts-cascade-ch {display:inline-block;opacity:0;animation:rts-cascade 0.45s cubic-bezier(0.34,1.56,0.64,1) both}\n.rts-ink-word {display:inline-block;opacity:0;animation:rts-ink 0.9s cubic-bezier(0.16,1,0.3,1) both}\n.rts-hinge-word {display:inline-block;opacity:0;transform-origin:left center;animation:rts-hinge 0.6s cubic-bezier(0.16,1,0.3,1) both}\n.rts-peel-word {display:inline-block;overflow:hidden;animation:rts-peel 0.6s cubic-bezier(0.77,0,0.18,1) both}\n.rts-fold-word {display:inline-block;opacity:0;transform-origin:center bottom;animation:rts-fold 0.6s cubic-bezier(0.34,1.4,0.64,1) both}\n.rts-shear-word {display:inline-block;opacity:0;animation:rts-shear 0.65s cubic-bezier(0.16,1,0.3,1) both}\n.rts-ripple-word {display:inline-block;opacity:0;animation:rts-ripple-w 0.75s cubic-bezier(0.34,1.4,0.64,1) both}\n.rts-cinch-ch {display:inline-block;opacity:0;transform-origin:center;animation:rts-cinch 0.55s cubic-bezier(0.34,1.2,0.64,1) both}\n.rts-tiltrise-word{display:inline-block;opacity:0;animation:rts-tiltrise 0.8s cubic-bezier(0.16,1,0.3,1) both}\n.rts-cardflip-ch {display:inline-block;opacity:0;transform-origin:center bottom;animation:rts-cardflip 0.4s cubic-bezier(0.34,1.4,0.64,1) both}\n.rts-conv-l {display:inline-block;opacity:0;animation:rts-conv-l 0.7s cubic-bezier(0.16,1,0.3,1) both}\n.rts-conv-r {display:inline-block;opacity:0;animation:rts-conv-r 0.7s cubic-bezier(0.16,1,0.3,1) both}\n.rts-splitrise-t {display:inline-block;opacity:0;animation:rts-splitrise-t 0.65s cubic-bezier(0.16,1,0.3,1) both}\n.rts-splitrise-b {display:inline-block;opacity:0;animation:rts-splitrise-b 0.65s cubic-bezier(0.16,1,0.3,1) both}\n\n/* ── Per-word / per-char spans (batch 3) ────────────────────────────────── */\n.rts-tec-l {display:inline-block;opacity:0;animation:rts-tec-l 0.65s cubic-bezier(0.16,1,0.3,1) both}\n.rts-tec-r {display:inline-block;opacity:0;animation:rts-tec-r 0.65s cubic-bezier(0.16,1,0.3,1) both}\n.rts-strat-word {display:inline-block;opacity:0;animation:rts-strat 0.85s cubic-bezier(0.16,1,0.3,1) both}\n.rts-gwell-ch {display:inline-block;opacity:0;animation:rts-gwell 0.62s cubic-bezier(0.36,0.07,0.19,0.97) both}\n.rts-orbit-word {display:inline-block;opacity:0;transform-origin:center;animation:rts-orbit 0.65s cubic-bezier(0.34,1.4,0.64,1) both}\n.rts-liquid-word{display:inline-block;opacity:0;transform-origin:center bottom;animation:rts-liquid 0.72s cubic-bezier(0.34,1.56,0.64,1) both}\n.rts-nf0 {display:inline-block;opacity:0;animation:rts-nf0 0.9s ease both}\n.rts-nf1 {display:inline-block;opacity:0;animation:rts-nf1 0.9s ease both}\n.rts-nf2 {display:inline-block;opacity:0;animation:rts-nf2 0.9s ease both}\n.rts-slab-word {display:inline-block;opacity:0;transform-origin:left center;animation:rts-slab 0.5s cubic-bezier(0.77,0,0.18,1) both}\n.rts-thread-ch {display:inline-block;opacity:0;animation:rts-thread 0.55s cubic-bezier(0.16,1,0.3,1) both}\n\n/* ── Batch 7 — 8 genuinely new mechanics ────────────────────────────────── */\n\n/* glassReveal — backdrop-filter blur evaporates as text solidifies */\n@keyframes rts-glass {\n 0% { opacity:0; filter:blur(0px); backdrop-filter:blur(20px); transform:scale(1.03) }\n 35% { opacity:0.6; filter:blur(2px) }\n 100%{ opacity:1; filter:blur(0px); backdrop-filter:blur(0px); transform:scale(1) }\n}\n.rts-glass { animation:rts-glass 1.2s cubic-bezier(0.16,1,0.3,1) both }\n\n/* wordPop — per-word springs from 0 at its own center, pure scale */\n@keyframes rts-wpop {\n 0% { opacity:0; transform:scale(0) }\n 55% { opacity:1; transform:scale(1.08) }\n 75% { transform:scale(0.97) }\n 100%{ transform:scale(1) }\n}\n.rts-wpop-word { display:inline-block; opacity:0; animation:rts-wpop 0.55s cubic-bezier(0.34,1.56,0.64,1) both }\n\n/* charDrop — pure gravity fall, no overshoot, no rotation */\n@keyframes rts-cdrop {\n 0% { opacity:0; transform:translateY(-48px) }\n 100%{ opacity:1; transform:translateY(0) }\n}\n.rts-cdrop-ch { display:inline-block; opacity:0; animation:rts-cdrop 0.6s cubic-bezier(0.55,0,1,0.45) both }\n\n/* scanline — single-pixel horizontal clip expands to full height */\n@keyframes rts-scan {\n 0% { clip-path:inset(49% 0 49% 0); opacity:0 }\n 15% { opacity:1 }\n 100%{ clip-path:inset(0% 0 0% 0) }\n}\n.rts-scan { animation:rts-scan 0.9s cubic-bezier(0.77,0,0.18,1) both }\n\n/* chromaShift — RGB channel offsets collapse to zero */\n@keyframes rts-chroma {\n 0% { opacity:0; text-shadow: -8px 0 0 rgba(255,0,80,0.7), 8px 0 0 rgba(0,200,255,0.7) }\n 40% { opacity:1; text-shadow: -4px 0 0 rgba(255,0,80,0.35), 4px 0 0 rgba(0,200,255,0.35) }\n 100%{ text-shadow:none }\n}\n.rts-chroma { animation:rts-chroma 1s cubic-bezier(0.16,1,0.3,1) both }\n\n/* wordFade — pure cross-dissolve with warmth scale, no Y movement */\n@keyframes rts-wfade {\n 0% { opacity:0; transform:scale(0.97) }\n 100%{ opacity:1; transform:scale(1) }\n}\n.rts-wfade-word { display:inline-block; opacity:0; animation:rts-wfade 0.9s cubic-bezier(0.4,0,0.2,1) both }\n\n/* rotateIn — full Y-axis card flip per word */\n@keyframes rts-rotatein {\n 0% { opacity:0; transform:perspective(500px) rotateY(90deg) }\n 55% { opacity:1; transform:perspective(500px) rotateY(-8deg) }\n 100%{ transform:perspective(500px) rotateY(0deg) }\n}\n.rts-rotatein-word { display:inline-block; opacity:0; transform-origin:center; animation:rts-rotatein 0.6s cubic-bezier(0.34,1.4,0.64,1) both }\n\n/* pressIn — presses down to 0.92 then springs outward past 1 */\n@keyframes rts-pressin {\n 0% { opacity:0; transform:scale(0.5) }\n 30% { opacity:1; transform:scale(0.92) }\n 60% { transform:scale(1.06) }\n 80% { transform:scale(0.98) }\n 100%{ transform:scale(1) }\n}\n.rts-pressin-word { display:inline-block; opacity:0; animation:rts-pressin 0.65s cubic-bezier(0.34,1.56,0.64,1) both }\n`;\n\nexport function injectAnimationStyles(): void {\n if (typeof document === \"undefined\") return;\n if (document.getElementById(STYLE_ID)) return;\n const style = document.createElement(\"style\");\n style.id = STYLE_ID;\n style.textContent = CSS;\n document.head.appendChild(style);\n}\n\n// ─── Whole-element animation map ─────────────────────────────────────────────\n\nconst WHOLE_CLASS_MAP: Partial<Record<HeroAnimation, string>> = {\n rise: \"rts-rise\",\n clip: \"rts-clip\",\n pop: \"rts-pop\",\n blur: \"rts-blur\",\n flip: \"rts-flip\",\n swipe: \"rts-swipe\",\n bounce: \"rts-bounce\",\n typewriter: \"rts-typewriter\",\n morph: \"rts-morph\",\n spotlight: \"rts-spotlight\",\n stretch: \"rts-stretch\",\n unfurl: \"rts-unfurl\",\n billboard: \"rts-billboard\",\n // Batch 7 — whole-element\n glassReveal:\"rts-glass\",\n scanline: \"rts-scan\",\n chromaShift:\"rts-chroma\",\n};\n\nexport function getAnimationClass(animation: HeroAnimation): string {\n return WHOLE_CLASS_MAP[animation] ?? \"\";\n}\n\nexport function isSplitAnimation(animation: HeroAnimation): boolean {\n return !(animation in WHOLE_CLASS_MAP);\n}\n\n// ─── HTML split builders ──────────────────────────────────────────────────────\n\nfunction wrapWords(html: string, cls: string, step: number): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n return tokens.map((tok, i) => {\n const delay = (i * step).toFixed(2);\n if (tok.startsWith(\"<em>\")) {\n return `<em><span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok.slice(4, -5)}</span></em>`;\n }\n return `<span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok}</span>`;\n }).join(\" \");\n}\n\nfunction wrapChars(html: string, cls: string, step: number): string {\n const result: string[] = [];\n let inEm = false, delay = 0, i = 0;\n while (i < html.length) {\n if (html.startsWith(\"<em>\", i)) { inEm = true; i += 4; continue; }\n if (html.startsWith(\"</em>\", i)) { inEm = false; i += 5; continue; }\n const ch = html[i];\n if (ch === \" \") { result.push(\" \"); i++; continue; }\n const span = `<span class=\"${cls}\" style=\"animation-delay:${delay.toFixed(2)}s\">${ch}</span>`;\n result.push(inEm ? `<em>${span}</em>` : span);\n delay += step;\n i++;\n }\n return result.join(\"\");\n}\n\nfunction wrapGround(html: string, step: number): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n return tokens.map((tok, i) => {\n const delay = (i * step).toFixed(2);\n const inner = tok.startsWith(\"<em>\") ? `<em>${tok.slice(4, -5)}</em>` : tok;\n return `<span class=\"rts-ground-wrap\"><span class=\"rts-ground-inner\" style=\"animation-delay:${delay}s\">${inner}</span></span>`;\n }).join(\" \");\n}\n\nfunction wrapTectonic(html: string): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n return tokens.map((tok, i) => {\n const cls = i % 2 === 0 ? \"rts-tec-l\" : \"rts-tec-r\";\n const delay = (i * 0.09).toFixed(2);\n if (tok.startsWith(\"<em>\")) {\n return `<em><span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok.slice(4, -5)}</span></em>`;\n }\n return `<span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok}</span>`;\n }).join(\" \");\n}\n\nfunction wrapNoiseFade(html: string): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n return tokens.map((tok, i) => {\n const cls = `rts-nf${i % 3}`;\n const delay = (i * 0.12).toFixed(2);\n if (tok.startsWith(\"<em>\")) {\n return `<em><span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok.slice(4, -5)}</span></em>`;\n }\n return `<span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok}</span>`;\n }).join(\" \");\n}\n\nfunction wrapConverge(html: string): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n const mid = Math.ceil(tokens.length / 2);\n return tokens.map((tok, i) => {\n const isLeft = i < mid;\n const dist = isLeft ? mid - 1 - i : i - mid;\n const delay = (dist * 0.07).toFixed(2);\n const cls = isLeft ? \"rts-conv-l\" : \"rts-conv-r\";\n const inner = tok.startsWith(\"<em>\") ? `<em>${tok.slice(4, -5)}</em>` : tok;\n return `<span class=\"${cls}\" style=\"animation-delay:${delay}s\">${inner}</span>`;\n }).join(\" \");\n}\n\nfunction wrapRipple(html: string): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n const mid = Math.floor(tokens.length / 2);\n return tokens.map((tok, i) => {\n const delay = (Math.abs(i - mid) * 0.1).toFixed(2);\n if (tok.startsWith(\"<em>\")) {\n return `<em><span class=\"rts-ripple-word\" style=\"animation-delay:${delay}s\">${tok.slice(4, -5)}</span></em>`;\n }\n return `<span class=\"rts-ripple-word\" style=\"animation-delay:${delay}s\">${tok}</span>`;\n }).join(\" \");\n}\n\nfunction wrapSplitRise(html: string): string {\n const tokens = html.match(/(<em>[\\s\\S]*?<\\/em>|[^\\s]+)/g) ?? [];\n return tokens.map((tok, i) => {\n const cls = i % 2 === 0 ? \"rts-splitrise-t\" : \"rts-splitrise-b\";\n const delay = (i * 0.08).toFixed(2);\n if (tok.startsWith(\"<em>\")) {\n return `<em><span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok.slice(4, -5)}</span></em>`;\n }\n return `<span class=\"${cls}\" style=\"animation-delay:${delay}s\">${tok}</span>`;\n }).join(\" \");\n}\n\n/**\n * Thread: each char gets a sine-wave Y offset injected as a CSS custom\n * property --ty so the keyframe can read it. Must be post-processed by\n * Typography after innerHTML is set — see applyThreadOffsets().\n */\nfunction wrapThread(html: string): string {\n return wrapChars(html, \"rts-thread-ch\", 0.04);\n}\n\n/**\n * Called by Typography after dangerouslySetInnerHTML for \"thread\" animation.\n * Stamps the sine-wave Y offset as --ty on each character span.\n */\nexport function applyThreadOffsets(container: HTMLElement): void {\n const spans = container.querySelectorAll<HTMLElement>(\".rts-thread-ch\");\n spans.forEach((el, i) => {\n const offset = Math.sin(i * 0.85) * 22;\n el.style.setProperty(\"--ty\", `${offset.toFixed(1)}px`);\n });\n}\n\n// ─── Public API ───────────────────────────────────────────────────────────────\n\nexport function buildSplitHTML(animation: HeroAnimation, html: string): string {\n switch (animation) {\n // Batch 1\n case \"stagger\": return wrapWords(html, \"rts-word\", 0.07);\n case \"letters\": return wrapChars(html, \"rts-letter\", 0.04);\n // Batch 2\n case \"velvet\": return wrapWords(html, \"rts-velvet-word\", 0.08);\n case \"curtain\": return wrapWords(html, \"rts-curtain-word\", 0.10);\n case \"ground\": return wrapGround(html, 0.09);\n case \"cascade\": return wrapChars(html, \"rts-cascade-ch\", 0.05);\n case \"ink\": return wrapWords(html, \"rts-ink-word\", 0.10);\n case \"hinge\": return wrapWords(html, \"rts-hinge-word\", 0.09);\n case \"peel\": return wrapWords(html, \"rts-peel-word\", 0.10);\n case \"fold\": return wrapWords(html, \"rts-fold-word\", 0.09);\n case \"shear\": return wrapWords(html, \"rts-shear-word\", 0.08);\n case \"ripple\": return wrapRipple(html);\n case \"cinch\": return wrapChars(html, \"rts-cinch-ch\", 0.048);\n case \"tiltrise\": return wrapWords(html, \"rts-tiltrise-word\", 0.09);\n case \"cardFlip\": return wrapChars(html, \"rts-cardflip-ch\", 0.045);\n case \"converge\": return wrapConverge(html);\n case \"splitRise\": return wrapSplitRise(html);\n // Batch 3\n case \"tectonic\": return wrapTectonic(html);\n case \"stratify\": return wrapWords(html, \"rts-strat-word\", 0.10);\n case \"gravityWell\":return wrapChars(html, \"rts-gwell-ch\", 0.05);\n case \"orbit\": return wrapWords(html, \"rts-orbit-word\", 0.10);\n case \"liquid\": return wrapWords(html, \"rts-liquid-word\", 0.09);\n case \"noiseFade\": return wrapNoiseFade(html);\n case \"slab\": return wrapWords(html, \"rts-slab-word\", 0.11);\n case \"thread\": return wrapThread(html);\n // Batch 7 — split\n case \"wordPop\": return wrapWords(html, \"rts-wpop-word\", 0.07);\n case \"charDrop\": return wrapChars(html, \"rts-cdrop-ch\", 0.04);\n case \"wordFade\": return wrapWords(html, \"rts-wfade-word\", 0.09);\n case \"rotateIn\": return wrapWords(html, \"rts-rotatein-word\", 0.08);\n case \"pressIn\": return wrapWords(html, \"rts-pressin-word\", 0.08);\n default: return html;\n }\n}\n\n// Legacy exports — backwards compat\nexport const buildStaggerHTML = (html: string) => buildSplitHTML(\"stagger\", html);\nexport const buildLettersHTML = (html: string) => buildSplitHTML(\"letters\", html);","import React, { createContext, useContext, useMemo } from \"react\";\nimport { HeroAnimation } from \"./types\";\nimport { injectFont, buildFontUrl, GOOGLE_FONTS } from \"./fonts\";\n\n// ─── Theme shape ──────────────────────────────────────────────────────────────\n\nexport interface TypographyTheme {\n /** Default Google Font for all Typography components */\n font?: string;\n\n /** Default accent color for <em> italic spans in Display / H1 */\n accentColor?: string;\n\n /** Default italic setting for Display / H1 heroes */\n italic?: boolean;\n\n /** Default entrance animation for Display / H1 heroes */\n animation?: HeroAnimation;\n\n /** Default text color applied to all variants */\n color?: string;\n}\n\n// ─── Defaults ─────────────────────────────────────────────────────────────────\n\nconst DEFAULT_THEME: Required<TypographyTheme> = {\n font: \"\",\n accentColor: \"#c8b89a\",\n italic: false,\n animation: \"rise\",\n color: \"\",\n};\n\n// ─── Context ──────────────────────────────────────────────────────────────────\n\nconst TypographyContext = createContext<Required<TypographyTheme>>(DEFAULT_THEME);\n\n// ─── Provider ─────────────────────────────────────────────────────────────────\n\nexport interface TypographyProviderProps {\n theme: TypographyTheme;\n children: React.ReactNode;\n}\n\nexport const TypographyProvider: React.FC<TypographyProviderProps> = ({\n theme,\n children,\n}) => {\n const resolved = useMemo<Required<TypographyTheme>>(\n () => ({\n font: theme.font ?? DEFAULT_THEME.font,\n accentColor: theme.accentColor ?? DEFAULT_THEME.accentColor,\n italic: theme.italic ?? DEFAULT_THEME.italic,\n animation: theme.animation ?? DEFAULT_THEME.animation,\n color: theme.color ?? DEFAULT_THEME.color,\n }),\n [theme.font, theme.accentColor, theme.italic, theme.animation, theme.color]\n );\n\n // Pre-load the theme font as soon as the provider mounts\n if (resolved.font && GOOGLE_FONTS.includes(resolved.font)) {\n injectFont(buildFontUrl(resolved.font));\n }\n\n return (\n <TypographyContext.Provider value={resolved}>\n {children}\n </TypographyContext.Provider>\n );\n};\n\n// ─── Hook ─────────────────────────────────────────────────────────────────────\n\n/**\n * Returns the resolved theme from the nearest TypographyProvider.\n * Falls back to DEFAULT_THEME if used outside a provider.\n */\nexport function useTypographyTheme(): Required<TypographyTheme> {\n return useContext(TypographyContext);\n}","import React, {\n CSSProperties,\n Children,\n isValidElement,\n useRef,\n useEffect,\n useInsertionEffect,\n} from \"react\";\nimport { TypographyProps, VariantTagMap, VariantStyleMap } from \"./types\";\nimport { GOOGLE_FONTS, buildFontUrl, injectFont } from \"./fonts\";\nimport {\n injectAnimationStyles,\n getAnimationClass,\n isSplitAnimation,\n buildSplitHTML,\n} from \"./animation\";\nimport { useTypographyTheme } from \"./Context\";\n\n// ─── Static maps ─────────────────────────────────────────────────────────────\n\nconst variantTagMap: VariantTagMap = {\n Display: \"h1\",\n H1: \"h1\",\n H2: \"h2\",\n H3: \"h3\",\n H4: \"h4\",\n H5: \"h5\",\n H6: \"h6\",\n Subheading: \"h6\",\n Overline: \"span\",\n Body: \"p\",\n Label: \"label\",\n Caption: \"span\",\n};\n\nconst variantStyleMap: VariantStyleMap = {\n Display: {\n fontSize: \"clamp(2.5rem, 6vw, 5rem)\",\n fontWeight: 800,\n lineHeight: 1.05,\n letterSpacing: \"-0.03em\",\n },\n H1: {\n fontSize: \"clamp(2rem, 4vw, 3rem)\",\n fontWeight: 700,\n lineHeight: 1.1,\n letterSpacing: \"-0.02em\",\n },\n H2: {\n fontSize: \"clamp(1.5rem, 3vw, 2.25rem)\",\n fontWeight: 700,\n lineHeight: 1.2,\n letterSpacing: \"-0.015em\",\n },\n H3: {\n fontSize: \"clamp(1.25rem, 2.5vw, 1.75rem)\",\n fontWeight: 600,\n lineHeight: 1.25,\n letterSpacing: \"-0.01em\",\n },\n H4: {\n fontSize: \"clamp(1.1rem, 2vw, 1.375rem)\",\n fontWeight: 600,\n lineHeight: 1.3,\n letterSpacing: \"-0.005em\",\n },\n H5: {\n fontSize: \"clamp(1rem, 1.5vw, 1.125rem)\",\n fontWeight: 600,\n lineHeight: 1.35,\n letterSpacing: \"0em\",\n },\n H6: {\n fontSize: \"1rem\",\n fontWeight: 600,\n lineHeight: 1.4,\n letterSpacing: \"0em\",\n },\n Subheading: {\n fontSize: \"1.125rem\",\n fontWeight: 500,\n lineHeight: 1.5,\n letterSpacing: \"0.005em\",\n },\n Overline: {\n fontSize: \"0.6875rem\",\n fontWeight: 700,\n lineHeight: 1.6,\n letterSpacing: \"0.12em\",\n textTransform: \"uppercase\" as CSSProperties[\"textTransform\"],\n },\n Body: {\n fontSize: \"1rem\",\n fontWeight: 400,\n lineHeight: 1.7,\n letterSpacing: \"0.01em\",\n },\n Label: {\n fontSize: \"0.875rem\",\n fontWeight: 500,\n lineHeight: 1.5,\n letterSpacing: \"0.02em\",\n },\n Caption: {\n fontSize: \"0.75rem\",\n fontWeight: 400,\n lineHeight: 1.6,\n letterSpacing: \"0.03em\",\n },\n};\n\n// ─── Constants ───────────────────────────────────────────────────────────────\n\nconst INSTRUMENT_SERIF_URL =\n \"https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&display=swap\";\n\n// ─── Helpers ─────────────────────────────────────────────────────────────────\n\nfunction childrenToHTML(children: React.ReactNode): string {\n return (\n Children.map(children, (child) => {\n if (typeof child === \"string\" || typeof child === \"number\") {\n return String(child);\n }\n if (isValidElement(child) && child.type === \"em\") {\n const inner =\n typeof child.props.children === \"string\" ? child.props.children : \"\";\n return `<em>${inner}</em>`;\n }\n return \"\";\n })?.join(\"\") ?? \"\"\n );\n}\n\nfunction renderChildrenWithEmStyles(\n children: React.ReactNode,\n italic: boolean,\n accentColor: string,\n headingFont?: string\n): React.ReactNode {\n const italicStyle: CSSProperties = {\n fontFamily: \"'Instrument Serif', serif\",\n fontStyle: \"italic\",\n fontWeight: 400,\n color: accentColor,\n };\n const noItalicStyle: CSSProperties = {\n fontFamily: headingFont ? `'${headingFont}', sans-serif` : \"inherit\",\n fontStyle: \"normal\",\n fontWeight: \"inherit\" as any,\n color: \"inherit\",\n };\n\n return Children.map(children, (child, i) => {\n if (isValidElement(child) && child.type === \"em\") {\n return (\n <em key={i} style={italic ? italicStyle : noItalicStyle}>\n {child.props.children}\n </em>\n );\n }\n return child;\n });\n}\n\nfunction applyEmStylesDOM(\n container: HTMLElement,\n italic: boolean,\n accentColor: string,\n headingFont?: string\n): void {\n const apply = (el: HTMLElement) => {\n if (italic) {\n el.style.fontFamily = \"'Instrument Serif', serif\";\n el.style.fontStyle = \"italic\";\n el.style.fontWeight = \"400\";\n el.style.color = accentColor;\n } else {\n el.style.fontFamily = headingFont ? `'${headingFont}', sans-serif` : \"inherit\";\n el.style.fontStyle = \"normal\";\n el.style.fontWeight = \"inherit\";\n el.style.color = \"inherit\";\n }\n };\n container.querySelectorAll<HTMLElement>(\"em\").forEach(apply);\n container.querySelectorAll<HTMLElement>(\"em > span\").forEach(apply);\n}\n\n// ─── Component ───────────────────────────────────────────────────────────────\n\nexport const Typography: React.FC<TypographyProps> = ({\n variant = \"Body\",\n font: fontProp,\n color: colorProp,\n animation: animationProp,\n italic: italicProp,\n accentColor: accentColorProp,\n align,\n className,\n style,\n children,\n as,\n truncate,\n maxLines,\n ...rest\n}) => {\n const theme = useTypographyTheme();\n const isHero = variant === \"Display\" || variant === \"H1\";\n const ref = useRef<HTMLElement>(null);\n\n // Prop wins; fall back to theme; fall back to built-in default\n const font = fontProp ?? (theme.font || undefined);\n const color = colorProp ?? (theme.color || undefined);\n const animation = isHero ? (animationProp ?? theme.animation ?? undefined) : undefined;\n const italic = italicProp ?? theme.italic;\n const accentColor = accentColorProp ?? theme.accentColor;\n\n // ── useInsertionEffect: inject <link> and <style> tags ────────────────────\n //\n // WHY useInsertionEffect instead of plain render-phase calls:\n //\n // 1. Server safety — useInsertionEffect (like all effects) is never called\n // on the server, so document.createElement / document.head never run\n // during SSR. The isBrowser guard in ssr.ts is a belt-and-suspenders\n // backup, but the effect boundary is the real guarantee.\n //\n // 2. Correctness — React 18 concurrent mode can call the render function\n // multiple times before committing. Doing DOM work in render can fire\n // those side-effects redundantly or out of order. useInsertionEffect\n // fires synchronously before the browser paints, once per commit.\n //\n // 3. No FOUC — because it fires before paint (earlier than useLayoutEffect),\n // the <style> tag is in the DOM before any text is visible, so there is\n // no flash of unstyled / wrong-font text.\n\n useInsertionEffect(() => {\n // Instrument Serif — always pre-load for hero so toggling italic is instant\n if (isHero) {\n injectFont(INSTRUMENT_SERIF_URL);\n }\n // Heading Google Font\n if (font && GOOGLE_FONTS.includes(font)) {\n injectFont(buildFontUrl(font));\n }\n // Animation keyframe stylesheet\n if (animation && isHero) {\n injectAnimationStyles();\n }\n }, [isHero, font, animation]);\n\n // ── useEffect: re-stamp inline styles on <em> after DOM updates ───────────\n useEffect(() => {\n if (!isHero || !animation || !ref.current) return;\n applyEmStylesDOM(ref.current, italic, accentColor, font);\n }, [italic, accentColor, font, animation, isHero]);\n\n const Tag = (as ?? variantTagMap[variant]) as React.ElementType;\n\n // ── Animation path: build inner HTML ─────────────────────────────────────\n\n let animClass = \"\";\n let heroHTML: string | null = null;\n\n if (animation && isHero) {\n const rawHTML = childrenToHTML(children);\n if (isSplitAnimation(animation)) {\n heroHTML = buildSplitHTML(animation, rawHTML);\n } else {\n heroHTML = rawHTML;\n animClass = getAnimationClass(animation);\n }\n }\n\n // ── Computed container styles ─────────────────────────────────────────────\n\n const computedStyle: CSSProperties = {\n ...variantStyleMap[variant],\n ...(font ? { fontFamily: `'${font}', sans-serif` } : {}),\n ...(color ? { color } : {}),\n ...(align ? { textAlign: align } : {}),\n ...(truncate\n ? { overflow: \"hidden\", textOverflow: \"ellipsis\", whiteSpace: \"nowrap\" }\n : {}),\n ...(maxLines && !truncate\n ? {\n display: \"-webkit-box\",\n WebkitLineClamp: maxLines,\n WebkitBoxOrient: \"vertical\" as CSSProperties[\"WebkitBoxOrient\"],\n overflow: \"hidden\",\n }\n : {}),\n margin: 0,\n padding: 0,\n ...style,\n };\n\n // ── Render: animation path (dangerouslySetInnerHTML) ──────────────────────\n\n if (heroHTML !== null) {\n return (\n <Tag\n key={animation}\n ref={ref}\n className={[animClass, className].filter(Boolean).join(\" \")}\n style={computedStyle}\n dangerouslySetInnerHTML={{ __html: heroHTML }}\n {...rest}\n />\n );\n }\n\n // ── Render: standard path ────────────────────────────────────────────────\n\n const processedChildren = isHero\n ? renderChildrenWithEmStyles(children, italic, accentColor, font)\n : children;\n\n return (\n <Tag\n ref={ref}\n className={className}\n style={computedStyle}\n {...rest}\n >\n {processedChildren}\n </Tag>\n );\n};\n\nexport default Typography;"],"names":["createContext","useMemo","_jsx","useContext","Children","isValidElement","useRef","useInsertionEffect","useEffect"],"mappings":"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","x_google_ignoreList":[0]}
|
package/dist/types.d.ts
CHANGED
|
@@ -2,38 +2,67 @@ import { CSSProperties, ElementType, HTMLAttributes } from "react";
|
|
|
2
2
|
export type TypographyVariant = "Display" | "H1" | "H2" | "H3" | "H4" | "H5" | "H6" | "Subheading" | "Overline" | "Body" | "Label" | "Caption";
|
|
3
3
|
export type TextAlign = "left" | "center" | "right" | "justify";
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
6
|
-
* Applied via CSS keyframes — GPU-composited, 60fps safe.
|
|
5
|
+
* Hero entrance animations — all GPU-composited (transform + opacity + filter only).
|
|
7
6
|
*
|
|
8
|
-
* —
|
|
9
|
-
* rise
|
|
10
|
-
* stagger
|
|
11
|
-
* clip
|
|
12
|
-
* pop
|
|
13
|
-
* letters
|
|
14
|
-
* blur
|
|
15
|
-
* flip
|
|
16
|
-
* swipe
|
|
17
|
-
* typewriter
|
|
18
|
-
* bounce
|
|
7
|
+
* ── Batch 1 — originals ──────────────────────────────────────────────────
|
|
8
|
+
* rise smooth upward fade (universal)
|
|
9
|
+
* stagger per-word upward rise in sequence
|
|
10
|
+
* clip text unmasked left to right
|
|
11
|
+
* pop spring scale-in
|
|
12
|
+
* letters each letter slides in with rotation
|
|
13
|
+
* blur emerges from blur
|
|
14
|
+
* flip 3-D rotateX on entry
|
|
15
|
+
* swipe slides in from the right
|
|
16
|
+
* typewriter character-by-character reveal
|
|
17
|
+
* bounce drops from above with bounce
|
|
19
18
|
*
|
|
20
|
-
* —
|
|
21
|
-
* velvet
|
|
22
|
-
* curtain
|
|
23
|
-
* morph
|
|
24
|
-
* ground
|
|
25
|
-
* cascade
|
|
26
|
-
* spotlight
|
|
27
|
-
* ink
|
|
28
|
-
* hinge
|
|
29
|
-
* stretch
|
|
30
|
-
* peel
|
|
19
|
+
* ── Batch 2 — modern ─────────────────────────────────────────────────────
|
|
20
|
+
* velvet words drift in with skew
|
|
21
|
+
* curtain each word clips upward
|
|
22
|
+
* morph squash-and-stretch spring
|
|
23
|
+
* ground words emerge from baseline
|
|
24
|
+
* cascade diagonal character waterfall
|
|
25
|
+
* spotlight expands from compressed letterspace
|
|
26
|
+
* ink words fade in with gentle scale
|
|
27
|
+
* hinge words rotate from left edge
|
|
28
|
+
* stretch horizontal rubber-band expand
|
|
29
|
+
* peel bottom-to-top clip per word
|
|
30
|
+
* fold words rotate in on Z from a folded angle
|
|
31
|
+
* shear words skewY then settle
|
|
32
|
+
* ripple words scale from compressed point, elastic outward wave
|
|
33
|
+
* cinch chars pinch on scaleX then snap open with skew
|
|
34
|
+
* tiltrise words rise while untilting from a sideways lean
|
|
35
|
+
* cardFlip chars flip up on X from flat
|
|
36
|
+
* converge outer words fly in, meet in center
|
|
37
|
+
* splitRise alternating words from top/bottom
|
|
38
|
+
*
|
|
39
|
+
* ── Batch 3 — new untouched techniques ───────────────────────────────────
|
|
40
|
+
* tectonic words slam from alternating X sides with skew — collision energy
|
|
41
|
+
* stratify per-word Z-depth flight through blur — true depth-of-field
|
|
42
|
+
* unfurl line expands from horizontal center — origami opening
|
|
43
|
+
* gravityWell chars fall from sky with micro-rotation physics overshoot
|
|
44
|
+
* orbit words grow from dot while rotating on Z-axis
|
|
45
|
+
* liquid per-word cross-axis squash then spring — fluid inertia
|
|
46
|
+
* noiseFade 3 random opacity waveforms per word — signal locking in
|
|
47
|
+
* slab words stamp from left with scaleX — print-press energy
|
|
48
|
+
* thread chars float on individual sine-wave Y offsets — musical
|
|
49
|
+
* billboard whole line rotates in on Y-axis — turning sign
|
|
50
|
+
*
|
|
51
|
+
* ── Batch 7 — genuinely new mechanics ────────────────────────────────────
|
|
52
|
+
* glassReveal backdrop-filter blur evaporates as text solidifies
|
|
53
|
+
* wordPop per-word springs from zero scale at its own centre
|
|
54
|
+
* charDrop chars fall under pure gravity — no overshoot or rotation
|
|
55
|
+
* scanline single-pixel horizontal slice expands to full height
|
|
56
|
+
* chromaShift RGB channel offsets collapse to zero (printing-register feel)
|
|
57
|
+
* wordFade per-word cross-dissolve with warmth scale, no Y movement
|
|
58
|
+
* rotateIn full Y-axis card-flip per word (face-up reveal)
|
|
59
|
+
* pressIn presses to 0.92 then springs past 1 (physical button feel)
|
|
31
60
|
*/
|
|
32
|
-
export type HeroAnimation = "rise" | "stagger" | "clip" | "pop" | "letters" | "blur" | "flip" | "swipe" | "typewriter" | "bounce" | "velvet" | "curtain" | "morph" | "ground" | "cascade" | "spotlight" | "ink" | "hinge" | "stretch" | "peel";
|
|
61
|
+
export type HeroAnimation = "rise" | "stagger" | "clip" | "pop" | "letters" | "blur" | "flip" | "swipe" | "typewriter" | "bounce" | "velvet" | "curtain" | "morph" | "ground" | "cascade" | "spotlight" | "ink" | "hinge" | "stretch" | "peel" | "fold" | "shear" | "ripple" | "cinch" | "tiltrise" | "cardFlip" | "converge" | "splitRise" | "tectonic" | "stratify" | "unfurl" | "gravityWell" | "orbit" | "liquid" | "noiseFade" | "slab" | "thread" | "billboard" | "glassReveal" | "wordPop" | "charDrop" | "scanline" | "chromaShift" | "wordFade" | "rotateIn" | "pressIn";
|
|
33
62
|
export interface TypographyProps extends HTMLAttributes<HTMLElement> {
|
|
34
63
|
/** Typography scale variant */
|
|
35
64
|
variant?: TypographyVariant;
|
|
36
|
-
/** Google Font name
|
|
65
|
+
/** Google Font name — auto-injects the Google Fonts <link> */
|
|
37
66
|
font?: string;
|
|
38
67
|
/** Text color — any valid CSS color */
|
|
39
68
|
color?: string;
|
|
@@ -43,28 +72,25 @@ export interface TypographyProps extends HTMLAttributes<HTMLElement> {
|
|
|
43
72
|
as?: ElementType;
|
|
44
73
|
/** Truncate to single line with ellipsis */
|
|
45
74
|
truncate?: boolean;
|
|
46
|
-
/** Clamp to N lines
|
|
75
|
+
/** Clamp to N lines */
|
|
47
76
|
maxLines?: number;
|
|
48
77
|
/**
|
|
49
|
-
* Hero entrance animation.
|
|
50
|
-
* "Display" or "H1".
|
|
78
|
+
* Hero entrance animation.
|
|
79
|
+
* Only applied on variant="Display" or variant="H1".
|
|
51
80
|
*/
|
|
52
81
|
animation?: HeroAnimation;
|
|
53
82
|
/**
|
|
54
83
|
* Italic accent for Display / H1 heroes.
|
|
55
|
-
* When true,
|
|
56
|
-
*
|
|
57
|
-
* in the heading font/weight with no serif or italics.
|
|
84
|
+
* When true, <em> children render in Instrument Serif italic + accentColor.
|
|
85
|
+
* Default: false.
|
|
58
86
|
*/
|
|
59
87
|
italic?: boolean;
|
|
60
88
|
/**
|
|
61
|
-
*
|
|
62
|
-
*
|
|
89
|
+
* Color for the <em> italic accent span.
|
|
90
|
+
* Default: "#c8b89a" (warm sand).
|
|
63
91
|
*/
|
|
64
92
|
accentColor?: string;
|
|
65
|
-
/** Inline style overrides */
|
|
66
93
|
style?: CSSProperties;
|
|
67
|
-
/** Additional class names */
|
|
68
94
|
className?: string;
|
|
69
95
|
}
|
|
70
96
|
export type VariantTagMap = Record<TypographyVariant, keyof JSX.IntrinsicElements>;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@edwinvakayil/calligraphy",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.4.0",
|
|
4
4
|
"description": "A lightweight React + TypeScript typography component with Google Fonts support. Scale from Display to Caption with a single prop.",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"module": "dist/index.esm.js",
|