UNPKG

@gracefullight/liquid-glass

Version:
159 lines (156 loc) 5.2 kB
"use client"; "use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/index.tsx var index_exports = {}; __export(index_exports, { LiquidGlassFilters: () => LiquidGlassFilters, LiquidGlassProvider: () => LiquidGlassProvider, useLiquidGlass: () => useLiquidGlass }); module.exports = __toCommonJS(index_exports); // src/liquid-glass-provider.tsx var import_react = require("react"); var import_jsx_runtime = require("react/jsx-runtime"); var defaultConfig = { radius: "12px", shadow: "0px 6px 24px rgba(0,0,0,0.2)", shadowOffset: "0px", shadowBlur: "20px", shadowSpread: "-5px", shadowColor: "rgba(255,255,255,0.7)", tintColor: "255,255,255", tintOpacity: 0.04, frostBlur: "2px", noiseFrequency: 2e-3, distortionStrength: 10, filterSeed: 92, filterNumOctaves: 2 }; var LiquidGlassContext = (0, import_react.createContext)(defaultConfig); var LiquidGlassProvider = ({ value, children }) => { const merged = { ...defaultConfig, ...value }; return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(LiquidGlassContext.Provider, { value: merged, children: [ children, /* @__PURE__ */ (0, import_jsx_runtime.jsxs)( "svg", { width: "0", height: "0", "aria-hidden": "true", focusable: "false", style: { position: "absolute" }, children: [ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("title", { children: "Liquid Glass SVG Filters" }), /* @__PURE__ */ (0, import_jsx_runtime.jsxs)( "filter", { id: "liquid-glass-distortion", x: "0", y: "0", width: "100%", height: "100%", children: [ /* @__PURE__ */ (0, import_jsx_runtime.jsx)( "feTurbulence", { type: "fractalNoise", baseFrequency: `${merged.noiseFrequency} ${merged.noiseFrequency}`, numOctaves: merged.filterNumOctaves, seed: merged.filterSeed, result: "noise" } ), /* @__PURE__ */ (0, import_jsx_runtime.jsx)("feGaussianBlur", { in: "noise", stdDeviation: "2", result: "blurred" }), /* @__PURE__ */ (0, import_jsx_runtime.jsx)( "feDisplacementMap", { in2: "blurred", in: "SourceGraphic", scale: merged.distortionStrength, xChannelSelector: "R", yChannelSelector: "G" } ) ] } ) ] } ) ] }); }; var useLiquidGlass = () => (0, import_react.useContext)(LiquidGlassContext); // src/liquid-glass-filters.tsx var import_jsx_runtime2 = require("react/jsx-runtime"); var LiquidGlassFilters = ({ innerShadowZIndex = 0, backdropFilterZIndex = -1 }) => { const ctx = useLiquidGlass(); return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_jsx_runtime2.Fragment, { children: [ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)( "span", { "aria-hidden": "true", style: { position: "absolute", inset: 0, width: "100%", height: "100%", zIndex: innerShadowZIndex, borderRadius: "inherit", pointerEvents: "none", boxShadow: `inset ${ctx.shadowOffset} ${ctx.shadowOffset} ${ctx.shadowBlur} ${ctx.shadowSpread} ${ctx.shadowColor}`, backgroundColor: `rgba(${ctx.tintColor}, ${ctx.tintOpacity})` } } ), /* @__PURE__ */ (0, import_jsx_runtime2.jsx)( "span", { "aria-hidden": "true", style: { position: "absolute", inset: 0, width: "100%", height: "100%", zIndex: backdropFilterZIndex, borderRadius: "inherit", pointerEvents: "none", isolation: "isolate", backdropFilter: `blur(${ctx.frostBlur})`, WebkitBackdropFilter: `blur(${ctx.frostBlur})`, filter: "url(#liquid-glass-distortion)", WebkitFilter: "url(#liquid-glass-distortion)" } } ) ] }); }; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { LiquidGlassFilters, LiquidGlassProvider, useLiquidGlass }); //# sourceMappingURL=index.js.map