tailwind-to-style 2.10.0-beta.1 → 2.10.1

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/index.cjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * tailwind-to-style v2.10.0-beta.1
2
+ * tailwind-to-style v2.10.1
3
3
  * Convert tailwind classes to inline style
4
4
  *
5
5
  * @author Bigetion
@@ -1595,9 +1595,9 @@ const configOptions = {
1595
1595
  vars
1596
1596
  };
1597
1597
 
1598
- /**
1599
- * TailwindCache singleton for managing generated Tailwind CSS
1600
- * Replaces global state with proper encapsulation
1598
+ /**
1599
+ * TailwindCache singleton for managing generated Tailwind CSS
1600
+ * Replaces global state with proper encapsulation
1601
1601
  */
1602
1602
  class TailwindCache {
1603
1603
  constructor() {
@@ -1606,44 +1606,44 @@ class TailwindCache {
1606
1606
  this.initialized = false;
1607
1607
  }
1608
1608
 
1609
- /**
1610
- * Get or generate the CSS object
1611
- * @param {Function} generateFn - Function to generate CSS string
1612
- * @param {Function} convertFn - Function to convert CSS string to object
1613
- * @returns {Object} CSS object lookup
1609
+ /**
1610
+ * Get or generate the CSS object
1611
+ * @param {Function} generateFn - Function to generate CSS string
1612
+ * @param {Function} convertFn - Function to convert CSS string to object
1613
+ * @returns {Object} CSS object lookup
1614
1614
  */
1615
1615
  getOrGenerate(generateFn, convertFn) {
1616
1616
  if (!this.initialized) {
1617
- this.twString = generateFn().replace(/\s\s+/g, ' ');
1617
+ this.twString = generateFn().replace(/\s\s+/g, " ");
1618
1618
  this.cssObject = convertFn(this.twString);
1619
1619
  this.initialized = true;
1620
1620
  }
1621
1621
  return this.cssObject;
1622
1622
  }
1623
1623
 
1624
- /**
1625
- * Get the CSS string
1624
+ /**
1625
+ * Get the CSS string
1626
1626
  */
1627
1627
  getCssString() {
1628
1628
  return this.twString;
1629
1629
  }
1630
1630
 
1631
- /**
1632
- * Get the CSS object
1631
+ /**
1632
+ * Get the CSS object
1633
1633
  */
1634
1634
  getCssObject() {
1635
1635
  return this.cssObject;
1636
1636
  }
1637
1637
 
1638
- /**
1639
- * Check if cache is initialized
1638
+ /**
1639
+ * Check if cache is initialized
1640
1640
  */
1641
1641
  isInitialized() {
1642
1642
  return this.initialized;
1643
1643
  }
1644
1644
 
1645
- /**
1646
- * Reset the cache (useful for testing)
1645
+ /**
1646
+ * Reset the cache (useful for testing)
1647
1647
  */
1648
1648
  reset() {
1649
1649
  this.twString = null;
@@ -1655,9 +1655,9 @@ class TailwindCache {
1655
1655
  // Singleton instance
1656
1656
  let instance = null;
1657
1657
 
1658
- /**
1659
- * Get the TailwindCache singleton instance
1660
- * @returns {TailwindCache} The cache instance
1658
+ /**
1659
+ * Get the TailwindCache singleton instance
1660
+ * @returns {TailwindCache} The cache instance
1661
1661
  */
1662
1662
  function getTailwindCache() {
1663
1663
  if (!instance) {
@@ -1666,8 +1666,8 @@ function getTailwindCache() {
1666
1666
  return instance;
1667
1667
  }
1668
1668
 
1669
- /**
1670
- * Reset the TailwindCache singleton (for testing)
1669
+ /**
1670
+ * Reset the TailwindCache singleton (for testing)
1671
1671
  */
1672
1672
  function resetTailwindCache() {
1673
1673
  if (instance) {
@@ -1677,13 +1677,13 @@ function resetTailwindCache() {
1677
1677
  }
1678
1678
 
1679
1679
  var _process$env;
1680
- /**
1681
- * Logger class with configurable log levels
1682
- * Prevents console spam in production
1680
+ /**
1681
+ * Logger class with configurable log levels
1682
+ * Prevents console spam in production
1683
1683
  */
1684
1684
  class Logger {
1685
1685
  constructor() {
1686
- let level = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'warn';
1686
+ let level = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "warn";
1687
1687
  this.level = level;
1688
1688
  this.levels = {
1689
1689
  debug: 0,
@@ -1694,9 +1694,9 @@ class Logger {
1694
1694
  };
1695
1695
  }
1696
1696
 
1697
- /**
1698
- * Set the log level
1699
- * @param {string} level - One of 'debug', 'info', 'warn', 'error', 'silent'
1697
+ /**
1698
+ * Set the log level
1699
+ * @param {string} level - One of 'debug', 'info', 'warn', 'error', 'silent'
1700
1700
  */
1701
1701
  setLevel(level) {
1702
1702
  if (this.levels[level] !== undefined) {
@@ -1704,25 +1704,25 @@ class Logger {
1704
1704
  }
1705
1705
  }
1706
1706
 
1707
- /**
1708
- * Get current log level
1707
+ /**
1708
+ * Get current log level
1709
1709
  */
1710
1710
  getLevel() {
1711
1711
  return this.level;
1712
1712
  }
1713
1713
 
1714
- /**
1715
- * Check if a message should be logged
1714
+ /**
1715
+ * Check if a message should be logged
1716
1716
  */
1717
1717
  shouldLog(level) {
1718
1718
  return this.levels[level] >= this.levels[this.level];
1719
1719
  }
1720
1720
 
1721
- /**
1722
- * Log debug message
1721
+ /**
1722
+ * Log debug message
1723
1723
  */
1724
1724
  debug(message) {
1725
- if (this.shouldLog('debug')) {
1725
+ if (this.shouldLog("debug")) {
1726
1726
  for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
1727
1727
  args[_key - 1] = arguments[_key];
1728
1728
  }
@@ -1730,11 +1730,11 @@ class Logger {
1730
1730
  }
1731
1731
  }
1732
1732
 
1733
- /**
1734
- * Log info message
1733
+ /**
1734
+ * Log info message
1735
1735
  */
1736
1736
  info(message) {
1737
- if (this.shouldLog('info')) {
1737
+ if (this.shouldLog("info")) {
1738
1738
  for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
1739
1739
  args[_key2 - 1] = arguments[_key2];
1740
1740
  }
@@ -1742,11 +1742,11 @@ class Logger {
1742
1742
  }
1743
1743
  }
1744
1744
 
1745
- /**
1746
- * Log warning message
1745
+ /**
1746
+ * Log warning message
1747
1747
  */
1748
1748
  warn(message) {
1749
- if (this.shouldLog('warn')) {
1749
+ if (this.shouldLog("warn")) {
1750
1750
  for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {
1751
1751
  args[_key3 - 1] = arguments[_key3];
1752
1752
  }
@@ -1754,11 +1754,11 @@ class Logger {
1754
1754
  }
1755
1755
  }
1756
1756
 
1757
- /**
1758
- * Log error message
1757
+ /**
1758
+ * Log error message
1759
1759
  */
1760
1760
  error(message) {
1761
- if (this.shouldLog('error')) {
1761
+ if (this.shouldLog("error")) {
1762
1762
  for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {
1763
1763
  args[_key4 - 1] = arguments[_key4];
1764
1764
  }
@@ -1768,16 +1768,16 @@ class Logger {
1768
1768
  }
1769
1769
 
1770
1770
  // Create singleton instance with production-safe defaults
1771
- const isProduction = typeof process !== 'undefined' && ((_process$env = process.env) === null || _process$env === void 0 ? void 0 : _process$env.NODE_ENV) === 'production';
1772
- const logger = new Logger(isProduction ? 'error' : 'warn');
1771
+ const isProduction = typeof process !== "undefined" && ((_process$env = process.env) === null || _process$env === void 0 ? void 0 : _process$env.NODE_ENV) === "production";
1772
+ const logger = new Logger(isProduction ? "error" : "warn");
1773
1773
 
1774
- /**
1775
- * User Configuration Management
1776
- * Handles theme extensions and custom plugin registration
1774
+ /**
1775
+ * User Configuration Management
1776
+ * Handles theme extensions and custom plugin registration
1777
1777
  */
1778
1778
 
1779
- /**
1780
- * User configuration state
1779
+ /**
1780
+ * User configuration state
1781
1781
  */
1782
1782
  let userConfig = {
1783
1783
  theme: {
@@ -1788,11 +1788,11 @@ let userConfig = {
1788
1788
  prefix: ""
1789
1789
  };
1790
1790
 
1791
- /**
1792
- * Deep merge two objects
1793
- * @param {Object} target - Target object
1794
- * @param {Object} source - Source object
1795
- * @returns {Object} Merged object
1791
+ /**
1792
+ * Deep merge two objects
1793
+ * @param {Object} target - Target object
1794
+ * @param {Object} source - Source object
1795
+ * @returns {Object} Merged object
1796
1796
  */
1797
1797
  function deepMerge(target, source) {
1798
1798
  const result = {
@@ -1808,31 +1808,31 @@ function deepMerge(target, source) {
1808
1808
  return result;
1809
1809
  }
1810
1810
 
1811
- /**
1812
- * Configure tailwind-to-style with custom theme and plugins
1813
- * @param {Object} config - Configuration object
1814
- * @param {Object} [config.theme] - Theme configuration
1815
- * @param {Object} [config.theme.extend] - Theme extensions
1816
- * @param {Array} [config.plugins] - Array of plugins
1817
- * @param {Object} [config.corePlugins] - Core plugins to enable/disable
1818
- * @param {string} [config.prefix] - Prefix for all classes
1819
- *
1820
- * @example
1821
- * configure({
1822
- * theme: {
1823
- * extend: {
1824
- * colors: {
1825
- * brand: {
1826
- * 500: '#3B82F6',
1827
- * },
1828
- * },
1829
- * spacing: {
1830
- * 128: '32rem',
1831
- * },
1832
- * },
1833
- * },
1834
- * plugins: [myCustomPlugin],
1835
- * });
1811
+ /**
1812
+ * Configure tailwind-to-style with custom theme and plugins
1813
+ * @param {Object} config - Configuration object
1814
+ * @param {Object} [config.theme] - Theme configuration
1815
+ * @param {Object} [config.theme.extend] - Theme extensions
1816
+ * @param {Array} [config.plugins] - Array of plugins
1817
+ * @param {Object} [config.corePlugins] - Core plugins to enable/disable
1818
+ * @param {string} [config.prefix] - Prefix for all classes
1819
+ *
1820
+ * @example
1821
+ * configure({
1822
+ * theme: {
1823
+ * extend: {
1824
+ * colors: {
1825
+ * brand: {
1826
+ * 500: '#3B82F6',
1827
+ * },
1828
+ * },
1829
+ * spacing: {
1830
+ * 128: '32rem',
1831
+ * },
1832
+ * },
1833
+ * },
1834
+ * plugins: [myCustomPlugin],
1835
+ * });
1836
1836
  */
1837
1837
  function configure() {
1838
1838
  let config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
@@ -1886,9 +1886,9 @@ function configure() {
1886
1886
  }
1887
1887
  }
1888
1888
 
1889
- /**
1890
- * Get current user configuration
1891
- * @returns {Object} Current configuration
1889
+ /**
1890
+ * Get current user configuration
1891
+ * @returns {Object} Current configuration
1892
1892
  */
1893
1893
  function getConfig() {
1894
1894
  return {
@@ -1896,8 +1896,8 @@ function getConfig() {
1896
1896
  };
1897
1897
  }
1898
1898
 
1899
- /**
1900
- * Reset configuration to defaults
1899
+ /**
1900
+ * Reset configuration to defaults
1901
1901
  */
1902
1902
  function resetConfig() {
1903
1903
  userConfig = {
@@ -1912,26 +1912,26 @@ function resetConfig() {
1912
1912
  logger.info("Configuration reset to defaults");
1913
1913
  }
1914
1914
 
1915
- /**
1916
- * Get extended theme value
1917
- * @param {string} key - Theme key (e.g., 'colors', 'spacing')
1918
- * @returns {Object} Extended theme values
1915
+ /**
1916
+ * Get extended theme value
1917
+ * @param {string} key - Theme key (e.g., 'colors', 'spacing')
1918
+ * @returns {Object} Extended theme values
1919
1919
  */
1920
1920
  function getExtendedTheme(key) {
1921
1921
  return userConfig.theme.extend[key] || {};
1922
1922
  }
1923
1923
 
1924
- /**
1925
- * Get all registered plugins
1926
- * @returns {Array} Array of plugins
1924
+ /**
1925
+ * Get all registered plugins
1926
+ * @returns {Array} Array of plugins
1927
1927
  */
1928
1928
  function getPlugins() {
1929
1929
  return userConfig.plugins;
1930
1930
  }
1931
1931
 
1932
- /**
1933
- * Get configured prefix
1934
- * @returns {string} Prefix string
1932
+ /**
1933
+ * Get configured prefix
1934
+ * @returns {string} Prefix string
1935
1935
  */
1936
1936
  function getPrefix() {
1937
1937
  return userConfig.prefix;
@@ -1979,6 +1979,19 @@ function getConfigOptions() {
1979
1979
  }
1980
1980
  });
1981
1981
 
1982
+ // Re-resolve theme functions after all extensions are applied
1983
+ // This ensures that theme functions like backgroundColor: ({ theme }) => theme("colors")
1984
+ // get the updated colors including custom theme extensions
1985
+ themeKeys.forEach(key => {
1986
+ if (isFunction(configOptions.theme[key])) {
1987
+ newTheme[key] = configOptions.theme[key]({
1988
+ theme: keyRef => {
1989
+ return newTheme[keyRef];
1990
+ }
1991
+ });
1992
+ }
1993
+ });
1994
+
1982
1995
  // Get user prefix
1983
1996
  const userPrefix = getPrefix();
1984
1997
  const finalPrefix = userPrefix || options.prefix || "";
@@ -2049,7 +2062,7 @@ function generateCssString$1() {
2049
2062
  return cssString;
2050
2063
  }
2051
2064
 
2052
- function generator$2w() {
2065
+ function generator$2M() {
2053
2066
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2054
2067
  const {
2055
2068
  prefix: globalPrefix,
@@ -2088,7 +2101,7 @@ function generator$2w() {
2088
2101
  return responsiveCssString;
2089
2102
  }
2090
2103
 
2091
- function generator$2v() {
2104
+ function generator$2L() {
2092
2105
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2093
2106
  const {
2094
2107
  prefix
@@ -2127,7 +2140,7 @@ function generator$2v() {
2127
2140
  return responsiveCssString;
2128
2141
  }
2129
2142
 
2130
- function generator$2u() {
2143
+ function generator$2K() {
2131
2144
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2132
2145
  const {
2133
2146
  prefix: globalPrefix
@@ -2155,7 +2168,7 @@ function generator$2u() {
2155
2168
  return responsiveCssString;
2156
2169
  }
2157
2170
 
2158
- function generator$2t() {
2171
+ function generator$2J() {
2159
2172
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2160
2173
  const {
2161
2174
  prefix: globalPrefix
@@ -2182,7 +2195,7 @@ function generator$2t() {
2182
2195
  return responsiveCssString;
2183
2196
  }
2184
2197
 
2185
- function generator$2s() {
2198
+ function generator$2I() {
2186
2199
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2187
2200
  const {
2188
2201
  prefix: globalPrefix
@@ -2209,14 +2222,224 @@ function generator$2s() {
2209
2222
  return responsiveCssString;
2210
2223
  }
2211
2224
 
2212
- /**
2213
- * Animation Generator
2214
- * Generates animation utility classes
2215
- * Note: Keyframes are defined in theme but not rendered here since inline styles
2216
- * can't use @keyframes. The animation values should reference keyframe names that
2217
- * are already defined in your global CSS.
2225
+ /**
2226
+ * Inline Animation System
2227
+ * Generate animation properties directly without keyframes
2218
2228
  */
2219
- function generator$2r() {
2229
+
2230
+ /* eslint-disable no-undef */
2231
+
2232
+ /**
2233
+ * Convert animation config to inline transition properties
2234
+ */
2235
+ function animationToTransition(animationConfig) {
2236
+ const {
2237
+ property = "all",
2238
+ duration = 300,
2239
+ easing = "ease-out",
2240
+ delay = 0
2241
+ } = animationConfig;
2242
+ return {
2243
+ transitionProperty: property,
2244
+ transitionDuration: `${duration}ms`,
2245
+ transitionTimingFunction: easing,
2246
+ transitionDelay: `${delay}ms`
2247
+ };
2248
+ }
2249
+
2250
+ /**
2251
+ * Built-in animation configs that work with transitions
2252
+ */
2253
+ const INLINE_ANIMATIONS = {
2254
+ "fade-in": {
2255
+ initial: {
2256
+ opacity: 0
2257
+ },
2258
+ final: {
2259
+ opacity: 1
2260
+ },
2261
+ transition: {
2262
+ duration: 500,
2263
+ easing: "ease-out"
2264
+ }
2265
+ },
2266
+ "slide-up": {
2267
+ initial: {
2268
+ transform: "translateY(20px)",
2269
+ opacity: 0
2270
+ },
2271
+ final: {
2272
+ transform: "translateY(0)",
2273
+ opacity: 1
2274
+ },
2275
+ transition: {
2276
+ duration: 500,
2277
+ easing: "ease-out"
2278
+ }
2279
+ },
2280
+ "slide-down": {
2281
+ initial: {
2282
+ transform: "translateY(-20px)",
2283
+ opacity: 0
2284
+ },
2285
+ final: {
2286
+ transform: "translateY(0)",
2287
+ opacity: 1
2288
+ },
2289
+ transition: {
2290
+ duration: 500,
2291
+ easing: "ease-out"
2292
+ }
2293
+ },
2294
+ "zoom-in": {
2295
+ initial: {
2296
+ transform: "scale(0.8)",
2297
+ opacity: 0
2298
+ },
2299
+ final: {
2300
+ transform: "scale(1)",
2301
+ opacity: 1
2302
+ },
2303
+ transition: {
2304
+ duration: 400,
2305
+ easing: "cubic-bezier(0.4, 0, 0.2, 1)"
2306
+ }
2307
+ },
2308
+ "zoom-out": {
2309
+ initial: {
2310
+ transform: "scale(1.2)",
2311
+ opacity: 0
2312
+ },
2313
+ final: {
2314
+ transform: "scale(1)",
2315
+ opacity: 1
2316
+ },
2317
+ transition: {
2318
+ duration: 400,
2319
+ easing: "cubic-bezier(0.4, 0, 0.2, 1)"
2320
+ }
2321
+ }
2322
+ };
2323
+
2324
+ /**
2325
+ * Apply inline animation to element
2326
+ */
2327
+ function applyInlineAnimation(element, animationName) {
2328
+ let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
2329
+ if (!element || !INLINE_ANIMATIONS[animationName]) return null;
2330
+ const animation = INLINE_ANIMATIONS[animationName];
2331
+ const {
2332
+ autoStart = true,
2333
+ onComplete
2334
+ } = options;
2335
+
2336
+ // Apply initial state
2337
+ Object.assign(element.style, animation.initial);
2338
+
2339
+ // Apply transition properties
2340
+ const transitionProps = animationToTransition(animation.transition);
2341
+ Object.assign(element.style, transitionProps);
2342
+ if (autoStart) {
2343
+ // Trigger animation on next frame
2344
+ requestAnimationFrame(() => {
2345
+ Object.assign(element.style, animation.final);
2346
+ if (onComplete) {
2347
+ setTimeout(onComplete, animation.transition.duration);
2348
+ }
2349
+ });
2350
+ }
2351
+ return {
2352
+ start: () => Object.assign(element.style, animation.final),
2353
+ reset: () => Object.assign(element.style, animation.initial),
2354
+ animation
2355
+ };
2356
+ }
2357
+
2358
+ /**
2359
+ * Animate element with custom properties
2360
+ */
2361
+ function animateElement(element, fromProps, toProps) {
2362
+ let options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
2363
+ if (!element) return null;
2364
+ const {
2365
+ duration = 300,
2366
+ easing = "ease-out",
2367
+ delay = 0,
2368
+ onComplete
2369
+ } = options;
2370
+
2371
+ // Apply initial state
2372
+ Object.assign(element.style, fromProps);
2373
+
2374
+ // Apply transition
2375
+ element.style.transition = `all ${duration}ms ${easing} ${delay}ms`;
2376
+
2377
+ // Trigger animation
2378
+ requestAnimationFrame(() => {
2379
+ Object.assign(element.style, toProps);
2380
+ if (onComplete) {
2381
+ setTimeout(onComplete, duration + delay);
2382
+ }
2383
+ });
2384
+ return {
2385
+ element,
2386
+ duration: duration + delay
2387
+ };
2388
+ }
2389
+
2390
+ /**
2391
+ * Chain multiple animations
2392
+ */
2393
+ function chainAnimations(element, animations) {
2394
+ let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
2395
+ if (!element || !animations.length) return Promise.resolve();
2396
+ const {
2397
+ onProgress
2398
+ } = options;
2399
+ let currentIndex = 0;
2400
+ return new Promise(resolve => {
2401
+ function runNext() {
2402
+ if (currentIndex >= animations.length) {
2403
+ resolve();
2404
+ return;
2405
+ }
2406
+ const animation = animations[currentIndex];
2407
+ animateElement(element, animation.from, animation.to, {
2408
+ ...animation.options,
2409
+ onComplete: () => {
2410
+ if (onProgress) {
2411
+ onProgress(currentIndex, animations.length);
2412
+ }
2413
+ currentIndex++;
2414
+ runNext();
2415
+ }
2416
+ });
2417
+ }
2418
+ runNext();
2419
+ });
2420
+ }
2421
+
2422
+ /**
2423
+ * Stagger animations for multiple elements
2424
+ */
2425
+ function staggerAnimations(elements, animationName) {
2426
+ let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
2427
+ const {
2428
+ staggerDelay = 100,
2429
+ ...animationOptions
2430
+ } = options;
2431
+ return elements.map((element, index) => {
2432
+ return setTimeout(() => {
2433
+ applyInlineAnimation(element, animationName, animationOptions);
2434
+ }, index * staggerDelay);
2435
+ });
2436
+ }
2437
+
2438
+ /**
2439
+ * Animation Generator
2440
+ * Generates animation utility classes with dynamic inline animations
2441
+ */
2442
+ function generator$2H() {
2220
2443
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2221
2444
  const {
2222
2445
  prefix: globalPrefix,
@@ -2230,7 +2453,51 @@ function generator$2r() {
2230
2453
  let {
2231
2454
  getCssByOptions
2232
2455
  } = _ref;
2233
- const cssString = getCssByOptions(animation, (key, value) => {
2456
+ // Merge theme animations with inline animations
2457
+ const allAnimations = {
2458
+ ...animation,
2459
+ // Add inline animations to the mix
2460
+ ...Object.keys(INLINE_ANIMATIONS).reduce((acc, key) => {
2461
+ acc[key] = `inline-${key}`; // Special marker for inline animations
2462
+ return acc;
2463
+ }, {})
2464
+ };
2465
+ const cssString = getCssByOptions(allAnimations, (key, value) => {
2466
+ // Check if this is an inline animation
2467
+ if (value.startsWith("inline-")) {
2468
+ const animationKey = value.replace("inline-", "");
2469
+ const inlineAnimation = INLINE_ANIMATIONS[animationKey];
2470
+ if (inlineAnimation) {
2471
+ // Generate CSS for inline animation (initial state + transition)
2472
+ const transitionProps = animationToTransition(inlineAnimation.transition);
2473
+ const initialProps = inlineAnimation.initial;
2474
+ let css = `${prefix}-${key} {\n`;
2475
+
2476
+ // Add initial state properties
2477
+ for (const [prop, val] of Object.entries(initialProps)) {
2478
+ const cssProp = prop.replace(/([A-Z])/g, "-$1").toLowerCase();
2479
+ css += ` ${cssProp}: ${val};\n`;
2480
+ }
2481
+
2482
+ // Add transition properties
2483
+ for (const [prop, val] of Object.entries(transitionProps)) {
2484
+ const cssProp = prop.replace(/([A-Z])/g, "-$1").toLowerCase();
2485
+ css += ` ${cssProp}: ${val};\n`;
2486
+ }
2487
+ css += "}\n";
2488
+
2489
+ // Add hover/active state for final animation
2490
+ css += `${prefix}-${key}:hover, ${prefix}-${key}.animate-active {\n`;
2491
+ for (const [prop, val] of Object.entries(inlineAnimation.final)) {
2492
+ const cssProp = prop.replace(/([A-Z])/g, "-$1").toLowerCase();
2493
+ css += ` ${cssProp}: ${val};\n`;
2494
+ }
2495
+ css += "}\n";
2496
+ return css;
2497
+ }
2498
+ }
2499
+
2500
+ // Fallback to traditional animation property
2234
2501
  return `
2235
2502
  ${prefix}-${key} {
2236
2503
  animation: ${value};
@@ -2242,7 +2509,7 @@ function generator$2r() {
2242
2509
  return responsiveCssString;
2243
2510
  }
2244
2511
 
2245
- function generator$2q() {
2512
+ function generator$2G() {
2246
2513
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2247
2514
  const {
2248
2515
  prefix
@@ -2262,7 +2529,7 @@ function generator$2q() {
2262
2529
  return responsiveCssString;
2263
2530
  }
2264
2531
 
2265
- function generator$2p() {
2532
+ function generator$2F() {
2266
2533
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2267
2534
  const {
2268
2535
  prefix: globalPrefix,
@@ -2291,7 +2558,7 @@ function generator$2p() {
2291
2558
  return responsiveCssString;
2292
2559
  }
2293
2560
 
2294
- function generator$2o() {
2561
+ function generator$2E() {
2295
2562
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2296
2563
  const {
2297
2564
  prefix: globalPrefix
@@ -2312,7 +2579,7 @@ function generator$2o() {
2312
2579
  return responsiveCssString;
2313
2580
  }
2314
2581
 
2315
- function generator$2n() {
2582
+ function generator$2D() {
2316
2583
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2317
2584
  const {
2318
2585
  prefix: globalPrefix
@@ -2339,7 +2606,7 @@ function generator$2n() {
2339
2606
  return responsiveCssString;
2340
2607
  }
2341
2608
 
2342
- function generator$2m() {
2609
+ function generator$2C() {
2343
2610
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2344
2611
  const {
2345
2612
  prefix: globalPrefix,
@@ -2379,7 +2646,7 @@ function generator$2m() {
2379
2646
  return responsiveCssString;
2380
2647
  }
2381
2648
 
2382
- function generator$2l() {
2649
+ function generator$2B() {
2383
2650
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2384
2651
  const {
2385
2652
  prefix: globalPrefix,
@@ -2413,7 +2680,7 @@ function generator$2l() {
2413
2680
  return responsiveCssString;
2414
2681
  }
2415
2682
 
2416
- function generator$2k() {
2683
+ function generator$2A() {
2417
2684
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2418
2685
  const {
2419
2686
  prefix: globalPrefix,
@@ -2437,7 +2704,7 @@ function generator$2k() {
2437
2704
  return responsiveCssString;
2438
2705
  }
2439
2706
 
2440
- function generator$2j() {
2707
+ function generator$2z() {
2441
2708
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2442
2709
  const {
2443
2710
  prefix: globalPrefix
@@ -2463,7 +2730,7 @@ function generator$2j() {
2463
2730
  return responsiveCssString;
2464
2731
  }
2465
2732
 
2466
- function generator$2i() {
2733
+ function generator$2y() {
2467
2734
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2468
2735
  const {
2469
2736
  prefix: globalPrefix,
@@ -2497,7 +2764,7 @@ function generator$2i() {
2497
2764
  return responsiveCssString;
2498
2765
  }
2499
2766
 
2500
- function generator$2h() {
2767
+ function generator$2x() {
2501
2768
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2502
2769
  const {
2503
2770
  prefix: globalPrefix
@@ -2525,7 +2792,7 @@ function generator$2h() {
2525
2792
  return responsiveCssString;
2526
2793
  }
2527
2794
 
2528
- function generator$2g() {
2795
+ function generator$2w() {
2529
2796
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2530
2797
  const {
2531
2798
  prefix: globalPrefix,
@@ -2559,7 +2826,288 @@ function generator$2g() {
2559
2826
  return responsiveCssString;
2560
2827
  }
2561
2828
 
2562
- function generator$2f() {
2829
+ function generator$2v() {
2830
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2831
+ const {
2832
+ prefix: globalPrefix,
2833
+ theme = {},
2834
+ vars = {}
2835
+ } = configOptions;
2836
+ const prefix = `${globalPrefix}backdrop-blur`;
2837
+ const {
2838
+ backdropBlur = {}
2839
+ } = theme;
2840
+ const responsiveCssString = generateCssString$1(_ref => {
2841
+ let {
2842
+ getCssByOptions
2843
+ } = _ref;
2844
+ const cssString = getCssByOptions(backdropBlur, (keyTmp, value) => {
2845
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
2846
+ return `
2847
+ ${prefix}${key} {
2848
+ --tw-backdrop-blur: blur(${value});
2849
+ ${vars.backdropFilter}
2850
+ }
2851
+ `;
2852
+ });
2853
+ return cssString;
2854
+ }, configOptions);
2855
+ return responsiveCssString;
2856
+ }
2857
+
2858
+ function generator$2u() {
2859
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2860
+ const {
2861
+ prefix: globalPrefix,
2862
+ theme = {},
2863
+ vars = {}
2864
+ } = configOptions;
2865
+ const prefix = `${globalPrefix}backdrop-brightness`;
2866
+ const {
2867
+ backdropBrightness = {}
2868
+ } = theme;
2869
+ const responsiveCssString = generateCssString$1(_ref => {
2870
+ let {
2871
+ getCssByOptions
2872
+ } = _ref;
2873
+ const cssString = getCssByOptions(backdropBrightness, (keyTmp, value) => {
2874
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
2875
+ return `
2876
+ ${prefix}${key} {
2877
+ --tw-backdrop-brightness: brightness(${value});
2878
+ ${vars.backdropFilter}
2879
+ }
2880
+ `;
2881
+ });
2882
+ return cssString;
2883
+ }, configOptions);
2884
+ return responsiveCssString;
2885
+ }
2886
+
2887
+ function generator$2t() {
2888
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2889
+ const {
2890
+ prefix: globalPrefix,
2891
+ theme = {},
2892
+ vars = {}
2893
+ } = configOptions;
2894
+ const prefix = `${globalPrefix}backdrop-contrast`;
2895
+ const {
2896
+ backdropContrast = {}
2897
+ } = theme;
2898
+ const responsiveCssString = generateCssString$1(_ref => {
2899
+ let {
2900
+ getCssByOptions
2901
+ } = _ref;
2902
+ const cssString = getCssByOptions(backdropContrast, (keyTmp, value) => {
2903
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
2904
+ return `
2905
+ ${prefix}${key} {
2906
+ --tw-backdrop-contrast: contrast(${value});
2907
+ ${vars.backdropFilter}
2908
+ }
2909
+ `;
2910
+ });
2911
+ return cssString;
2912
+ }, configOptions);
2913
+ return responsiveCssString;
2914
+ }
2915
+
2916
+ function generator$2s() {
2917
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2918
+ const {
2919
+ prefix,
2920
+ vars = {}
2921
+ } = configOptions;
2922
+ const responsiveCssString = generateCssString$1(() => {
2923
+ const cssString = `
2924
+ ${prefix}backdrop-filter {
2925
+ ${vars.backdropFilter}
2926
+ }
2927
+ ${prefix}backdrop-filter-none {
2928
+ backdrop-filter: none;
2929
+ }
2930
+ `;
2931
+ return cssString;
2932
+ }, configOptions);
2933
+ return responsiveCssString;
2934
+ }
2935
+
2936
+ function generator$2r() {
2937
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2938
+ const {
2939
+ prefix: globalPrefix,
2940
+ theme = {},
2941
+ vars = {}
2942
+ } = configOptions;
2943
+ const prefix = `${globalPrefix}backdrop-grayscale`;
2944
+ const {
2945
+ backdropGrayscale = {}
2946
+ } = theme;
2947
+ const responsiveCssString = generateCssString$1(_ref => {
2948
+ let {
2949
+ getCssByOptions
2950
+ } = _ref;
2951
+ const cssString = getCssByOptions(backdropGrayscale, (keyTmp, value) => {
2952
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
2953
+ return `
2954
+ ${prefix}${key} {
2955
+ --tw-backdrop-grayscale: grayscale(${value});
2956
+ ${vars.backdropFilter}
2957
+ }
2958
+ `;
2959
+ });
2960
+ return cssString;
2961
+ }, configOptions);
2962
+ return responsiveCssString;
2963
+ }
2964
+
2965
+ function generator$2q() {
2966
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2967
+ const {
2968
+ prefix: globalPrefix,
2969
+ theme = {},
2970
+ vars = {}
2971
+ } = configOptions;
2972
+ const prefix = `${globalPrefix}backdrop-hue-rotate`;
2973
+ const {
2974
+ backdropHueRotate = {}
2975
+ } = theme;
2976
+ const responsiveCssString = generateCssString$1(_ref => {
2977
+ let {
2978
+ getCssByOptions
2979
+ } = _ref;
2980
+ const cssString = getCssByOptions(backdropHueRotate, (keyTmp, value) => {
2981
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
2982
+ return `
2983
+ ${prefix}${key} {
2984
+ --tw-backdrop-hue-rotate: hue-rotate(${value});
2985
+ ${vars.backdropFilter}
2986
+ }
2987
+ `;
2988
+ });
2989
+ return cssString;
2990
+ }, configOptions);
2991
+ return responsiveCssString;
2992
+ }
2993
+
2994
+ function generator$2p() {
2995
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2996
+ const {
2997
+ prefix: globalPrefix,
2998
+ theme = {},
2999
+ vars = {}
3000
+ } = configOptions;
3001
+ const prefix = `${globalPrefix}backdrop-invert`;
3002
+ const {
3003
+ backdropInvert = {}
3004
+ } = theme;
3005
+ const responsiveCssString = generateCssString$1(_ref => {
3006
+ let {
3007
+ getCssByOptions
3008
+ } = _ref;
3009
+ const cssString = getCssByOptions(backdropInvert, (keyTmp, value) => {
3010
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
3011
+ return `
3012
+ ${prefix}${key} {
3013
+ --tw-backdrop-invert: invert(${value});
3014
+ ${vars.backdropFilter}
3015
+ }
3016
+ `;
3017
+ });
3018
+ return cssString;
3019
+ }, configOptions);
3020
+ return responsiveCssString;
3021
+ }
3022
+
3023
+ function generator$2o() {
3024
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3025
+ const {
3026
+ prefix: globalPrefix,
3027
+ theme = {},
3028
+ vars = {}
3029
+ } = configOptions;
3030
+ const prefix = `${globalPrefix}backdrop-opacity`;
3031
+ const {
3032
+ backdropOpacity = {}
3033
+ } = theme;
3034
+ const responsiveCssString = generateCssString$1(_ref => {
3035
+ let {
3036
+ getCssByOptions
3037
+ } = _ref;
3038
+ const cssString = getCssByOptions(backdropOpacity, (keyTmp, value) => {
3039
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
3040
+ return `
3041
+ ${prefix}${key} {
3042
+ --tw-backdrop-opacity: opacity(${value});
3043
+ ${vars.backdropFilter}
3044
+ }
3045
+ `;
3046
+ });
3047
+ return cssString;
3048
+ }, configOptions);
3049
+ return responsiveCssString;
3050
+ }
3051
+
3052
+ function generator$2n() {
3053
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3054
+ const {
3055
+ prefix: globalPrefix,
3056
+ theme = {},
3057
+ vars = {}
3058
+ } = configOptions;
3059
+ const prefix = `${globalPrefix}backdrop-saturate`;
3060
+ const {
3061
+ backdropSaturate = {}
3062
+ } = theme;
3063
+ const responsiveCssString = generateCssString$1(_ref => {
3064
+ let {
3065
+ getCssByOptions
3066
+ } = _ref;
3067
+ const cssString = getCssByOptions(backdropSaturate, (keyTmp, value) => {
3068
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
3069
+ return `
3070
+ ${prefix}${key} {
3071
+ --tw-backdrop-saturate: saturate(${value});
3072
+ ${vars.backdropFilter}
3073
+ }
3074
+ `;
3075
+ });
3076
+ return cssString;
3077
+ }, configOptions);
3078
+ return responsiveCssString;
3079
+ }
3080
+
3081
+ function generator$2m() {
3082
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3083
+ const {
3084
+ prefix: globalPrefix,
3085
+ theme = {},
3086
+ vars = {}
3087
+ } = configOptions;
3088
+ const prefix = `${globalPrefix}backdrop-sepia`;
3089
+ const {
3090
+ backdropSepia = {}
3091
+ } = theme;
3092
+ const responsiveCssString = generateCssString$1(_ref => {
3093
+ let {
3094
+ getCssByOptions
3095
+ } = _ref;
3096
+ const cssString = getCssByOptions(backdropSepia, (keyTmp, value) => {
3097
+ const key = keyTmp.toLowerCase() !== "default" ? `-${keyTmp}` : "";
3098
+ return `
3099
+ ${prefix}${key} {
3100
+ --tw-backdrop-sepia: sepia(${value});
3101
+ ${vars.backdropFilter}
3102
+ }
3103
+ `;
3104
+ });
3105
+ return cssString;
3106
+ }, configOptions);
3107
+ return responsiveCssString;
3108
+ }
3109
+
3110
+ function generator$2l() {
2563
3111
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2564
3112
  const {
2565
3113
  prefix: globalPrefix,
@@ -2593,7 +3141,7 @@ function generator$2f() {
2593
3141
  return responsiveCssString;
2594
3142
  }
2595
3143
 
2596
- function generator$2e() {
3144
+ function generator$2k() {
2597
3145
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2598
3146
  const {
2599
3147
  prefix: globalPrefix
@@ -2614,7 +3162,7 @@ function generator$2e() {
2614
3162
  return responsiveCssString;
2615
3163
  }
2616
3164
 
2617
- function generator$2d() {
3165
+ function generator$2j() {
2618
3166
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2619
3167
  const {
2620
3168
  prefix: globalPrefix,
@@ -2702,7 +3250,7 @@ function generator$2d() {
2702
3250
  return responsiveCssString;
2703
3251
  }
2704
3252
 
2705
- function generator$2c() {
3253
+ function generator$2i() {
2706
3254
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2707
3255
  const {
2708
3256
  prefix: globalPrefix,
@@ -2726,7 +3274,7 @@ function generator$2c() {
2726
3274
  return responsiveCssString;
2727
3275
  }
2728
3276
 
2729
- function generator$2b() {
3277
+ function generator$2h() {
2730
3278
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2731
3279
  const {
2732
3280
  prefix: globalPrefix,
@@ -2801,7 +3349,7 @@ function generator$2b() {
2801
3349
  return responsiveCssString;
2802
3350
  }
2803
3351
 
2804
- function generator$2a() {
3352
+ function generator$2g() {
2805
3353
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2806
3354
  const {
2807
3355
  prefix: globalPrefix,
@@ -2836,7 +3384,7 @@ function generator$2a() {
2836
3384
  return responsiveCssString;
2837
3385
  }
2838
3386
 
2839
- function generator$29() {
3387
+ function generator$2f() {
2840
3388
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2841
3389
  const {
2842
3390
  prefix: globalPrefix
@@ -2857,7 +3405,7 @@ function generator$29() {
2857
3405
  return responsiveCssString;
2858
3406
  }
2859
3407
 
2860
- function generator$28() {
3408
+ function generator$2e() {
2861
3409
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2862
3410
  const {
2863
3411
  prefix: globalPrefix,
@@ -2922,7 +3470,7 @@ function generator$28() {
2922
3470
  return responsiveCssString;
2923
3471
  }
2924
3472
 
2925
- function generator$27() {
3473
+ function generator$2d() {
2926
3474
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2927
3475
  const {
2928
3476
  prefix: globalPrefix
@@ -2944,7 +3492,7 @@ function generator$27() {
2944
3492
  return responsiveCssString;
2945
3493
  }
2946
3494
 
2947
- function generator$26() {
3495
+ function generator$2c() {
2948
3496
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
2949
3497
  const {
2950
3498
  prefix: globalPrefix,
@@ -2998,7 +3546,7 @@ function generator$26() {
2998
3546
  return responsiveCssString;
2999
3547
  }
3000
3548
 
3001
- function generator$25() {
3549
+ function generator$2b() {
3002
3550
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3003
3551
  const {
3004
3552
  prefix: globalPrefix
@@ -3022,7 +3570,67 @@ function generator$25() {
3022
3570
  return responsiveCssString;
3023
3571
  }
3024
3572
 
3025
- function generator$24() {
3573
+ function generator$2a() {
3574
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3575
+ const {
3576
+ prefix
3577
+ } = configOptions;
3578
+ const propertyOptions = ["auto", "avoid", "all", "avoid-page", "page", "left", "right", "column"];
3579
+ const responsiveCssString = generateCssString$1(_ref => {
3580
+ let {
3581
+ getCssByOptions
3582
+ } = _ref;
3583
+ const cssString = getCssByOptions(propertyOptions, (key, value) => `
3584
+ ${prefix}break-after-${key} {
3585
+ break-after: ${value};
3586
+ }
3587
+ `);
3588
+ return cssString;
3589
+ }, configOptions);
3590
+ return responsiveCssString;
3591
+ }
3592
+
3593
+ function generator$29() {
3594
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3595
+ const {
3596
+ prefix
3597
+ } = configOptions;
3598
+ const propertyOptions = ["auto", "avoid", "all", "avoid-page", "page", "left", "right", "column"];
3599
+ const responsiveCssString = generateCssString$1(_ref => {
3600
+ let {
3601
+ getCssByOptions
3602
+ } = _ref;
3603
+ const cssString = getCssByOptions(propertyOptions, (key, value) => `
3604
+ ${prefix}break-before-${key} {
3605
+ break-before: ${value};
3606
+ }
3607
+ `);
3608
+ return cssString;
3609
+ }, configOptions);
3610
+ return responsiveCssString;
3611
+ }
3612
+
3613
+ function generator$28() {
3614
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3615
+ const {
3616
+ prefix
3617
+ } = configOptions;
3618
+ const propertyOptions = ["auto", "avoid", "avoid-page", "avoid-column"];
3619
+ const responsiveCssString = generateCssString$1(_ref => {
3620
+ let {
3621
+ getCssByOptions
3622
+ } = _ref;
3623
+ const cssString = getCssByOptions(propertyOptions, (key, value) => `
3624
+ ${prefix}break-inside-${key} {
3625
+ break-inside: ${value};
3626
+ }
3627
+ `);
3628
+ return cssString;
3629
+ }, configOptions);
3630
+ return responsiveCssString;
3631
+ }
3632
+
3633
+ function generator$27() {
3026
3634
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3027
3635
  const {
3028
3636
  prefix: globalPrefix,
@@ -3056,7 +3664,7 @@ function generator$24() {
3056
3664
  return responsiveCssString;
3057
3665
  }
3058
3666
 
3059
- function generator$23() {
3667
+ function generator$26() {
3060
3668
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3061
3669
  const {
3062
3670
  prefix: globalPrefix
@@ -3077,7 +3685,7 @@ function generator$23() {
3077
3685
  return responsiveCssString;
3078
3686
  }
3079
3687
 
3080
- function generator$22() {
3688
+ function generator$25() {
3081
3689
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3082
3690
  const {
3083
3691
  prefix: globalPrefix,
@@ -3116,7 +3724,7 @@ function generator$22() {
3116
3724
  return responsiveCssString;
3117
3725
  }
3118
3726
 
3119
- function generator$21() {
3727
+ function generator$24() {
3120
3728
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3121
3729
  const {
3122
3730
  prefix: globalPrefix
@@ -3137,7 +3745,46 @@ function generator$21() {
3137
3745
  return responsiveCssString;
3138
3746
  }
3139
3747
 
3140
- function generator$20() {
3748
+ function generator$23() {
3749
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3750
+ const {
3751
+ prefix,
3752
+ theme = {}
3753
+ } = configOptions;
3754
+ const {
3755
+ columns = {}
3756
+ } = theme;
3757
+ const responsiveCssString = generateCssString$1(_ref => {
3758
+ let {
3759
+ getCssByOptions
3760
+ } = _ref;
3761
+ const cssString = getCssByOptions(columns, (key, value) => `
3762
+ ${prefix}columns-${key} {
3763
+ columns: ${value};
3764
+ }
3765
+ `);
3766
+ return cssString;
3767
+ }, configOptions);
3768
+ return responsiveCssString;
3769
+ }
3770
+
3771
+ function generator$22() {
3772
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3773
+ const {
3774
+ prefix
3775
+ } = configOptions;
3776
+ const responsiveCssString = generateCssString$1(() => {
3777
+ const cssString = `
3778
+ ${prefix}container {
3779
+ width: 100%;
3780
+ }
3781
+ `;
3782
+ return cssString;
3783
+ }, configOptions);
3784
+ return responsiveCssString;
3785
+ }
3786
+
3787
+ function generator$21() {
3141
3788
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3142
3789
  const {
3143
3790
  prefix: globalPrefix,
@@ -3161,7 +3808,7 @@ function generator$20() {
3161
3808
  return responsiveCssString;
3162
3809
  }
3163
3810
 
3164
- function generator$1$() {
3811
+ function generator$20() {
3165
3812
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3166
3813
  const {
3167
3814
  prefix: globalPrefix,
@@ -3195,7 +3842,7 @@ function generator$1$() {
3195
3842
  return responsiveCssString;
3196
3843
  }
3197
3844
 
3198
- function generator$1_() {
3845
+ function generator$1$() {
3199
3846
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3200
3847
  const {
3201
3848
  prefix: globalPrefix
@@ -3216,7 +3863,7 @@ function generator$1_() {
3216
3863
  return responsiveCssString;
3217
3864
  }
3218
3865
 
3219
- function generator$1Z() {
3866
+ function generator$1_() {
3220
3867
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3221
3868
  const {
3222
3869
  prefix
@@ -3236,7 +3883,7 @@ function generator$1Z() {
3236
3883
  return responsiveCssString;
3237
3884
  }
3238
3885
 
3239
- function generator$1Y() {
3886
+ function generator$1Z() {
3240
3887
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3241
3888
  const {
3242
3889
  prefix: globalPrefix,
@@ -3267,7 +3914,7 @@ function generator$1Y() {
3267
3914
  return responsiveCssString;
3268
3915
  }
3269
3916
 
3270
- function generator$1X() {
3917
+ function generator$1Y() {
3271
3918
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3272
3919
  const {
3273
3920
  prefix: globalPrefix,
@@ -3291,7 +3938,7 @@ function generator$1X() {
3291
3938
  return responsiveCssString;
3292
3939
  }
3293
3940
 
3294
- function generator$1W() {
3941
+ function generator$1X() {
3295
3942
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3296
3943
  const {
3297
3944
  prefix: globalPrefix
@@ -3312,7 +3959,7 @@ function generator$1W() {
3312
3959
  return responsiveCssString;
3313
3960
  }
3314
3961
 
3315
- function generator$1V() {
3962
+ function generator$1W() {
3316
3963
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3317
3964
  const {
3318
3965
  prefix: globalPrefix,
@@ -3360,7 +4007,7 @@ function generator$1V() {
3360
4007
  return responsiveCssString;
3361
4008
  }
3362
4009
 
3363
- function generator$1U() {
4010
+ function generator$1V() {
3364
4011
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3365
4012
  const {
3366
4013
  prefix: globalPrefix,
@@ -3388,7 +4035,7 @@ function generator$1U() {
3388
4035
  return responsiveCssString;
3389
4036
  }
3390
4037
 
3391
- function generator$1T() {
4038
+ function generator$1U() {
3392
4039
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3393
4040
  const {
3394
4041
  prefix: globalPrefix,
@@ -3414,7 +4061,7 @@ function generator$1T() {
3414
4061
  return responsiveCssString;
3415
4062
  }
3416
4063
 
3417
- function generator$1S(_ref) {
4064
+ function generator$1T(_ref) {
3418
4065
  let {
3419
4066
  prefix
3420
4067
  } = _ref;
@@ -3427,7 +4074,7 @@ function generator$1S(_ref) {
3427
4074
  `;
3428
4075
  }
3429
4076
 
3430
- function generator$1R() {
4077
+ function generator$1S() {
3431
4078
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3432
4079
  const {
3433
4080
  prefix: globalPrefix,
@@ -3451,7 +4098,7 @@ function generator$1R() {
3451
4098
  return responsiveCssString;
3452
4099
  }
3453
4100
 
3454
- function generator$1Q() {
4101
+ function generator$1R() {
3455
4102
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3456
4103
  const {
3457
4104
  prefix: globalPrefix,
@@ -3475,7 +4122,7 @@ function generator$1Q() {
3475
4122
  return responsiveCssString;
3476
4123
  }
3477
4124
 
3478
- function generator$1P() {
4125
+ function generator$1Q() {
3479
4126
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3480
4127
  const {
3481
4128
  prefix: globalPrefix
@@ -3501,7 +4148,7 @@ function generator$1P() {
3501
4148
  return responsiveCssString;
3502
4149
  }
3503
4150
 
3504
- function generator$1O() {
4151
+ function generator$1P() {
3505
4152
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3506
4153
  const {
3507
4154
  prefix: globalPrefix,
@@ -3525,7 +4172,7 @@ function generator$1O() {
3525
4172
  return responsiveCssString;
3526
4173
  }
3527
4174
 
3528
- function generator$1N() {
4175
+ function generator$1O() {
3529
4176
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3530
4177
  const {
3531
4178
  prefix: globalPrefix,
@@ -3549,7 +4196,7 @@ function generator$1N() {
3549
4196
  return responsiveCssString;
3550
4197
  }
3551
4198
 
3552
- function generator$1M() {
4199
+ function generator$1N() {
3553
4200
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3554
4201
  const {
3555
4202
  prefix: globalPrefix
@@ -3575,7 +4222,7 @@ function generator$1M() {
3575
4222
  return responsiveCssString;
3576
4223
  }
3577
4224
 
3578
- function generator$1L() {
4225
+ function generator$1M() {
3579
4226
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3580
4227
  const {
3581
4228
  prefix: globalPrefix
@@ -3596,7 +4243,7 @@ function generator$1L() {
3596
4243
  return responsiveCssString;
3597
4244
  }
3598
4245
 
3599
- function generator$1K() {
4246
+ function generator$1L() {
3600
4247
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3601
4248
  const {
3602
4249
  prefix: globalPrefix,
@@ -3630,7 +4277,7 @@ function generator$1K() {
3630
4277
  return responsiveCssString;
3631
4278
  }
3632
4279
 
3633
- function generator$1J() {
4280
+ function generator$1K() {
3634
4281
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3635
4282
  const {
3636
4283
  prefix
@@ -3650,7 +4297,7 @@ function generator$1J() {
3650
4297
  return responsiveCssString;
3651
4298
  }
3652
4299
 
3653
- function generator$1I() {
4300
+ function generator$1J() {
3654
4301
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3655
4302
  const {
3656
4303
  prefix
@@ -3673,7 +4320,7 @@ function generator$1I() {
3673
4320
  return responsiveCssString;
3674
4321
  }
3675
4322
 
3676
- function generator$1H() {
4323
+ function generator$1I() {
3677
4324
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3678
4325
  const {
3679
4326
  prefix
@@ -3703,7 +4350,7 @@ function generator$1H() {
3703
4350
  return responsiveCssString;
3704
4351
  }
3705
4352
 
3706
- function generator$1G() {
4353
+ function generator$1H() {
3707
4354
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3708
4355
  const {
3709
4356
  prefix: globalPrefix,
@@ -3737,7 +4384,7 @@ function generator$1G() {
3737
4384
  return responsiveCssString;
3738
4385
  }
3739
4386
 
3740
- function generator$1F() {
4387
+ function generator$1G() {
3741
4388
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3742
4389
  const {
3743
4390
  prefix: globalPrefix,
@@ -3767,7 +4414,7 @@ function generator$1F() {
3767
4414
  return responsiveCssString;
3768
4415
  }
3769
4416
 
3770
- function generator$1E() {
4417
+ function generator$1F() {
3771
4418
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3772
4419
  const {
3773
4420
  prefix,
@@ -3806,7 +4453,7 @@ function generator$1E() {
3806
4453
  return responsiveCssString;
3807
4454
  }
3808
4455
 
3809
- function generator$1D() {
4456
+ function generator$1E() {
3810
4457
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3811
4458
  const {
3812
4459
  prefix: globalPrefix,
@@ -3840,7 +4487,7 @@ function generator$1D() {
3840
4487
  return responsiveCssString;
3841
4488
  }
3842
4489
 
3843
- function generator$1C() {
4490
+ function generator$1D() {
3844
4491
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3845
4492
  const {
3846
4493
  prefix: globalPrefix,
@@ -3864,7 +4511,7 @@ function generator$1C() {
3864
4511
  return responsiveCssString;
3865
4512
  }
3866
4513
 
3867
- function generator$1B() {
4514
+ function generator$1C() {
3868
4515
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3869
4516
  const {
3870
4517
  prefix: globalPrefix
@@ -3890,7 +4537,7 @@ function generator$1B() {
3890
4537
  return responsiveCssString;
3891
4538
  }
3892
4539
 
3893
- function generator$1A() {
4540
+ function generator$1B() {
3894
4541
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3895
4542
  const {
3896
4543
  prefix: globalPrefix,
@@ -3914,7 +4561,7 @@ function generator$1A() {
3914
4561
  return responsiveCssString;
3915
4562
  }
3916
4563
 
3917
- function generator$1z() {
4564
+ function generator$1A() {
3918
4565
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3919
4566
  const {
3920
4567
  prefix: globalPrefix,
@@ -3938,7 +4585,7 @@ function generator$1z() {
3938
4585
  return responsiveCssString;
3939
4586
  }
3940
4587
 
3941
- function generator$1y() {
4588
+ function generator$1z() {
3942
4589
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3943
4590
  const {
3944
4591
  prefix: globalPrefix,
@@ -3962,7 +4609,7 @@ function generator$1y() {
3962
4609
  return responsiveCssString;
3963
4610
  }
3964
4611
 
3965
- function generator$1x() {
4612
+ function generator$1y() {
3966
4613
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3967
4614
  const {
3968
4615
  prefix: globalPrefix,
@@ -3986,7 +4633,7 @@ function generator$1x() {
3986
4633
  return responsiveCssString;
3987
4634
  }
3988
4635
 
3989
- function generator$1w() {
4636
+ function generator$1x() {
3990
4637
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3991
4638
  const {
3992
4639
  prefix: globalPrefix,
@@ -4010,7 +4657,7 @@ function generator$1w() {
4010
4657
  return responsiveCssString;
4011
4658
  }
4012
4659
 
4013
- function generator$1v() {
4660
+ function generator$1w() {
4014
4661
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4015
4662
  const {
4016
4663
  prefix: globalPrefix,
@@ -4034,7 +4681,7 @@ function generator$1v() {
4034
4681
  return responsiveCssString;
4035
4682
  }
4036
4683
 
4037
- function generator$1u() {
4684
+ function generator$1v() {
4038
4685
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4039
4686
  const {
4040
4687
  prefix: globalPrefix,
@@ -4058,7 +4705,7 @@ function generator$1u() {
4058
4705
  return responsiveCssString;
4059
4706
  }
4060
4707
 
4061
- function generator$1t() {
4708
+ function generator$1u() {
4062
4709
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4063
4710
  const {
4064
4711
  prefix: globalPrefix,
@@ -4082,7 +4729,7 @@ function generator$1t() {
4082
4729
  return responsiveCssString;
4083
4730
  }
4084
4731
 
4085
- function generator$1s() {
4732
+ function generator$1t() {
4086
4733
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4087
4734
  const {
4088
4735
  prefix: globalPrefix,
@@ -4106,7 +4753,7 @@ function generator$1s() {
4106
4753
  return responsiveCssString;
4107
4754
  }
4108
4755
 
4109
- function generator$1r() {
4756
+ function generator$1s() {
4110
4757
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4111
4758
  const {
4112
4759
  prefix: globalPrefix,
@@ -4130,7 +4777,7 @@ function generator$1r() {
4130
4777
  return responsiveCssString;
4131
4778
  }
4132
4779
 
4133
- function generator$1q() {
4780
+ function generator$1r() {
4134
4781
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4135
4782
  const {
4136
4783
  prefix: globalPrefix,
@@ -4168,7 +4815,7 @@ function generator$1q() {
4168
4815
  return responsiveCssString;
4169
4816
  }
4170
4817
 
4171
- function generator$1p() {
4818
+ function generator$1q() {
4172
4819
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4173
4820
  const {
4174
4821
  prefix: globalPrefix
@@ -4190,7 +4837,7 @@ function generator$1p() {
4190
4837
  return responsiveCssString;
4191
4838
  }
4192
4839
 
4193
- function generator$1o() {
4840
+ function generator$1p() {
4194
4841
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4195
4842
  const {
4196
4843
  prefix: globalPrefix,
@@ -4248,7 +4895,7 @@ function generator$1o() {
4248
4895
  return responsiveCssString;
4249
4896
  }
4250
4897
 
4251
- function generator$1n() {
4898
+ function generator$1o() {
4252
4899
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4253
4900
  const {
4254
4901
  prefix: globalPrefix,
@@ -4282,7 +4929,7 @@ function generator$1n() {
4282
4929
  return responsiveCssString;
4283
4930
  }
4284
4931
 
4285
- function generator$1m() {
4932
+ function generator$1n() {
4286
4933
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4287
4934
  const {
4288
4935
  prefix: globalPrefix
@@ -4306,7 +4953,7 @@ function generator$1m() {
4306
4953
  return responsiveCssString;
4307
4954
  }
4308
4955
 
4309
- function generator$1l() {
4956
+ function generator$1m() {
4310
4957
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4311
4958
  const {
4312
4959
  prefix: globalPrefix
@@ -4334,7 +4981,7 @@ function generator$1l() {
4334
4981
  return responsiveCssString;
4335
4982
  }
4336
4983
 
4337
- function generator$1k() {
4984
+ function generator$1l() {
4338
4985
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4339
4986
  const {
4340
4987
  prefix: globalPrefix
@@ -4355,7 +5002,7 @@ function generator$1k() {
4355
5002
  return responsiveCssString;
4356
5003
  }
4357
5004
 
4358
- function generator$1j() {
5005
+ function generator$1k() {
4359
5006
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4360
5007
  const {
4361
5008
  prefix: globalPrefix
@@ -4376,7 +5023,7 @@ function generator$1j() {
4376
5023
  return responsiveCssString;
4377
5024
  }
4378
5025
 
4379
- function generator$1i() {
5026
+ function generator$1j() {
4380
5027
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4381
5028
  const {
4382
5029
  prefix: globalPrefix,
@@ -4400,7 +5047,7 @@ function generator$1i() {
4400
5047
  return responsiveCssString;
4401
5048
  }
4402
5049
 
4403
- function generator$1h() {
5050
+ function generator$1i() {
4404
5051
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4405
5052
  const {
4406
5053
  prefix: globalPrefix,
@@ -4427,7 +5074,7 @@ function generator$1h() {
4427
5074
  return responsiveCssString;
4428
5075
  }
4429
5076
 
4430
- function generator$1g() {
5077
+ function generator$1h() {
4431
5078
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4432
5079
  const {
4433
5080
  prefix: globalPrefix,
@@ -4451,6 +5098,22 @@ function generator$1g() {
4451
5098
  return responsiveCssString;
4452
5099
  }
4453
5100
 
5101
+ function generator$1g() {
5102
+ let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
5103
+ const {
5104
+ prefix
5105
+ } = configOptions;
5106
+ const responsiveCssString = generateCssString$1(() => {
5107
+ const cssString = `
5108
+ ${prefix}list-image-none {
5109
+ list-style-image: none;
5110
+ }
5111
+ `;
5112
+ return cssString;
5113
+ }, configOptions);
5114
+ return responsiveCssString;
5115
+ }
5116
+
4454
5117
  function generator$1f() {
4455
5118
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4456
5119
  const {
@@ -6407,9 +7070,9 @@ function generator$d() {
6407
7070
  return responsiveCssString;
6408
7071
  }
6409
7072
 
6410
- /**
6411
- * Transition Delay Generator
6412
- * Generates transition-delay utility classes
7073
+ /**
7074
+ * Transition Delay Generator
7075
+ * Generates transition-delay utility classes
6413
7076
  */
6414
7077
  function generator$c() {
6415
7078
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
@@ -6437,9 +7100,9 @@ function generator$c() {
6437
7100
  return responsiveCssString;
6438
7101
  }
6439
7102
 
6440
- /**
6441
- * Transition Duration Generator
6442
- * Generates transition-duration utility classes
7103
+ /**
7104
+ * Transition Duration Generator
7105
+ * Generates transition-duration utility classes
6443
7106
  */
6444
7107
  function generator$b() {
6445
7108
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
@@ -6467,9 +7130,9 @@ function generator$b() {
6467
7130
  return responsiveCssString;
6468
7131
  }
6469
7132
 
6470
- /**
6471
- * Transition Property Generator
6472
- * Generates transition-property utility classes
7133
+ /**
7134
+ * Transition Property Generator
7135
+ * Generates transition-property utility classes
6473
7136
  */
6474
7137
  function generator$a() {
6475
7138
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
@@ -6508,9 +7171,9 @@ function generator$a() {
6508
7171
  return responsiveCssString;
6509
7172
  }
6510
7173
 
6511
- /**
6512
- * Transition Timing Function Generator
6513
- * Generates transition-timing-function utility classes (ease)
7174
+ /**
7175
+ * Transition Timing Function Generator
7176
+ * Generates transition-timing-function utility classes (ease)
6514
7177
  */
6515
7178
  function generator$9() {
6516
7179
  let configOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
@@ -6779,9 +7442,9 @@ function generator() {
6779
7442
  return responsiveCssString;
6780
7443
  }
6781
7444
 
6782
- /**
6783
- * Proper LRU (Least Recently Used) Cache implementation
6784
- * Efficiently manages memory by removing least recently used items
7445
+ /**
7446
+ * Proper LRU (Least Recently Used) Cache implementation
7447
+ * Efficiently manages memory by removing least recently used items
6785
7448
  */
6786
7449
  class LRUCache {
6787
7450
  constructor() {
@@ -6790,9 +7453,9 @@ class LRUCache {
6790
7453
  this.cache = new Map();
6791
7454
  }
6792
7455
 
6793
- /**
6794
- * Get value from cache
6795
- * Updates the item as most recently used
7456
+ /**
7457
+ * Get value from cache
7458
+ * Updates the item as most recently used
6796
7459
  */
6797
7460
  get(key) {
6798
7461
  if (!this.cache.has(key)) {
@@ -6805,9 +7468,9 @@ class LRUCache {
6805
7468
  return value;
6806
7469
  }
6807
7470
 
6808
- /**
6809
- * Set value in cache
6810
- * Removes least recently used item if cache is full
7471
+ /**
7472
+ * Set value in cache
7473
+ * Removes least recently used item if cache is full
6811
7474
  */
6812
7475
  set(key, value) {
6813
7476
  // If key exists, delete it first to update position
@@ -6821,61 +7484,61 @@ class LRUCache {
6821
7484
  this.cache.set(key, value);
6822
7485
  }
6823
7486
 
6824
- /**
6825
- * Check if key exists in cache
7487
+ /**
7488
+ * Check if key exists in cache
6826
7489
  */
6827
7490
  has(key) {
6828
7491
  return this.cache.has(key);
6829
7492
  }
6830
7493
 
6831
- /**
6832
- * Clear all cache entries
7494
+ /**
7495
+ * Clear all cache entries
6833
7496
  */
6834
7497
  clear() {
6835
7498
  this.cache.clear();
6836
7499
  }
6837
7500
 
6838
- /**
6839
- * Get current cache size
7501
+ /**
7502
+ * Get current cache size
6840
7503
  */
6841
7504
  get size() {
6842
7505
  return this.cache.size;
6843
7506
  }
6844
7507
 
6845
- /**
6846
- * Delete specific key
7508
+ /**
7509
+ * Delete specific key
6847
7510
  */
6848
7511
  delete(key) {
6849
7512
  return this.cache.delete(key);
6850
7513
  }
6851
7514
  }
6852
7515
 
6853
- /**
6854
- * Custom error class for tailwind-to-style
7516
+ /**
7517
+ * Custom error class for tailwind-to-style
6855
7518
  */
6856
7519
  class TwsError extends Error {
6857
7520
  constructor(message) {
6858
7521
  let context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
6859
7522
  super(message);
6860
- this.name = 'TwsError';
7523
+ this.name = "TwsError";
6861
7524
  this.context = context;
6862
7525
  this.timestamp = new Date().toISOString();
6863
7526
  }
6864
7527
  }
6865
7528
 
6866
- /**
6867
- * Error event handlers
7529
+ /**
7530
+ * Error event handlers
6868
7531
  */
6869
7532
  const errorHandlers = new Set();
6870
7533
 
6871
- /**
6872
- * Register an error handler
6873
- * @param {Function} handler - Function to call when errors occur
6874
- * @returns {Function} Unsubscribe function
7534
+ /**
7535
+ * Register an error handler
7536
+ * @param {Function} handler - Function to call when errors occur
7537
+ * @returns {Function} Unsubscribe function
6875
7538
  */
6876
7539
  function onError(handler) {
6877
- if (typeof handler !== 'function') {
6878
- throw new TypeError('Error handler must be a function');
7540
+ if (typeof handler !== "function") {
7541
+ throw new TypeError("Error handler must be a function");
6879
7542
  }
6880
7543
  errorHandlers.add(handler);
6881
7544
 
@@ -6883,10 +7546,10 @@ function onError(handler) {
6883
7546
  return () => errorHandlers.delete(handler);
6884
7547
  }
6885
7548
 
6886
- /**
6887
- * Handle and broadcast errors
6888
- * @param {Error} error - The error that occurred
6889
- * @param {Object} context - Additional context about the error
7549
+ /**
7550
+ * Handle and broadcast errors
7551
+ * @param {Error} error - The error that occurred
7552
+ * @param {Object} context - Additional context about the error
6890
7553
  */
6891
7554
  function handleError(error) {
6892
7555
  let context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
@@ -6900,41 +7563,41 @@ function handleError(error) {
6900
7563
  try {
6901
7564
  handler(twsError);
6902
7565
  } catch (handlerError) {
6903
- logger.error('Error in error handler:', handlerError);
7566
+ logger.error("Error in error handler:", handlerError);
6904
7567
  }
6905
7568
  });
6906
7569
  return twsError;
6907
7570
  }
6908
7571
 
6909
- /**
6910
- * Plugin API for tailwind-to-style
6911
- * Allows users to create custom utilities and extend functionality
7572
+ /**
7573
+ * Plugin API for tailwind-to-style
7574
+ * Allows users to create custom utilities and extend functionality
6912
7575
  */
6913
7576
 
6914
- /**
6915
- * Create a plugin for tailwind-to-style
6916
- *
6917
- * @param {string} name - Plugin name
6918
- * @param {Object} definition - Plugin definition
6919
- * @param {Object} [definition.utilities] - Custom utility classes
6920
- * @param {Object} [definition.components] - Custom component classes
6921
- * @param {Function} [definition.handler] - Custom handler function
6922
- * @returns {Object} Plugin object
6923
- *
6924
- * @example
6925
- * const myPlugin = createPlugin('my-plugin', {
6926
- * utilities: {
6927
- * '.text-gradient': {
6928
- * 'background-clip': 'text',
6929
- * '-webkit-background-clip': 'text',
6930
- * '-webkit-text-fill-color': 'transparent',
6931
- * },
6932
- * '.glass': {
6933
- * 'backdrop-filter': 'blur(10px)',
6934
- * 'background-color': 'rgba(255, 255, 255, 0.1)',
6935
- * },
6936
- * },
6937
- * });
7577
+ /**
7578
+ * Create a plugin for tailwind-to-style
7579
+ *
7580
+ * @param {string} name - Plugin name
7581
+ * @param {Object} definition - Plugin definition
7582
+ * @param {Object} [definition.utilities] - Custom utility classes
7583
+ * @param {Object} [definition.components] - Custom component classes
7584
+ * @param {Function} [definition.handler] - Custom handler function
7585
+ * @returns {Object} Plugin object
7586
+ *
7587
+ * @example
7588
+ * const myPlugin = createPlugin('my-plugin', {
7589
+ * utilities: {
7590
+ * '.text-gradient': {
7591
+ * 'background-clip': 'text',
7592
+ * '-webkit-background-clip': 'text',
7593
+ * '-webkit-text-fill-color': 'transparent',
7594
+ * },
7595
+ * '.glass': {
7596
+ * 'backdrop-filter': 'blur(10px)',
7597
+ * 'background-color': 'rgba(255, 255, 255, 0.1)',
7598
+ * },
7599
+ * },
7600
+ * });
6938
7601
  */
6939
7602
  function createPlugin(name, definition) {
6940
7603
  if (!name || typeof name !== "string") {
@@ -6954,28 +7617,28 @@ function createPlugin(name, definition) {
6954
7617
  return plugin;
6955
7618
  }
6956
7619
 
6957
- /**
6958
- * Create a utility plugin with dynamic values
6959
- *
6960
- * @param {string} name - Plugin name
6961
- * @param {Object} config - Configuration
6962
- * @param {string} config.prefix - Class prefix (e.g., 'text', 'bg')
6963
- * @param {Object} config.values - Values object
6964
- * @param {Function} config.formatter - Function to format CSS properties
6965
- * @returns {Object} Plugin object
6966
- *
6967
- * @example
6968
- * const textShadowPlugin = createUtilityPlugin('text-shadow', {
6969
- * prefix: 'text-shadow',
6970
- * values: {
6971
- * sm: '1px 1px 2px rgba(0,0,0,0.1)',
6972
- * md: '2px 2px 4px rgba(0,0,0,0.1)',
6973
- * lg: '4px 4px 8px rgba(0,0,0,0.1)',
6974
- * },
6975
- * formatter: (value) => ({
6976
- * 'text-shadow': value,
6977
- * }),
6978
- * });
7620
+ /**
7621
+ * Create a utility plugin with dynamic values
7622
+ *
7623
+ * @param {string} name - Plugin name
7624
+ * @param {Object} config - Configuration
7625
+ * @param {string} config.prefix - Class prefix (e.g., 'text', 'bg')
7626
+ * @param {Object} config.values - Values object
7627
+ * @param {Function} config.formatter - Function to format CSS properties
7628
+ * @returns {Object} Plugin object
7629
+ *
7630
+ * @example
7631
+ * const textShadowPlugin = createUtilityPlugin('text-shadow', {
7632
+ * prefix: 'text-shadow',
7633
+ * values: {
7634
+ * sm: '1px 1px 2px rgba(0,0,0,0.1)',
7635
+ * md: '2px 2px 4px rgba(0,0,0,0.1)',
7636
+ * lg: '4px 4px 8px rgba(0,0,0,0.1)',
7637
+ * },
7638
+ * formatter: (value) => ({
7639
+ * 'text-shadow': value,
7640
+ * }),
7641
+ * });
6979
7642
  */
6980
7643
  function createUtilityPlugin(name, config) {
6981
7644
  const {
@@ -6997,17 +7660,17 @@ function createUtilityPlugin(name, config) {
6997
7660
  });
6998
7661
  }
6999
7662
 
7000
- /**
7001
- * Create a variant plugin
7002
- *
7003
- * @param {string} name - Plugin name
7004
- * @param {Function} handler - Variant handler function
7005
- * @returns {Object} Plugin object
7006
- *
7007
- * @example
7008
- * const hoverParentPlugin = createVariantPlugin('hover-parent', (selector) => {
7009
- * return `.parent:hover ${selector}`;
7010
- * });
7663
+ /**
7664
+ * Create a variant plugin
7665
+ *
7666
+ * @param {string} name - Plugin name
7667
+ * @param {Function} handler - Variant handler function
7668
+ * @returns {Object} Plugin object
7669
+ *
7670
+ * @example
7671
+ * const hoverParentPlugin = createVariantPlugin('hover-parent', (selector) => {
7672
+ * return `.parent:hover ${selector}`;
7673
+ * });
7011
7674
  */
7012
7675
  function createVariantPlugin(name, handler) {
7013
7676
  if (!handler || typeof handler !== "function") {
@@ -7021,11 +7684,11 @@ function createVariantPlugin(name, handler) {
7021
7684
  });
7022
7685
  }
7023
7686
 
7024
- /**
7025
- * Convert plugin utilities to lookup object
7026
- * @param {Object} plugin - Plugin object
7027
- * @param {string} [prefix] - Optional prefix for all classes
7028
- * @returns {Object} Lookup object
7687
+ /**
7688
+ * Convert plugin utilities to lookup object
7689
+ * @param {Object} plugin - Plugin object
7690
+ * @param {string} [prefix] - Optional prefix for all classes
7691
+ * @returns {Object} Lookup object
7029
7692
  */
7030
7693
  function pluginToLookup(plugin) {
7031
7694
  let prefix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : "";
@@ -7144,88 +7807,427 @@ const patterns = {
7144
7807
  ...fontFamily
7145
7808
  };
7146
7809
 
7810
+ /**
7811
+ * Web Animations API Integration
7812
+ * Dynamic animations without keyframes injection
7813
+ */
7814
+
7815
+ /* eslint-disable no-undef */
7816
+
7817
+ /**
7818
+ * Built-in animation definitions using Web Animations API
7819
+ */
7820
+ const BUILTIN_ANIMATIONS = {
7821
+ spin: {
7822
+ keyframes: [{
7823
+ transform: "rotate(0deg)"
7824
+ }, {
7825
+ transform: "rotate(360deg)"
7826
+ }],
7827
+ options: {
7828
+ duration: 1000,
7829
+ iterations: Infinity
7830
+ }
7831
+ },
7832
+ ping: {
7833
+ keyframes: [{
7834
+ transform: "scale(1)",
7835
+ opacity: 1
7836
+ }, {
7837
+ transform: "scale(2)",
7838
+ opacity: 0
7839
+ }],
7840
+ options: {
7841
+ duration: 1000,
7842
+ iterations: Infinity
7843
+ }
7844
+ },
7845
+ pulse: {
7846
+ keyframes: [{
7847
+ opacity: 1
7848
+ }, {
7849
+ opacity: 0.5
7850
+ }, {
7851
+ opacity: 1
7852
+ }],
7853
+ options: {
7854
+ duration: 2000,
7855
+ iterations: Infinity
7856
+ }
7857
+ },
7858
+ bounce: {
7859
+ keyframes: [{
7860
+ transform: "translateY(0)",
7861
+ animationTimingFunction: "cubic-bezier(0.8,0,1,1)"
7862
+ }, {
7863
+ transform: "translateY(-25%)",
7864
+ animationTimingFunction: "cubic-bezier(0,0,0.2,1)"
7865
+ }, {
7866
+ transform: "translateY(0)",
7867
+ animationTimingFunction: "cubic-bezier(0.8,0,1,1)"
7868
+ }],
7869
+ options: {
7870
+ duration: 1000,
7871
+ iterations: Infinity
7872
+ }
7873
+ },
7874
+ "fade-in": {
7875
+ keyframes: [{
7876
+ opacity: 0
7877
+ }, {
7878
+ opacity: 1
7879
+ }],
7880
+ options: {
7881
+ duration: 500,
7882
+ fill: "forwards"
7883
+ }
7884
+ },
7885
+ "slide-up": {
7886
+ keyframes: [{
7887
+ transform: "translateY(20px)",
7888
+ opacity: 0
7889
+ }, {
7890
+ transform: "translateY(0)",
7891
+ opacity: 1
7892
+ }],
7893
+ options: {
7894
+ duration: 500,
7895
+ fill: "forwards"
7896
+ }
7897
+ }
7898
+ };
7899
+
7900
+ /**
7901
+ * Apply animation using Web Animations API
7902
+ */
7903
+ function applyWebAnimation(element, animationName) {
7904
+ let customAnimations = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
7905
+ if (!element || typeof element.animate !== "function") return null;
7906
+ const animation = BUILTIN_ANIMATIONS[animationName] || customAnimations[animationName];
7907
+ if (!animation) return null;
7908
+ return element.animate(animation.keyframes, animation.options);
7909
+ }
7910
+
7911
+ /**
7912
+ * Create animation observer for elements with animation classes
7913
+ */
7914
+ function createAnimationObserver() {
7915
+ let customAnimations = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7916
+ if (typeof MutationObserver === "undefined") return null;
7917
+ const observer = new MutationObserver(mutations => {
7918
+ mutations.forEach(mutation => {
7919
+ mutation.addedNodes.forEach(node => {
7920
+ if (node.nodeType === Node.ELEMENT_NODE) {
7921
+ processAnimationElements(node, customAnimations);
7922
+ }
7923
+ });
7924
+ if (mutation.type === "attributes" && mutation.attributeName === "class") {
7925
+ processAnimationElements(mutation.target, customAnimations);
7926
+ }
7927
+ });
7928
+ });
7929
+ observer.observe(document.body, {
7930
+ childList: true,
7931
+ subtree: true,
7932
+ attributes: true,
7933
+ attributeFilter: ["class"]
7934
+ });
7935
+ return observer;
7936
+ }
7937
+
7938
+ /**
7939
+ * Process elements for animation classes
7940
+ */
7941
+ function processAnimationElements(element) {
7942
+ let customAnimations = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
7943
+ if (!element.classList) return;
7944
+ const animationClasses = Array.from(element.classList).filter(cls => cls.startsWith("animate-")).map(cls => cls.replace("animate-", ""));
7945
+ animationClasses.forEach(animationName => {
7946
+ applyWebAnimation(element, animationName, customAnimations);
7947
+ });
7948
+ }
7949
+
7950
+ /**
7951
+ * Initialize web animations for existing elements
7952
+ */
7953
+ function initWebAnimations() {
7954
+ let customAnimations = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7955
+ if (typeof document === "undefined") return;
7956
+
7957
+ // Process existing elements
7958
+ const animatedElements = document.querySelectorAll('[class*="animate-"]');
7959
+ animatedElements.forEach(element => {
7960
+ processAnimationElements(element, customAnimations);
7961
+ });
7962
+
7963
+ // Create observer for new elements
7964
+ return createAnimationObserver(customAnimations);
7965
+ }
7966
+
7967
+ /**
7968
+ * Dynamic Animation System
7969
+ * Uses CSS variables for dynamic keyframe generation
7970
+ */
7971
+
7972
+ /* eslint-disable no-undef */
7973
+
7974
+ let animationStyleElement = null;
7975
+ let animationCounter = 0;
7976
+
7977
+ /**
7978
+ * Initialize dynamic animation style element
7979
+ */
7980
+ function initAnimationStyleElement() {
7981
+ if (typeof document === "undefined") return null;
7982
+ if (!animationStyleElement) {
7983
+ animationStyleElement = document.createElement("style");
7984
+ animationStyleElement.id = "twsx-dynamic-animations";
7985
+ animationStyleElement.setAttribute("data-twsx", "dynamic-animations");
7986
+ document.head.appendChild(animationStyleElement);
7987
+ }
7988
+ return animationStyleElement;
7989
+ }
7990
+
7991
+ /**
7992
+ * Generate dynamic keyframe with CSS variables
7993
+ */
7994
+ function generateDynamicKeyframe(name, keyframeObj) {
7995
+ let variables = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
7996
+ let css = `@keyframes ${name} {\n`;
7997
+ for (const [percentage, styles] of Object.entries(keyframeObj)) {
7998
+ css += ` ${percentage} {\n`;
7999
+ if (typeof styles === "object") {
8000
+ for (const [prop, value] of Object.entries(styles)) {
8001
+ const cssProp = prop.replace(/([A-Z])/g, "-$1").toLowerCase();
8002
+
8003
+ // Replace variables in value
8004
+ let finalValue = value;
8005
+ for (const [varName, varValue] of Object.entries(variables)) {
8006
+ finalValue = finalValue.replace(new RegExp(`\\$\\{${varName}\\}`, "g"), varValue);
8007
+ }
8008
+ css += ` ${cssProp}: ${finalValue};\n`;
8009
+ }
8010
+ }
8011
+ css += " }\n";
8012
+ }
8013
+ css += "}\n";
8014
+ return css;
8015
+ }
8016
+
8017
+ /**
8018
+ * Create dynamic animation with parameters
8019
+ */
8020
+ function createDynamicAnimation(baseKeyframes) {
8021
+ let parameters = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
8022
+ const animationId = `dynamic-anim-${++animationCounter}`;
8023
+ const styleElement = initAnimationStyleElement();
8024
+ if (!styleElement) return null;
8025
+
8026
+ // Generate keyframes with parameters
8027
+ const keyframeCSS = generateDynamicKeyframe(animationId, baseKeyframes, parameters);
8028
+ styleElement.textContent += keyframeCSS;
8029
+ return animationId;
8030
+ }
8031
+
8032
+ /**
8033
+ * Predefined dynamic animation templates
8034
+ */
8035
+ const DYNAMIC_TEMPLATES = {
8036
+ slideIn: {
8037
+ keyframes: {
8038
+ "0%": {
8039
+ transform: "translate${direction}(${distance})",
8040
+ opacity: "${startOpacity}"
8041
+ },
8042
+ "100%": {
8043
+ transform: "translate${direction}(0)",
8044
+ opacity: "${endOpacity}"
8045
+ }
8046
+ },
8047
+ defaults: {
8048
+ direction: "Y",
8049
+ distance: "20px",
8050
+ startOpacity: "0",
8051
+ endOpacity: "1"
8052
+ }
8053
+ },
8054
+ scale: {
8055
+ keyframes: {
8056
+ "0%": {
8057
+ transform: "scale(${startScale})",
8058
+ opacity: "${startOpacity}"
8059
+ },
8060
+ "100%": {
8061
+ transform: "scale(${endScale})",
8062
+ opacity: "${endOpacity}"
8063
+ }
8064
+ },
8065
+ defaults: {
8066
+ startScale: "0.8",
8067
+ endScale: "1",
8068
+ startOpacity: "0",
8069
+ endOpacity: "1"
8070
+ }
8071
+ },
8072
+ rotate: {
8073
+ keyframes: {
8074
+ "0%": {
8075
+ transform: "rotate(${startAngle})"
8076
+ },
8077
+ "100%": {
8078
+ transform: "rotate(${endAngle})"
8079
+ }
8080
+ },
8081
+ defaults: {
8082
+ startAngle: "0deg",
8083
+ endAngle: "360deg"
8084
+ }
8085
+ },
8086
+ colorShift: {
8087
+ keyframes: {
8088
+ "0%": {
8089
+ backgroundColor: "${startColor}",
8090
+ color: "${startTextColor}"
8091
+ },
8092
+ "100%": {
8093
+ backgroundColor: "${endColor}",
8094
+ color: "${endTextColor}"
8095
+ }
8096
+ },
8097
+ defaults: {
8098
+ startColor: "transparent",
8099
+ endColor: "#3b82f6",
8100
+ startTextColor: "inherit",
8101
+ endTextColor: "white"
8102
+ }
8103
+ }
8104
+ };
8105
+
8106
+ /**
8107
+ * Create animation from template
8108
+ */
8109
+ function createTemplateAnimation(templateName) {
8110
+ let customParams = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
8111
+ const template = DYNAMIC_TEMPLATES[templateName];
8112
+ if (!template) return null;
8113
+ const params = {
8114
+ ...template.defaults,
8115
+ ...customParams
8116
+ };
8117
+ return createDynamicAnimation(template.keyframes, params);
8118
+ }
8119
+
8120
+ /**
8121
+ * Apply dynamic animation to element
8122
+ */
8123
+ function applyDynamicAnimation(element, templateName) {
8124
+ let params = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
8125
+ let duration = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 500;
8126
+ if (!element) return null;
8127
+ const animationName = createTemplateAnimation(templateName, params);
8128
+ if (!animationName) return null;
8129
+ element.style.animation = `${animationName} ${duration}ms ease-out forwards`;
8130
+ return animationName;
8131
+ }
8132
+
7147
8133
  const plugins = {
7148
- accentColor: generator$2w,
7149
- accessibility: generator$2v,
7150
- alignContent: generator$2u,
7151
- alignItems: generator$2t,
7152
- alignSelf: generator$2s,
7153
- animation: generator$2r,
7154
- appearance: generator$2q,
7155
- aspect: generator$2p,
7156
- backgroundAttachment: generator$2o,
7157
- backgroundClip: generator$2n,
7158
- backgroundColor: generator$2m,
7159
- backgroundImage: generator$2l,
7160
- backgroundOpacity: generator$2k,
7161
- backgroundOrigin: generator$2j,
7162
- backgroundPosition: generator$2i,
7163
- backgroundRepeat: generator$2h,
7164
- backgroundSize: generator$2g,
7165
- blur: generator$2f,
7166
- borderCollapse: generator$2e,
7167
- borderColor: generator$2d,
7168
- borderOpacity: generator$2c,
7169
- borderRadius: generator$2b,
7170
- borderSpacing: generator$2a,
7171
- borderStyle: generator$29,
7172
- borderWidth: generator$28,
7173
- boxDecorationBreak: generator$27,
7174
- boxShadow: generator$26,
7175
- boxSizing: generator$25,
7176
- brightness: generator$24,
7177
- captionSide: generator$23,
7178
- caretColor: generator$22,
7179
- clear: generator$21,
7180
- content: generator$20,
7181
- contrast: generator$1$,
7182
- cursor: generator$1_,
7183
- display: generator$1Z,
7184
- divideColor: generator$1Y,
7185
- divideOpacity: generator$1X,
7186
- divideStyle: generator$1W,
7187
- divideWidth: generator$1V,
7188
- dropShadow: generator$1U,
7189
- fill: generator$1T,
7190
- filter: generator$1S,
7191
- flex: generator$1R,
7192
- flexBasis: generator$1Q,
7193
- flexDirection: generator$1P,
7194
- flexGrow: generator$1O,
7195
- flexShrink: generator$1N,
7196
- flexWrap: generator$1M,
7197
- float: generator$1L,
7198
- fontSize: generator$1K,
7199
- fontSmoothing: generator$1J,
7200
- fontStyle: generator$1I,
7201
- fontVariantNumeric: generator$1H,
7202
- fontWeight: generator$1G,
7203
- gap: generator$1F,
7204
- gradientColorStops: generator$1E,
7205
- grayscale: generator$1D,
7206
- gridAutoColumns: generator$1C,
7207
- gridAutoFlow: generator$1B,
7208
- gridAutoRows: generator$1A,
7209
- gridColumn: generator$1z,
7210
- gridColumnEnd: generator$1y,
7211
- gridColumnStart: generator$1x,
7212
- gridRow: generator$1w,
7213
- gridRowEnd: generator$1v,
7214
- gridRowStart: generator$1u,
7215
- gridTemplateColumns: generator$1t,
7216
- gridTemplateRows: generator$1s,
7217
- height: generator$1r,
7218
- hueRotate: generator$1q,
7219
- hyphens: generator$1p,
7220
- inset: generator$1o,
7221
- invert: generator$1n,
7222
- isolation: generator$1m,
7223
- justifyContent: generator$1l,
7224
- justifyItems: generator$1k,
7225
- justifySelf: generator$1j,
7226
- letterSpacing: generator$1i,
7227
- lineClamp: generator$1h,
7228
- lineHeight: generator$1g,
8134
+ accentColor: generator$2M,
8135
+ accessibility: generator$2L,
8136
+ alignContent: generator$2K,
8137
+ alignItems: generator$2J,
8138
+ alignSelf: generator$2I,
8139
+ animation: generator$2H,
8140
+ appearance: generator$2G,
8141
+ aspect: generator$2F,
8142
+ backgroundAttachment: generator$2E,
8143
+ backgroundClip: generator$2D,
8144
+ backgroundColor: generator$2C,
8145
+ backgroundImage: generator$2B,
8146
+ backgroundOpacity: generator$2A,
8147
+ backgroundOrigin: generator$2z,
8148
+ backgroundPosition: generator$2y,
8149
+ backgroundRepeat: generator$2x,
8150
+ backgroundSize: generator$2w,
8151
+ backdropBlur: generator$2v,
8152
+ backdropBrightness: generator$2u,
8153
+ backdropContrast: generator$2t,
8154
+ backdropFilter: generator$2s,
8155
+ backdropGrayscale: generator$2r,
8156
+ backdropHueRotate: generator$2q,
8157
+ backdropInvert: generator$2p,
8158
+ backdropOpacity: generator$2o,
8159
+ backdropSaturate: generator$2n,
8160
+ backdropSepia: generator$2m,
8161
+ blur: generator$2l,
8162
+ borderCollapse: generator$2k,
8163
+ borderColor: generator$2j,
8164
+ borderOpacity: generator$2i,
8165
+ borderRadius: generator$2h,
8166
+ borderSpacing: generator$2g,
8167
+ borderStyle: generator$2f,
8168
+ borderWidth: generator$2e,
8169
+ boxDecorationBreak: generator$2d,
8170
+ boxShadow: generator$2c,
8171
+ boxSizing: generator$2b,
8172
+ breakAfter: generator$2a,
8173
+ breakBefore: generator$29,
8174
+ breakInside: generator$28,
8175
+ brightness: generator$27,
8176
+ captionSide: generator$26,
8177
+ caretColor: generator$25,
8178
+ clear: generator$24,
8179
+ columns: generator$23,
8180
+ container: generator$22,
8181
+ content: generator$21,
8182
+ contrast: generator$20,
8183
+ cursor: generator$1$,
8184
+ display: generator$1_,
8185
+ divideColor: generator$1Z,
8186
+ divideOpacity: generator$1Y,
8187
+ divideStyle: generator$1X,
8188
+ divideWidth: generator$1W,
8189
+ dropShadow: generator$1V,
8190
+ fill: generator$1U,
8191
+ filter: generator$1T,
8192
+ flex: generator$1S,
8193
+ flexBasis: generator$1R,
8194
+ flexDirection: generator$1Q,
8195
+ flexGrow: generator$1P,
8196
+ flexShrink: generator$1O,
8197
+ flexWrap: generator$1N,
8198
+ float: generator$1M,
8199
+ fontSize: generator$1L,
8200
+ fontSmoothing: generator$1K,
8201
+ fontStyle: generator$1J,
8202
+ fontVariantNumeric: generator$1I,
8203
+ fontWeight: generator$1H,
8204
+ gap: generator$1G,
8205
+ gradientColorStops: generator$1F,
8206
+ grayscale: generator$1E,
8207
+ gridAutoColumns: generator$1D,
8208
+ gridAutoFlow: generator$1C,
8209
+ gridAutoRows: generator$1B,
8210
+ gridColumn: generator$1A,
8211
+ gridColumnEnd: generator$1z,
8212
+ gridColumnStart: generator$1y,
8213
+ gridRow: generator$1x,
8214
+ gridRowEnd: generator$1w,
8215
+ gridRowStart: generator$1v,
8216
+ gridTemplateColumns: generator$1u,
8217
+ gridTemplateRows: generator$1t,
8218
+ height: generator$1s,
8219
+ hueRotate: generator$1r,
8220
+ hyphens: generator$1q,
8221
+ inset: generator$1p,
8222
+ invert: generator$1o,
8223
+ isolation: generator$1n,
8224
+ justifyContent: generator$1m,
8225
+ justifyItems: generator$1l,
8226
+ justifySelf: generator$1k,
8227
+ letterSpacing: generator$1j,
8228
+ lineClamp: generator$1i,
8229
+ lineHeight: generator$1h,
8230
+ listStyleImage: generator$1g,
7229
8231
  listStylePosition: generator$1f,
7230
8232
  listStyleType: generator$1e,
7231
8233
  margin: generator$1d,
@@ -7323,10 +8325,10 @@ function parseCustomClassWithPatterns(className) {
7323
8325
  return null;
7324
8326
  }
7325
8327
 
7326
- /**
7327
- * Resolve all CSS custom properties (var) in a CSS string and output only clear CSS (no custom property)
7328
- * @param {string} cssString
7329
- * @returns {string} e.g. 'color: rgba(255,255,255,1); background: #fff;'
8328
+ /**
8329
+ * Resolve all CSS custom properties (var) in a CSS string and output only clear CSS (no custom property)
8330
+ * @param {string} cssString
8331
+ * @returns {string} e.g. 'color: rgba(255,255,255,1); background: #fff;'
7330
8332
  */
7331
8333
  function resolveCssToClearCss(cssString) {
7332
8334
  const customVars = {};
@@ -7356,19 +8358,40 @@ function resolveCssToClearCss(cssString) {
7356
8358
  // Cache for getConfigOptions - use LRU cache
7357
8359
  const configOptionsCache = new LRUCache(500);
7358
8360
  function generateTailwindCssString() {
8361
+ var _options$theme, _userConfigData$theme;
7359
8362
  let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7360
8363
  const pluginKeys = Object.keys(plugins);
8364
+
8365
+ // Merge user config with options
8366
+ const userConfigData = getConfig();
8367
+ const mergedOptions = {
8368
+ ...options,
8369
+ theme: {
8370
+ ...options.theme,
8371
+ ...userConfigData.theme,
8372
+ extend: {
8373
+ ...((_options$theme = options.theme) === null || _options$theme === void 0 ? void 0 : _options$theme.extend),
8374
+ ...((_userConfigData$theme = userConfigData.theme) === null || _userConfigData$theme === void 0 ? void 0 : _userConfigData$theme.extend)
8375
+ }
8376
+ }
8377
+ };
8378
+
7361
8379
  // Use cache to prevent unnecessary reprocessing
7362
- const key = JSON.stringify(options);
8380
+ // Include user config in cache key to ensure cache invalidation
8381
+ const key = JSON.stringify({
8382
+ options: mergedOptions,
8383
+ userConfigHash: JSON.stringify(userConfigData)
8384
+ });
7363
8385
  if (!configOptionsCache.has(key)) {
7364
- configOptionsCache.set(key, getConfigOptions(options, pluginKeys));
8386
+ const configOptions = getConfigOptions(mergedOptions, pluginKeys);
8387
+ configOptionsCache.set(key, configOptions);
7365
8388
  }
7366
8389
  const configOptions = configOptionsCache.get(key);
7367
8390
  const {
7368
8391
  corePlugins = {}
7369
8392
  } = configOptions;
7370
8393
  const corePluginKeys = Object.keys(corePlugins);
7371
- let cssString = ``;
8394
+ let cssString = "";
7372
8395
  Object.keys(plugins).forEach(key => {
7373
8396
  if (corePluginKeys.indexOf(key) >= 0 && !corePlugins[key]) {
7374
8397
  cssString += "";
@@ -7417,10 +8440,10 @@ const specialVariants = {
7417
8440
  dark: (state, sel) => `.dark ${sel}`
7418
8441
  };
7419
8442
  const selectorVariants = {
7420
- first: () => `> :first-child`,
7421
- last: () => `> :last-child`,
7422
- odd: () => `> :nth-child(odd)`,
7423
- even: () => `> :nth-child(even)`,
8443
+ first: () => "> :first-child",
8444
+ last: () => "> :last-child",
8445
+ odd: () => "> :nth-child(odd)",
8446
+ even: () => "> :nth-child(even)",
7424
8447
  not: arg => `> :not(${arg})`,
7425
8448
  number: arg => `> :nth-child(${arg})`
7426
8449
  };
@@ -7507,7 +8530,10 @@ function debounce(func) {
7507
8530
  }
7508
8531
  const context = this;
7509
8532
  callCount++;
8533
+
8534
+ // eslint-disable-next-line no-undef
7510
8535
  clearTimeout(timeout);
8536
+ // eslint-disable-next-line no-undef
7511
8537
  timeout = setTimeout(() => {
7512
8538
  const marker = performanceMonitor.start(`debounced:${func.name || "anonymous"}`);
7513
8539
  try {
@@ -7596,11 +8622,11 @@ function separateAndResolveCSS(arr) {
7596
8622
  }
7597
8623
  }
7598
8624
 
7599
- /**
7600
- * Process opacity modifier from class name (e.g., text-red-500/50 -> 50% opacity)
7601
- * @param {string} className - Class name with potential opacity modifier
7602
- * @param {string} cssDeclaration - CSS declaration to modify
7603
- * @returns {string} Modified CSS declaration with opacity applied
8625
+ /**
8626
+ * Process opacity modifier from class name (e.g., text-red-500/50 -> 50% opacity)
8627
+ * @param {string} className - Class name with potential opacity modifier
8628
+ * @param {string} cssDeclaration - CSS declaration to modify
8629
+ * @returns {string} Modified CSS declaration with opacity applied
7604
8630
  */
7605
8631
  function processOpacityModifier(className, cssDeclaration) {
7606
8632
  const opacityMatch = className.match(/\/(\d+)$/);
@@ -7661,11 +8687,11 @@ function processOpacityModifier(className, cssDeclaration) {
7661
8687
  return modifiedDeclaration;
7662
8688
  }
7663
8689
 
7664
- /**
7665
- * Convert Tailwind class string to inline CSS styles or JSON object
7666
- * @param {string} classNames - String containing Tailwind classes to convert
7667
- * @param {boolean} convertToJson - If true, result will be JSON object, if false becomes CSS string
7668
- * @returns {string|Object} Inline CSS string or style JSON object
8690
+ /**
8691
+ * Convert Tailwind class string to inline CSS styles or JSON object
8692
+ * @param {string} classNames - String containing Tailwind classes to convert
8693
+ * @param {boolean} convertToJson - If true, result will be JSON object, if false becomes CSS string
8694
+ * @returns {string|Object} Inline CSS string or style JSON object
7669
8695
  */
7670
8696
  function tws(classNames, convertToJson) {
7671
8697
  const totalMarker = performanceMonitor.start("tws:total");
@@ -8104,17 +9130,17 @@ function generateCssString(styles) {
8104
9130
  for (const subSel in content) {
8105
9131
  cssString += `${subSel}{${content[subSel].trim().replace(/\n/g, "")}}`;
8106
9132
  }
8107
- cssString += `}`;
9133
+ cssString += "}";
8108
9134
  }
8109
9135
  return cssString.trim();
8110
9136
  }
8111
9137
 
8112
- /**
8113
- * Generate CSS string from style object with SCSS-like syntax
8114
- * Supports nested selectors, state variants, responsive variants, and @css directives
8115
- * @param {Object} obj - Object with SCSS-like style format
8116
- * @param {Object} [options] - Additional options, e.g. { inject: true/false }
8117
- * @returns {string} Generated CSS string
9138
+ /**
9139
+ * Generate CSS string from style object with SCSS-like syntax
9140
+ * Supports nested selectors, state variants, responsive variants, and @css directives
9141
+ * @param {Object} obj - Object with SCSS-like style format
9142
+ * @param {Object} [options] - Additional options, e.g. { inject: true/false }
9143
+ * @returns {string} Generated CSS string
8118
9144
  */
8119
9145
  function twsx(obj) {
8120
9146
  let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
@@ -8168,9 +9194,9 @@ function twsx(obj) {
8168
9194
  // Process each selector
8169
9195
  const processMarker = performanceMonitor.start("twsx:process");
8170
9196
  for (const selector in flattered) {
8171
- let val = flattered[selector];
9197
+ const val = flattered[selector];
8172
9198
  let baseClass = "";
8173
- let nested = {};
9199
+ const nested = {};
8174
9200
  if (typeof val === "string") {
8175
9201
  // Check if this is a @css property value - if so, don't process through expandGroupedClass
8176
9202
  if (selector.includes(" @css ")) {
@@ -8259,19 +9285,19 @@ function autoInjectCss(cssString) {
8259
9285
  }
8260
9286
 
8261
9287
  // Enhanced debounced functions with performance monitoring configuration
8262
- /**
8263
- * Debounced version of tws function with performance monitoring
8264
- * @param {string} classNames - String containing Tailwind classes to convert
8265
- * @param {boolean} convertToJson - If true, result will be JSON object, if false becomes CSS string
8266
- * @returns {string|Object} Inline CSS string or style JSON object
9288
+ /**
9289
+ * Debounced version of tws function with performance monitoring
9290
+ * @param {string} classNames - String containing Tailwind classes to convert
9291
+ * @param {boolean} convertToJson - If true, result will be JSON object, if false becomes CSS string
9292
+ * @returns {string|Object} Inline CSS string or style JSON object
8267
9293
  */
8268
9294
  const debouncedTws = debounce(tws, 50); // Faster debounce for tws
8269
9295
 
8270
- /**
8271
- * Debounced version of twsx function with performance monitoring
8272
- * @param {Object} obj - Object with SCSS-like style format
8273
- * @param {Object} [options] - Additional options
8274
- * @returns {string} Generated CSS string
9296
+ /**
9297
+ * Debounced version of twsx function with performance monitoring
9298
+ * @param {Object} obj - Object with SCSS-like style format
9299
+ * @param {Object} [options] - Additional options
9300
+ * @returns {string} Generated CSS string
8275
9301
  */
8276
9302
  const debouncedTwsx = debounce(twsx, 100); // Standard debounce for twsx
8277
9303
 
@@ -8307,11 +9333,20 @@ const performanceUtils = {
8307
9333
  }
8308
9334
  };
8309
9335
 
9336
+ exports.DYNAMIC_TEMPLATES = DYNAMIC_TEMPLATES;
9337
+ exports.INLINE_ANIMATIONS = INLINE_ANIMATIONS;
8310
9338
  exports.LRUCache = LRUCache;
8311
9339
  exports.Logger = Logger;
8312
9340
  exports.TwsError = TwsError;
9341
+ exports.animateElement = animateElement;
9342
+ exports.applyDynamicAnimation = applyDynamicAnimation;
9343
+ exports.applyInlineAnimation = applyInlineAnimation;
9344
+ exports.applyWebAnimation = applyWebAnimation;
9345
+ exports.chainAnimations = chainAnimations;
8313
9346
  exports.configure = configure;
9347
+ exports.createDynamicAnimation = createDynamicAnimation;
8314
9348
  exports.createPlugin = createPlugin;
9349
+ exports.createTemplateAnimation = createTemplateAnimation;
8315
9350
  exports.createUtilityPlugin = createUtilityPlugin;
8316
9351
  exports.createVariantPlugin = createVariantPlugin;
8317
9352
  exports.debouncedTws = debouncedTws;
@@ -8319,10 +9354,12 @@ exports.debouncedTwsx = debouncedTwsx;
8319
9354
  exports.getConfig = getConfig;
8320
9355
  exports.getTailwindCache = getTailwindCache;
8321
9356
  exports.handleError = handleError;
9357
+ exports.initWebAnimations = initWebAnimations;
8322
9358
  exports.logger = logger;
8323
9359
  exports.onError = onError;
8324
9360
  exports.performanceUtils = performanceUtils;
8325
9361
  exports.resetConfig = resetConfig;
8326
9362
  exports.resetTailwindCache = resetTailwindCache;
9363
+ exports.staggerAnimations = staggerAnimations;
8327
9364
  exports.tws = tws;
8328
9365
  exports.twsx = twsx;