@frontfriend/tailwind 2.4.2 → 2.5.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/cli.js +40 -28
- package/dist/index.js +1 -1
- package/dist/index.js.map +2 -2
- package/dist/lib/core/component-downloader.js +2 -2
- package/dist/lib/core/component-downloader.js.map +3 -3
- package/dist/lib/core/token-processor.js +1 -1
- package/dist/lib/core/token-processor.js.map +3 -3
- package/dist/scripts/generate-icon-types.js +1 -1
- package/package.json +2 -2
- package/scripts/generate-icon-types.js +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../lib/core/errors.js", "../../../lib/core/token-processor.js"],
|
|
4
|
-
"sourcesContent": ["class APIError extends Error {\n constructor(message, statusCode, url) {\n super(message);\n this.name = 'APIError';\n this.statusCode = statusCode;\n this.url = url;\n this.code = `API_${statusCode}`;\n }\n}\n\nclass CacheError extends Error {\n constructor(message, operation) {\n super(message);\n this.name = 'CacheError';\n this.operation = operation;\n this.code = `CACHE_${operation.toUpperCase()}`;\n }\n}\n\nclass ConfigError extends Error {\n constructor(message, field) {\n super(message);\n this.name = 'ConfigError';\n this.field = field;\n this.code = `CONFIG_${field.toUpperCase()}`;\n }\n}\n\nclass ProcessingError extends Error {\n constructor(message, token) {\n super(message);\n this.name = 'ProcessingError';\n this.token = token;\n this.code = 'PROCESSING_ERROR';\n }\n}\n\nmodule.exports = {\n APIError,\n CacheError,\n ConfigError,\n ProcessingError\n};", "const Color = require('color');\nconst https = require('https');\nconst { ProcessingError } = require('./errors');\n\nclass TokenProcessor {\n /**\n * Convert hex color to HSL format for Tailwind CSS\n * @param {string} hex - Hex color value\n * @returns {string} HSL string in format \"H S% L%\"\n */\n hexToHsl(hex) {\n try {\n const color = Color(hex);\n const hsl = color.hsl();\n \n // Get HSL values\n const h = Math.round(hsl.hue());\n const s = Math.round(hsl.saturationl());\n const l = Math.round(hsl.lightness());\n \n // Handle alpha channel if present\n const alpha = color.alpha();\n if (alpha < 1) {\n // Round alpha to 2 decimal places\n const roundedAlpha = Math.round(alpha * 100) / 100;\n return `${h} ${s}% ${l}% / ${roundedAlpha}`;\n }\n \n return `${h} ${s}% ${l}%`;\n } catch (error) {\n throw new ProcessingError(`Failed to convert color ${hex}: ${error.message}`, hex);\n }\n }\n\n /**\n * Process color tokens into CSS variables\n * @param {Object} colorsData - Color tokens data\n * @returns {Object} Processed variables and color map\n */\n processColors(colorsData) {\n const variables = {};\n const colorMap = {};\n const utilities = {\n backgroundColor: {},\n textColor: {},\n borderColor: {}\n };\n\n // Check if we have valid color data\n if (!colorsData || typeof colorsData !== 'object') {\n console.log(' \u26A0\uFE0F No valid color data to process');\n return { variables, colorMap, utilities };\n }\n\n // Recursive function to process nested color structures\n const processColorGroup = (obj, prefix = '') => {\n for (const [key, value] of Object.entries(obj)) {\n if (value && typeof value === 'object') {\n if (value.$value) {\n // This is a color value\n const colorName = prefix ? `${prefix}-${key}` : key;\n const varName = `--color-${colorName}`;\n \n // Convert hex to HSL\n const hslValue = this.hexToHsl(value.$value);\n variables[varName] = hslValue;\n colorMap[colorName] = varName;\n \n // Generate Tailwind utilities\n utilities.backgroundColor[colorName] = `hsl(var(${varName}))`;\n utilities.textColor[colorName] = `hsl(var(${varName}))`;\n utilities.borderColor[colorName] = `hsl(var(${varName}))`;\n } else {\n // Nested structure, recurse\n const newPrefix = prefix ? `${prefix}-${key}` : key;\n processColorGroup(value, newPrefix);\n }\n }\n }\n };\n\n // Process colors - handle both nested and flat structures\n if (colorsData) {\n if (colorsData.colors) {\n processColorGroup(colorsData.colors);\n } else {\n // Direct color structure\n processColorGroup(colorsData);\n }\n }\n\n return {\n variables,\n colorMap,\n utilities\n };\n }\n\n /**\n * Process semantic tokens that reference other tokens\n * @param {Object} semanticData - Semantic tokens data\n * @param {Object} colorMap - Map of color names to CSS variables\n * @returns {Object} Semantic CSS variables and token utilities\n */\n processSemanticTokens(semanticData, colorMap) {\n const semanticVariables = {};\n const tokens = {\n backgroundColor: {},\n textColor: {},\n borderColor: {}\n };\n\n // Format token name (similar to current plugin)\n const formatTokenName = (name) => {\n return name.replace(/ /g, '').replace(/\\./g, '-').toLowerCase();\n };\n\n // Extract token reference from string like \"{colors.primary.500}\"\n const extractReference = (refString) => {\n // Handle non-string values\n if (typeof refString !== 'string') return null;\n \n const match = refString.match(/^\\{(.+)\\}$/);\n if (!match) return null;\n \n // Split the reference path and remove the first part if it's \"colors\"\n const parts = match[1].split('.');\n if (parts[0] === 'colors' && parts.length > 1) {\n // Check if second part is also \"colors\" (nested structure)\n if (parts[1] === 'colors' && parts.length > 2) {\n return parts.slice(2).join('-');\n }\n return parts.slice(1).join('-');\n }\n return parts.join('-');\n };\n\n // Process semantic category (bg, text, border)\n const processCategory = (category, outputCategory) => {\n if (!semanticData[category]) return;\n\n for (const [key, value] of Object.entries(semanticData[category])) {\n if (key === 'disabled') {\n // Handle disabled state specially\n const reference = extractReference(value.$value);\n if (reference) {\n const referencedVar = colorMap[reference];\n if (referencedVar) {\n const varName = `--${category}-disabled`;\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens[outputCategory]['disabled'] = `var(${varName})`;\n }\n }\n continue;\n }\n\n // Process nested structure (e.g., neutral -> low -> default)\n for (const [mainKey, mainValue] of Object.entries(value)) {\n for (const [stateKey, stateValue] of Object.entries(mainValue)) {\n let tokenKey = formatTokenName(`${key}-${mainKey}-${stateKey}`);\n \n // Remove '-default' suffix for cleaner class names\n if (tokenKey.endsWith('-default')) {\n tokenKey = tokenKey.slice(0, -8);\n }\n\n const varName = `--${category}-${tokenKey}`;\n \n // Check if it's a reference\n const reference = extractReference(stateValue.$value);\n if (reference) {\n // Look up the referenced color variable\n const referencedVar = colorMap[reference];\n if (referencedVar) {\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens[outputCategory][tokenKey] = `var(${varName})`;\n }\n } else if (stateValue.$value) {\n // Direct hex value - convert to HSL\n const hslValue = this.hexToHsl(stateValue.$value);\n semanticVariables[varName] = hslValue;\n tokens[outputCategory][tokenKey] = `hsl(var(${varName}))`;\n }\n }\n }\n }\n };\n\n // Process semantic categories\n processCategory('bg', 'backgroundColor');\n processCategory('text', 'textColor');\n processCategory('border', 'borderColor');\n\n // Process layer tokens\n if (semanticData.layer) {\n for (const [layerKey, layerValue] of Object.entries(semanticData.layer)) {\n const varName = `--layer-${layerKey}`;\n const reference = extractReference(layerValue.$value);\n \n if (reference) {\n // Format the reference to match semantic token naming\n let formattedRef = reference.replace(/\\./g, '-').toLowerCase();\n \n // Remove -default suffix if present\n if (formattedRef.endsWith('-default')) {\n formattedRef = formattedRef.slice(0, -8);\n }\n \n // Check if it's a semantic reference (e.g., bg-neutral-subtle)\n if (formattedRef.startsWith('bg-') || formattedRef.startsWith('text-') || formattedRef.startsWith('border-')) {\n // It's referencing a semantic token\n const semanticVar = `--${formattedRef}`;\n semanticVariables[varName] = `var(${semanticVar})`;\n tokens.backgroundColor[`layer-${layerKey}`] = `var(${varName})`;\n } else {\n // It's referencing a color token\n const referencedVar = colorMap[formattedRef];\n if (referencedVar) {\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens.backgroundColor[`layer-${layerKey}`] = `var(${varName})`;\n }\n }\n } else if (layerValue.$value) {\n // Direct value\n const hslValue = this.hexToHsl(layerValue.$value);\n semanticVariables[varName] = hslValue;\n tokens.backgroundColor[`layer-${layerKey}`] = `hsl(var(${varName}))`;\n }\n }\n }\n\n // Process overlay tokens\n if (semanticData.overlay) {\n for (const [overlayKey, overlayValue] of Object.entries(semanticData.overlay)) {\n const varName = `--overlay-${overlayKey}`;\n \n if (overlayValue.$value) {\n // Overlay values are hex colors with alpha, keep them as-is\n semanticVariables[varName] = overlayValue.$value;\n tokens.backgroundColor[`overlay-${overlayKey}`] = `var(${varName})`;\n }\n }\n }\n\n // Process icon tokens (map to text and fill colors)\n if (semanticData.icon) {\n // Ensure fill property exists\n if (!tokens.fill) {\n tokens.fill = {};\n }\n \n for (const [iconKey, iconValue] of Object.entries(semanticData.icon)) {\n if (iconKey === 'disabled') {\n const reference = extractReference(iconValue.$value);\n if (reference) {\n const referencedVar = colorMap[reference];\n if (referencedVar) {\n const varName = `--icon-disabled`;\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens.textColor['icon-disabled'] = `var(${varName})`;\n tokens.fill['icon-disabled'] = `var(${varName})`;\n }\n }\n continue;\n }\n\n for (const [mainKey, mainValue] of Object.entries(iconValue)) {\n for (const [stateKey, stateValue] of Object.entries(mainValue)) {\n let tokenKey = formatTokenName(`icon-${iconKey}-${mainKey}-${stateKey}`);\n if (tokenKey.endsWith('-default')) {\n tokenKey = tokenKey.slice(0, -8);\n }\n\n const varName = `--${tokenKey}`;\n const reference = extractReference(stateValue.$value);\n \n if (reference) {\n const referencedVar = colorMap[reference];\n if (referencedVar) {\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens.textColor[tokenKey] = `var(${varName})`;\n tokens.fill[tokenKey] = `var(${varName})`;\n }\n }\n }\n }\n }\n }\n\n return { semanticVariables, tokens };\n }\n\n /**\n * Fetch CSS from URL and parse font-face rules\n * @param {string} url - Font CSS URL\n * @returns {Promise<string>} Font face CSS\n */\n async fetchFontCss(url) {\n return new Promise((resolve, reject) => {\n https.get(url, (response) => {\n let data = '';\n \n if (response.statusCode !== 200) {\n reject(new Error(`Failed to fetch font CSS: ${response.statusCode}`));\n return;\n }\n\n response.on('data', (chunk) => {\n data += chunk;\n });\n\n response.on('end', () => {\n resolve(data);\n });\n\n response.on('error', (error) => {\n reject(error);\n });\n }).on('error', (error) => {\n reject(error);\n });\n });\n }\n\n /**\n * Parse font-face CSS into structured objects\n * @param {string} css - CSS text containing @font-face rules\n * @returns {Array} Array of font-face objects\n */\n parseFontFaces(css) {\n const fontFaceRegex = /@font-face\\s*{([^}]+)}/g;\n const fontFaces = [];\n let match;\n\n while ((match = fontFaceRegex.exec(css)) !== null) {\n const fontProperties = match[1].trim().split(';').filter(Boolean);\n const fontObj = {};\n\n fontProperties.forEach(prop => {\n const colonIndex = prop.indexOf(':');\n if (colonIndex !== -1) {\n const key = prop.slice(0, colonIndex).trim();\n const value = prop.slice(colonIndex + 1).trim();\n \n // Clean up quotes from font-family\n if (key === 'font-family') {\n fontObj[key] = value.replace(/[\"']/g, '');\n } else {\n fontObj[key] = value;\n }\n }\n });\n\n // Ensure src URLs are properly quoted\n if (fontObj['src']) {\n fontObj['src'] = fontObj['src']\n .replace(/url\\([\"']?/, 'url(\\'')\n .replace(/[\"']?\\)/, '\\')');\n }\n\n fontFaces.push(fontObj);\n }\n\n return fontFaces;\n }\n\n /**\n * Process fonts data\n * @param {Object} fontData - Font URLs object\n * @returns {Promise<Array>} Array of font-face objects\n */\n async processFonts(fontData) {\n const fontFaces = [];\n\n if (!fontData || typeof fontData !== 'object') {\n return fontFaces;\n }\n\n // Process each font URL (font, font2, etc.)\n const fontFields = Object.keys(fontData).filter(key => key.startsWith('font'));\n \n for (const field of fontFields) {\n const url = fontData[field];\n if (typeof url === 'string' && url.startsWith('http')) {\n try {\n const css = await this.fetchFontCss(url);\n const parsedFonts = this.parseFontFaces(css);\n \n if (parsedFonts.length > 0) {\n fontFaces.push(...parsedFonts);\n }\n } catch (error) {\n console.warn(`Failed to process font ${field}:`, error.message);\n }\n }\n }\n\n return fontFaces;\n }\n\n /**\n * Process font family tokens\n * @param {Object} globalTokens - Global tokens data containing font families\n * @returns {Object} Font family utilities\n */\n processFontFamilies(globalTokens) {\n const fontFamilyUtilities = {};\n \n if (!globalTokens || !globalTokens.font || !globalTokens.font.family) {\n return fontFamilyUtilities;\n }\n\n const fontFamilies = globalTokens.font.family;\n \n // Process each font family (primary, secondary, etc.)\n for (const [key, value] of Object.entries(fontFamilies)) {\n if (value && value.$value) {\n // Format the key (e.g., primary -> primary)\n const fontKey = key.toLowerCase();\n \n // Extract font family value\n let fontFamilyValue = value.$value;\n \n // If it's a reference, extract it\n if (typeof fontFamilyValue === 'string' && fontFamilyValue.startsWith('{') && fontFamilyValue.endsWith('}')) {\n // This is a reference, but for font families we usually have direct values\n fontFamilyValue = fontFamilyValue.slice(1, -1);\n }\n \n // Store the font family utility\n // Store the font family utility - ensure proper quoting for multi-word fonts\n // For Tailwind, we need to format font families properly\n \n // Capitalize the first letter of each word in font names for proper rendering\n const capitalizeFontName = (name) => {\n return name.split(' ').map(word => \n word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n ).join(' ');\n };\n \n // Check if it's already a font stack or needs quoting\n if (fontFamilyValue.includes(',')) {\n // It's already a font stack, use as is\n fontFamilyUtilities[fontKey] = fontFamilyValue;\n } else {\n // Capitalize the font name\n const capitalizedFont = capitalizeFontName(fontFamilyValue);\n \n if (capitalizedFont.includes(' ') && !capitalizedFont.startsWith('\"') && !capitalizedFont.startsWith(\"'\")) {\n // Multi-word font needs quotes, add generic fallback\n fontFamilyUtilities[fontKey] = `\"${capitalizedFont}\", sans-serif`;\n } else {\n // Single word font, add generic fallback\n fontFamilyUtilities[fontKey] = `${capitalizedFont}, sans-serif`;\n }\n }\n }\n }\n \n return fontFamilyUtilities;\n }\n\n /**\n * Process animations data\n * @param {Object} animationData - Animation definitions\n * @returns {Object} Keyframes and animation utilities\n */\n processAnimations(animationData) {\n const keyframes = {};\n const animations = {};\n\n if (!animationData || typeof animationData !== 'object') {\n return { keyframes, animations };\n }\n\n // Process each animation\n for (const [name, definition] of Object.entries(animationData)) {\n if (definition && typeof definition === 'object') {\n // Generate keyframe name\n const keyframeName = `${name}`;\n \n // Process keyframe steps\n if (definition.keyframes) {\n const keyframeSteps = {};\n \n for (const [step, props] of Object.entries(definition.keyframes)) {\n if (props && typeof props === 'object') {\n keyframeSteps[step] = props;\n }\n }\n \n keyframes[keyframeName] = keyframeSteps;\n }\n\n // Create animation utility\n const animationValue = [\n keyframeName,\n definition.duration || '1s',\n definition.easing || 'ease',\n definition.delay || '0s',\n definition.iterations || '1',\n definition.direction || 'normal',\n definition.fillMode || 'none'\n ].join(' ');\n\n animations[name] = animationValue;\n }\n }\n\n return { keyframes, animations };\n }\n\n /**\n * Generate safelist classes for Tailwind\n * @param {Object} tokens - All processed tokens\n * @returns {Array} Safelist patterns\n */\n generateSafelistClasses(tokens) {\n const safelist = [];\n const variants = ['hover:', 'focus:', 'active:', 'disabled:', 'dark:'];\n\n // Add semantic token utilities (bg-, text-, border-)\n if (tokens.backgroundColor) {\n for (const tokenName of Object.keys(tokens.backgroundColor)) {\n safelist.push(`bg-${tokenName}`);\n \n // Add variants\n variants.forEach(variant => {\n safelist.push(`${variant}bg-${tokenName}`);\n });\n }\n }\n\n if (tokens.textColor) {\n for (const tokenName of Object.keys(tokens.textColor)) {\n safelist.push(`text-${tokenName}`);\n \n // Add variants\n variants.forEach(variant => {\n safelist.push(`${variant}text-${tokenName}`);\n });\n }\n }\n\n if (tokens.borderColor) {\n for (const tokenName of Object.keys(tokens.borderColor)) {\n safelist.push(`border-${tokenName}`);\n \n // Add variants\n variants.forEach(variant => {\n safelist.push(`${variant}border-${tokenName}`);\n });\n }\n }\n\n // Add fill utilities (for icons)\n if (tokens.fill) {\n for (const tokenName of Object.keys(tokens.fill)) {\n safelist.push(`fill-${tokenName}`);\n \n // Also add text-icon-* classes\n if (tokenName.startsWith('icon-')) {\n safelist.push(`text-${tokenName}`);\n }\n }\n }\n\n // Add font family utilities\n if (tokens.fontFamily) {\n for (const fontName of Object.keys(tokens.fontFamily)) {\n safelist.push(`font-${fontName}`);\n }\n }\n\n // Add animation classes\n if (tokens.animations) {\n for (const animationName of Object.keys(tokens.animations)) {\n safelist.push(`animate-${animationName}`);\n }\n }\n\n return safelist;\n }\n\n /**\n * Extract unique classes from components configuration\n * @param {Object} componentsConfig - Components configuration object\n * @returns {Array} Array of unique class names\n */\n extractClassesFromComponentsConfig(componentsConfig) {\n const classSet = new Set();\n\n // Helper function to extract classes from a string\n const extractClasses = (classString) => {\n if (typeof classString === 'string') {\n // Split by spaces and filter out empty strings\n const classes = classString.split(/\\s+/).filter(c => c.length > 0);\n classes.forEach(cls => {\n // Skip variant selectors like [&>svg]:absolute\n classSet.add(cls);\n });\n }\n };\n\n // Recursive function to traverse the config object\n const traverse = (obj) => {\n if (!obj || typeof obj !== 'object') return;\n\n for (const key in obj) {\n const value = obj[key];\n \n if (typeof value === 'string') {\n extractClasses(value);\n } else if (typeof value === 'object') {\n traverse(value);\n }\n }\n };\n\n // Process the components config\n if (componentsConfig) {\n traverse(componentsConfig);\n }\n\n // Convert set to array and sort\n return Array.from(classSet).sort();\n }\n\n /**\n * Process custom CSS into a format compatible with Tailwind's addBase\n * @param {string} css - Raw CSS string\n * @returns {Object} CSS rules as object for Tailwind addBase\n */\n processCustomCss(css) {\n if (!css || typeof css !== 'string') {\n return {};\n }\n\n // Simply return the raw CSS as a string that can be added via addBase\n return { raw: css };\n }\n\n /**\n * Main orchestration method to process all token data\n * @param {Object} data - Complete token data from API\n * @returns {Promise<Object>} Processed token data\n */\n async process(data) {\n try {\n const result = {\n variables: {},\n semanticVariables: {},\n semanticDarkVariables: {},\n utilities: {},\n fontFaces: [],\n keyframes: {},\n animations: {},\n safelist: [],\n metadata: {},\n custom: data.customCss ? this.processCustomCss(data.customCss) : {}\n };\n\n // Handle different token formats (new vs legacy)\n let colorData = null;\n \n // Check if we have tokens in the new format\n if (data.tokens && typeof data.tokens === 'object') {\n // New format from processed-tokens endpoint\n const tokens = data.tokens;\n \n // Extract color data from various possible locations\n colorData = tokens['Global Colors/Default'] || \n tokens['Global Colors'] || \n tokens['colors'] ||\n tokens;\n } else if (data.colors) {\n // Legacy format or direct colors data\n colorData = data.colors;\n }\n\n // Process colors\n if (colorData) {\n const colorResult = this.processColors(colorData);\n result.variables = { ...result.variables, ...colorResult.variables };\n result.utilities = { ...result.utilities, ...colorResult.utilities };\n result.colorMap = colorResult.colorMap || {};\n } else {\n result.colorMap = {};\n }\n\n // Process semantic tokens (light mode)\n if (data.semantic && result.colorMap) {\n const semanticResult = this.processSemanticTokens(data.semantic, result.colorMap);\n result.semanticVariables = semanticResult.semanticVariables;\n // Merge tokens into utilities\n if (semanticResult.tokens) {\n result.tokens = semanticResult.tokens;\n // Replace color utilities with semantic token utilities\n result.utilities = semanticResult.tokens;\n }\n }\n\n // Process semantic tokens (dark mode)\n if (data.semanticDark && result.colorMap) {\n const semanticDarkResult = this.processSemanticTokens(data.semanticDark, result.colorMap);\n result.semanticDarkVariables = semanticDarkResult.semanticVariables;\n }\n\n // Process fonts\n if (data.fonts) {\n result.fontFaces = await this.processFonts(data.fonts);\n }\n\n // Process font families from global tokens\n if (data.globalTokens) {\n result.fontFamilies = this.processFontFamilies(data.globalTokens);\n \n // Add font family utilities\n if (result.fontFamilies) {\n if (!result.utilities.fontFamily) {\n result.utilities.fontFamily = {};\n }\n Object.assign(result.utilities.fontFamily, result.fontFamilies);\n }\n }\n\n // Process animations\n if (data.animations) {\n const animationResult = this.processAnimations(data.animations);\n result.keyframes = animationResult.keyframes;\n result.animations = animationResult.animations;\n }\n\n // Generate safelist from semantic tokens (not colorMap)\n // Pass the tokens object that contains backgroundColor, textColor, etc.\n result.safelist = this.generateSafelistClasses(result.tokens || result.utilities);\n\n // Add metadata\n result.metadata = {\n timestamp: new Date().toISOString(),\n version: data.version || '2.0.0',\n ffId: data.ffId\n };\n\n return result;\n } catch (error) {\n console.error('Error processing tokens:', error);\n throw error;\n }\n }\n}\n\nmodule.exports = TokenProcessor;"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["require_errors", "__commonJSMin", "exports", "module", "APIError", "message", "statusCode", "url", "CacheError", "operation", "ConfigError", "field", "ProcessingError", "token", "Color", "https", "ProcessingError", "TokenProcessor", "hex", "color", "hsl", "h", "s", "alpha", "roundedAlpha", "error", "colorsData", "variables", "colorMap", "utilities", "processColorGroup", "obj", "prefix", "key", "value", "colorName", "varName", "hslValue", "newPrefix", "semanticData", "semanticVariables", "tokens", "formatTokenName", "name", "extractReference", "refString", "match", "parts", "processCategory", "category", "outputCategory", "reference", "referencedVar", "mainKey", "mainValue", "stateKey", "stateValue", "tokenKey", "layerKey", "layerValue", "formattedRef", "semanticVar", "overlayKey", "overlayValue", "iconKey", "iconValue", "url", "resolve", "reject", "response", "data", "chunk", "css", "fontFaceRegex", "fontFaces", "fontProperties", "fontObj", "prop", "colonIndex", "fontData", "fontFields", "field", "parsedFonts", "globalTokens", "fontFamilyUtilities", "fontFamilies", "fontKey", "fontFamilyValue", "capitalizeFontName", "word", "capitalizedFont", "animationData", "keyframes", "animations", "definition", "keyframeName", "keyframeSteps", "step", "props", "animationValue", "safelist", "
|
|
4
|
+
"sourcesContent": ["class APIError extends Error {\n constructor(message, statusCode, url) {\n super(message);\n this.name = 'APIError';\n this.statusCode = statusCode;\n this.url = url;\n this.code = `API_${statusCode}`;\n }\n}\n\nclass CacheError extends Error {\n constructor(message, operation) {\n super(message);\n this.name = 'CacheError';\n this.operation = operation;\n this.code = `CACHE_${operation.toUpperCase()}`;\n }\n}\n\nclass ConfigError extends Error {\n constructor(message, field) {\n super(message);\n this.name = 'ConfigError';\n this.field = field;\n this.code = `CONFIG_${field.toUpperCase()}`;\n }\n}\n\nclass ProcessingError extends Error {\n constructor(message, token) {\n super(message);\n this.name = 'ProcessingError';\n this.token = token;\n this.code = 'PROCESSING_ERROR';\n }\n}\n\nmodule.exports = {\n APIError,\n CacheError,\n ConfigError,\n ProcessingError\n};", "const Color = require('color');\nconst https = require('https');\nconst { ProcessingError } = require('./errors');\n\nclass TokenProcessor {\n /**\n * Convert hex color to HSL format for Tailwind CSS\n * @param {string} hex - Hex color value\n * @returns {string} HSL string in format \"H S% L%\"\n */\n hexToHsl(hex) {\n try {\n const color = Color(hex);\n const hsl = color.hsl();\n \n // Get HSL values\n const h = Math.round(hsl.hue());\n const s = Math.round(hsl.saturationl());\n const l = Math.round(hsl.lightness());\n \n // Handle alpha channel if present\n const alpha = color.alpha();\n if (alpha < 1) {\n // Round alpha to 2 decimal places\n const roundedAlpha = Math.round(alpha * 100) / 100;\n return `${h} ${s}% ${l}% / ${roundedAlpha}`;\n }\n \n return `${h} ${s}% ${l}%`;\n } catch (error) {\n throw new ProcessingError(`Failed to convert color ${hex}: ${error.message}`, hex);\n }\n }\n\n /**\n * Process color tokens into CSS variables\n * @param {Object} colorsData - Color tokens data\n * @returns {Object} Processed variables and color map\n */\n processColors(colorsData) {\n const variables = {};\n const colorMap = {};\n const utilities = {\n backgroundColor: {},\n textColor: {},\n borderColor: {}\n };\n\n // Check if we have valid color data\n if (!colorsData || typeof colorsData !== 'object') {\n console.log(' \u26A0\uFE0F No valid color data to process');\n return { variables, colorMap, utilities };\n }\n\n // Recursive function to process nested color structures\n const processColorGroup = (obj, prefix = '') => {\n for (const [key, value] of Object.entries(obj)) {\n if (value && typeof value === 'object') {\n if (value.$value) {\n // This is a color value\n const colorName = prefix ? `${prefix}-${key}` : key;\n const varName = `--color-${colorName}`;\n \n // Convert hex to HSL\n const hslValue = this.hexToHsl(value.$value);\n variables[varName] = hslValue;\n colorMap[colorName] = varName;\n \n // Generate Tailwind utilities\n utilities.backgroundColor[colorName] = `hsl(var(${varName}))`;\n utilities.textColor[colorName] = `hsl(var(${varName}))`;\n utilities.borderColor[colorName] = `hsl(var(${varName}))`;\n } else {\n // Nested structure, recurse\n const newPrefix = prefix ? `${prefix}-${key}` : key;\n processColorGroup(value, newPrefix);\n }\n }\n }\n };\n\n // Process colors - handle both nested and flat structures\n if (colorsData) {\n if (colorsData.colors) {\n processColorGroup(colorsData.colors);\n } else {\n // Direct color structure\n processColorGroup(colorsData);\n }\n }\n\n return {\n variables,\n colorMap,\n utilities\n };\n }\n\n /**\n * Process semantic tokens that reference other tokens\n * @param {Object} semanticData - Semantic tokens data\n * @param {Object} colorMap - Map of color names to CSS variables\n * @returns {Object} Semantic CSS variables and token utilities\n */\n processSemanticTokens(semanticData, colorMap) {\n const semanticVariables = {};\n const tokens = {\n backgroundColor: {},\n textColor: {},\n borderColor: {}\n };\n\n // Format token name (similar to current plugin)\n const formatTokenName = (name) => {\n return name.replace(/ /g, '').replace(/\\./g, '-').toLowerCase();\n };\n\n // Extract token reference from string like \"{colors.primary.500}\"\n const extractReference = (refString) => {\n // Handle non-string values\n if (typeof refString !== 'string') return null;\n \n const match = refString.match(/^\\{(.+)\\}$/);\n if (!match) return null;\n \n // Split the reference path and remove the first part if it's \"colors\"\n const parts = match[1].split('.');\n if (parts[0] === 'colors' && parts.length > 1) {\n // Check if second part is also \"colors\" (nested structure)\n if (parts[1] === 'colors' && parts.length > 2) {\n return parts.slice(2).join('-');\n }\n return parts.slice(1).join('-');\n }\n return parts.join('-');\n };\n\n // Process semantic category (bg, text, border)\n const processCategory = (category, outputCategory) => {\n if (!semanticData[category]) return;\n\n for (const [key, value] of Object.entries(semanticData[category])) {\n if (key === 'disabled') {\n // Handle disabled state specially\n const reference = extractReference(value.$value);\n if (reference) {\n const referencedVar = colorMap[reference];\n if (referencedVar) {\n const varName = `--${category}-disabled`;\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens[outputCategory]['disabled'] = `var(${varName})`;\n }\n }\n continue;\n }\n\n // Process nested structure (e.g., neutral -> low -> default)\n for (const [mainKey, mainValue] of Object.entries(value)) {\n for (const [stateKey, stateValue] of Object.entries(mainValue)) {\n let tokenKey = formatTokenName(`${key}-${mainKey}-${stateKey}`);\n \n // Remove '-default' suffix for cleaner class names\n if (tokenKey.endsWith('-default')) {\n tokenKey = tokenKey.slice(0, -8);\n }\n\n const varName = `--${category}-${tokenKey}`;\n \n // Check if it's a reference\n const reference = extractReference(stateValue.$value);\n if (reference) {\n // Look up the referenced color variable\n const referencedVar = colorMap[reference];\n if (referencedVar) {\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens[outputCategory][tokenKey] = `var(${varName})`;\n }\n } else if (stateValue.$value) {\n // Direct hex value - convert to HSL\n const hslValue = this.hexToHsl(stateValue.$value);\n semanticVariables[varName] = hslValue;\n tokens[outputCategory][tokenKey] = `hsl(var(${varName}))`;\n }\n }\n }\n }\n };\n\n // Process semantic categories\n processCategory('bg', 'backgroundColor');\n processCategory('text', 'textColor');\n processCategory('border', 'borderColor');\n\n // Process layer tokens\n if (semanticData.layer) {\n for (const [layerKey, layerValue] of Object.entries(semanticData.layer)) {\n const varName = `--layer-${layerKey}`;\n const reference = extractReference(layerValue.$value);\n \n if (reference) {\n // Format the reference to match semantic token naming\n let formattedRef = reference.replace(/\\./g, '-').toLowerCase();\n \n // Remove -default suffix if present\n if (formattedRef.endsWith('-default')) {\n formattedRef = formattedRef.slice(0, -8);\n }\n \n // Check if it's a semantic reference (e.g., bg-neutral-subtle)\n if (formattedRef.startsWith('bg-') || formattedRef.startsWith('text-') || formattedRef.startsWith('border-')) {\n // It's referencing a semantic token\n const semanticVar = `--${formattedRef}`;\n semanticVariables[varName] = `var(${semanticVar})`;\n tokens.backgroundColor[`layer-${layerKey}`] = `var(${varName})`;\n } else {\n // It's referencing a color token\n const referencedVar = colorMap[formattedRef];\n if (referencedVar) {\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens.backgroundColor[`layer-${layerKey}`] = `var(${varName})`;\n }\n }\n } else if (layerValue.$value) {\n // Direct value\n const hslValue = this.hexToHsl(layerValue.$value);\n semanticVariables[varName] = hslValue;\n tokens.backgroundColor[`layer-${layerKey}`] = `hsl(var(${varName}))`;\n }\n }\n }\n\n // Process overlay tokens\n if (semanticData.overlay) {\n for (const [overlayKey, overlayValue] of Object.entries(semanticData.overlay)) {\n const varName = `--overlay-${overlayKey}`;\n \n if (overlayValue.$value) {\n // Overlay values are hex colors with alpha, keep them as-is\n semanticVariables[varName] = overlayValue.$value;\n tokens.backgroundColor[`overlay-${overlayKey}`] = `var(${varName})`;\n }\n }\n }\n\n // Process icon tokens (map to text and fill colors)\n if (semanticData.icon) {\n // Ensure fill property exists\n if (!tokens.fill) {\n tokens.fill = {};\n }\n \n for (const [iconKey, iconValue] of Object.entries(semanticData.icon)) {\n if (iconKey === 'disabled') {\n const reference = extractReference(iconValue.$value);\n if (reference) {\n const referencedVar = colorMap[reference];\n if (referencedVar) {\n const varName = `--icon-disabled`;\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens.textColor['icon-disabled'] = `var(${varName})`;\n tokens.fill['icon-disabled'] = `var(${varName})`;\n }\n }\n continue;\n }\n\n for (const [mainKey, mainValue] of Object.entries(iconValue)) {\n for (const [stateKey, stateValue] of Object.entries(mainValue)) {\n let tokenKey = formatTokenName(`icon-${iconKey}-${mainKey}-${stateKey}`);\n if (tokenKey.endsWith('-default')) {\n tokenKey = tokenKey.slice(0, -8);\n }\n\n const varName = `--${tokenKey}`;\n const reference = extractReference(stateValue.$value);\n \n if (reference) {\n const referencedVar = colorMap[reference];\n if (referencedVar) {\n semanticVariables[varName] = `var(${referencedVar})`;\n tokens.textColor[tokenKey] = `var(${varName})`;\n tokens.fill[tokenKey] = `var(${varName})`;\n }\n }\n }\n }\n }\n }\n\n return { semanticVariables, tokens };\n }\n\n /**\n * Fetch CSS from URL and parse font-face rules\n * @param {string} url - Font CSS URL\n * @returns {Promise<string>} Font face CSS\n */\n async fetchFontCss(url) {\n return new Promise((resolve, reject) => {\n https.get(url, (response) => {\n let data = '';\n \n if (response.statusCode !== 200) {\n reject(new Error(`Failed to fetch font CSS: ${response.statusCode}`));\n return;\n }\n\n response.on('data', (chunk) => {\n data += chunk;\n });\n\n response.on('end', () => {\n resolve(data);\n });\n\n response.on('error', (error) => {\n reject(error);\n });\n }).on('error', (error) => {\n reject(error);\n });\n });\n }\n\n /**\n * Parse font-face CSS into structured objects\n * @param {string} css - CSS text containing @font-face rules\n * @returns {Array} Array of font-face objects\n */\n parseFontFaces(css) {\n const fontFaceRegex = /@font-face\\s*{([^}]+)}/g;\n const fontFaces = [];\n let match;\n\n while ((match = fontFaceRegex.exec(css)) !== null) {\n const fontProperties = match[1].trim().split(';').filter(Boolean);\n const fontObj = {};\n\n fontProperties.forEach(prop => {\n const colonIndex = prop.indexOf(':');\n if (colonIndex !== -1) {\n const key = prop.slice(0, colonIndex).trim();\n const value = prop.slice(colonIndex + 1).trim();\n \n // Clean up quotes from font-family\n if (key === 'font-family') {\n fontObj[key] = value.replace(/[\"']/g, '');\n } else {\n fontObj[key] = value;\n }\n }\n });\n\n // Ensure src URLs are properly quoted\n if (fontObj['src']) {\n fontObj['src'] = fontObj['src']\n .replace(/url\\([\"']?/, 'url(\\'')\n .replace(/[\"']?\\)/, '\\')');\n }\n\n fontFaces.push(fontObj);\n }\n\n return fontFaces;\n }\n\n /**\n * Process fonts data\n * @param {Object} fontData - Font URLs object\n * @returns {Promise<Array>} Array of font-face objects\n */\n async processFonts(fontData) {\n const fontFaces = [];\n\n if (!fontData || typeof fontData !== 'object') {\n return fontFaces;\n }\n\n // Process each font URL (font, font2, etc.)\n const fontFields = Object.keys(fontData).filter(key => key.startsWith('font'));\n \n for (const field of fontFields) {\n const url = fontData[field];\n if (typeof url === 'string' && url.startsWith('http')) {\n try {\n const css = await this.fetchFontCss(url);\n const parsedFonts = this.parseFontFaces(css);\n \n if (parsedFonts.length > 0) {\n fontFaces.push(...parsedFonts);\n }\n } catch (error) {\n console.warn(`Failed to process font ${field}:`, error.message);\n }\n }\n }\n\n return fontFaces;\n }\n\n /**\n * Process font family tokens\n * @param {Object} globalTokens - Global tokens data containing font families\n * @returns {Object} Font family utilities\n */\n processFontFamilies(globalTokens) {\n const fontFamilyUtilities = {};\n \n if (!globalTokens || !globalTokens.font || !globalTokens.font.family) {\n return fontFamilyUtilities;\n }\n\n const fontFamilies = globalTokens.font.family;\n \n // Process each font family (primary, secondary, etc.)\n for (const [key, value] of Object.entries(fontFamilies)) {\n if (value && value.$value) {\n // Format the key (e.g., primary -> primary)\n const fontKey = key.toLowerCase();\n \n // Extract font family value\n let fontFamilyValue = value.$value;\n \n // If it's a reference, extract it\n if (typeof fontFamilyValue === 'string' && fontFamilyValue.startsWith('{') && fontFamilyValue.endsWith('}')) {\n // This is a reference, but for font families we usually have direct values\n fontFamilyValue = fontFamilyValue.slice(1, -1);\n }\n \n // Store the font family utility\n // Store the font family utility - ensure proper quoting for multi-word fonts\n // For Tailwind, we need to format font families properly\n \n // Capitalize the first letter of each word in font names for proper rendering\n const capitalizeFontName = (name) => {\n return name.split(' ').map(word => \n word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n ).join(' ');\n };\n \n // Check if it's already a font stack or needs quoting\n if (fontFamilyValue.includes(',')) {\n // It's already a font stack, use as is\n fontFamilyUtilities[fontKey] = fontFamilyValue;\n } else {\n // Capitalize the font name\n const capitalizedFont = capitalizeFontName(fontFamilyValue);\n \n if (capitalizedFont.includes(' ') && !capitalizedFont.startsWith('\"') && !capitalizedFont.startsWith(\"'\")) {\n // Multi-word font needs quotes, add generic fallback\n fontFamilyUtilities[fontKey] = `\"${capitalizedFont}\", sans-serif`;\n } else {\n // Single word font, add generic fallback\n fontFamilyUtilities[fontKey] = `${capitalizedFont}, sans-serif`;\n }\n }\n }\n }\n \n return fontFamilyUtilities;\n }\n\n /**\n * Process animations data\n * @param {Object} animationData - Animation definitions\n * @returns {Object} Keyframes and animation utilities\n */\n processAnimations(animationData) {\n const keyframes = {};\n const animations = {};\n\n if (!animationData || typeof animationData !== 'object') {\n return { keyframes, animations };\n }\n\n // Process each animation\n for (const [name, definition] of Object.entries(animationData)) {\n if (definition && typeof definition === 'object') {\n // Generate keyframe name\n const keyframeName = `${name}`;\n \n // Process keyframe steps\n if (definition.keyframes) {\n const keyframeSteps = {};\n \n for (const [step, props] of Object.entries(definition.keyframes)) {\n if (props && typeof props === 'object') {\n keyframeSteps[step] = props;\n }\n }\n \n keyframes[keyframeName] = keyframeSteps;\n }\n\n // Create animation utility\n const animationValue = [\n keyframeName,\n definition.duration || '1s',\n definition.easing || 'ease',\n definition.delay || '0s',\n definition.iterations || '1',\n definition.direction || 'normal',\n definition.fillMode || 'none'\n ].join(' ');\n\n animations[name] = animationValue;\n }\n }\n\n return { keyframes, animations };\n }\n\n /**\n * Generate safelist classes for Tailwind\n * @param {Object} tokens - All processed tokens\n * @returns {Array} Safelist patterns\n */\n generateSafelistClasses(tokens) {\n const safelist = [];\n\n // Add semantic token utilities (bg-, text-, border-)\n // Note: Only base classes are added to safelist. Variants (hover:, focus:, etc.)\n // are detected by Tailwind's JIT when actually used in components.\n // This prevents generation of invalid CSS selector combinations with Turbopack.\n if (tokens.backgroundColor) {\n for (const tokenName of Object.keys(tokens.backgroundColor)) {\n safelist.push(`bg-${tokenName}`);\n }\n }\n\n if (tokens.textColor) {\n for (const tokenName of Object.keys(tokens.textColor)) {\n safelist.push(`text-${tokenName}`);\n }\n }\n\n if (tokens.borderColor) {\n for (const tokenName of Object.keys(tokens.borderColor)) {\n safelist.push(`border-${tokenName}`);\n }\n }\n\n // Add fill utilities (for icons)\n if (tokens.fill) {\n for (const tokenName of Object.keys(tokens.fill)) {\n safelist.push(`fill-${tokenName}`);\n \n // Also add text-icon-* classes\n if (tokenName.startsWith('icon-')) {\n safelist.push(`text-${tokenName}`);\n }\n }\n }\n\n // Add font family utilities\n if (tokens.fontFamily) {\n for (const fontName of Object.keys(tokens.fontFamily)) {\n safelist.push(`font-${fontName}`);\n }\n }\n\n // Add animation classes\n if (tokens.animations) {\n for (const animationName of Object.keys(tokens.animations)) {\n safelist.push(`animate-${animationName}`);\n }\n }\n\n return safelist;\n }\n\n /**\n * Extract unique classes from components configuration\n * @param {Object} componentsConfig - Components configuration object\n * @returns {Array} Array of unique class names\n */\n extractClassesFromComponentsConfig(componentsConfig) {\n const classSet = new Set();\n\n // Helper function to extract classes from a string\n const extractClasses = (classString) => {\n if (typeof classString === 'string') {\n // Split by spaces and filter out empty strings\n const classes = classString.split(/\\s+/).filter(c => c.length > 0);\n classes.forEach(cls => {\n // Skip variant selectors like [&>svg]:absolute\n classSet.add(cls);\n });\n }\n };\n\n // Recursive function to traverse the config object\n const traverse = (obj) => {\n if (!obj || typeof obj !== 'object') return;\n\n for (const key in obj) {\n const value = obj[key];\n \n if (typeof value === 'string') {\n extractClasses(value);\n } else if (typeof value === 'object') {\n traverse(value);\n }\n }\n };\n\n // Process the components config\n if (componentsConfig) {\n traverse(componentsConfig);\n }\n\n // Convert set to array and sort\n return Array.from(classSet).sort();\n }\n\n /**\n * Process custom CSS into a format compatible with Tailwind's addBase\n * @param {string} css - Raw CSS string\n * @returns {Object} CSS rules as object for Tailwind addBase\n */\n processCustomCss(css) {\n if (!css || typeof css !== 'string') {\n return {};\n }\n\n // Simply return the raw CSS as a string that can be added via addBase\n return { raw: css };\n }\n\n /**\n * Main orchestration method to process all token data\n * @param {Object} data - Complete token data from API\n * @returns {Promise<Object>} Processed token data\n */\n async process(data) {\n try {\n const result = {\n variables: {},\n semanticVariables: {},\n semanticDarkVariables: {},\n utilities: {},\n fontFaces: [],\n keyframes: {},\n animations: {},\n safelist: [],\n metadata: {},\n custom: data.customCss ? this.processCustomCss(data.customCss) : {}\n };\n\n // Handle different token formats (new vs legacy)\n let colorData = null;\n \n // Check if we have tokens in the new format\n if (data.tokens && typeof data.tokens === 'object') {\n // New format from processed-tokens endpoint\n const tokens = data.tokens;\n \n // Extract color data from various possible locations\n colorData = tokens['Global Colors/Default'] || \n tokens['Global Colors'] || \n tokens['colors'] ||\n tokens;\n } else if (data.colors) {\n // Legacy format or direct colors data\n colorData = data.colors;\n }\n\n // Process colors\n if (colorData) {\n const colorResult = this.processColors(colorData);\n result.variables = { ...result.variables, ...colorResult.variables };\n result.utilities = { ...result.utilities, ...colorResult.utilities };\n result.colorMap = colorResult.colorMap || {};\n } else {\n result.colorMap = {};\n }\n\n // Process semantic tokens (light mode)\n if (data.semantic && result.colorMap) {\n const semanticResult = this.processSemanticTokens(data.semantic, result.colorMap);\n result.semanticVariables = semanticResult.semanticVariables;\n // Merge tokens into utilities\n if (semanticResult.tokens) {\n result.tokens = semanticResult.tokens;\n // Replace color utilities with semantic token utilities\n result.utilities = semanticResult.tokens;\n }\n }\n\n // Process semantic tokens (dark mode)\n if (data.semanticDark && result.colorMap) {\n const semanticDarkResult = this.processSemanticTokens(data.semanticDark, result.colorMap);\n result.semanticDarkVariables = semanticDarkResult.semanticVariables;\n }\n\n // Process fonts\n if (data.fonts) {\n result.fontFaces = await this.processFonts(data.fonts);\n }\n\n // Process font families from global tokens\n if (data.globalTokens) {\n result.fontFamilies = this.processFontFamilies(data.globalTokens);\n \n // Add font family utilities\n if (result.fontFamilies) {\n if (!result.utilities.fontFamily) {\n result.utilities.fontFamily = {};\n }\n Object.assign(result.utilities.fontFamily, result.fontFamilies);\n }\n }\n\n // Process animations\n if (data.animations) {\n const animationResult = this.processAnimations(data.animations);\n result.keyframes = animationResult.keyframes;\n result.animations = animationResult.animations;\n }\n\n // Generate safelist from semantic tokens (not colorMap)\n // Pass the tokens object that contains backgroundColor, textColor, etc.\n result.safelist = this.generateSafelistClasses(result.tokens || result.utilities);\n\n // Add metadata\n result.metadata = {\n timestamp: new Date().toISOString(),\n version: data.version || '2.0.0',\n ffId: data.ffId\n };\n\n return result;\n } catch (error) {\n console.error('Error processing tokens:', error);\n throw error;\n }\n }\n}\n\nmodule.exports = TokenProcessor;"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["require_errors", "__commonJSMin", "exports", "module", "APIError", "message", "statusCode", "url", "CacheError", "operation", "ConfigError", "field", "ProcessingError", "token", "Color", "https", "ProcessingError", "TokenProcessor", "hex", "color", "hsl", "h", "s", "alpha", "roundedAlpha", "error", "colorsData", "variables", "colorMap", "utilities", "processColorGroup", "obj", "prefix", "key", "value", "colorName", "varName", "hslValue", "newPrefix", "semanticData", "semanticVariables", "tokens", "formatTokenName", "name", "extractReference", "refString", "match", "parts", "processCategory", "category", "outputCategory", "reference", "referencedVar", "mainKey", "mainValue", "stateKey", "stateValue", "tokenKey", "layerKey", "layerValue", "formattedRef", "semanticVar", "overlayKey", "overlayValue", "iconKey", "iconValue", "url", "resolve", "reject", "response", "data", "chunk", "css", "fontFaceRegex", "fontFaces", "fontProperties", "fontObj", "prop", "colonIndex", "fontData", "fontFields", "field", "parsedFonts", "globalTokens", "fontFamilyUtilities", "fontFamilies", "fontKey", "fontFamilyValue", "capitalizeFontName", "word", "capitalizedFont", "animationData", "keyframes", "animations", "definition", "keyframeName", "keyframeSteps", "step", "props", "animationValue", "safelist", "tokenName", "fontName", "animationName", "componentsConfig", "classSet", "extractClasses", "classString", "c", "cls", "traverse", "result", "colorData", "colorResult", "semanticResult", "semanticDarkResult", "animationResult"]
|
|
7
7
|
}
|
|
@@ -15,7 +15,7 @@ function generateIconTypes(options = {}) {
|
|
|
15
15
|
|
|
16
16
|
// Check if icons.json exists
|
|
17
17
|
if (!fs.existsSync(iconsPath)) {
|
|
18
|
-
console.error('[FrontFriend] Error: icons.json not found. Please run "npx frontfriend
|
|
18
|
+
console.error('[FrontFriend] Error: icons.json not found. Please run "npx frontfriend init" first.');
|
|
19
19
|
process.exit(1);
|
|
20
20
|
}
|
|
21
21
|
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@frontfriend/tailwind",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.5.1",
|
|
4
4
|
"description": "Design token management for Tailwind CSS",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"types": "./dist/types/index.d.ts",
|
|
@@ -74,4 +74,4 @@
|
|
|
74
74
|
"esbuild": "^0.19.0",
|
|
75
75
|
"glob": "^10.0.0"
|
|
76
76
|
}
|
|
77
|
-
}
|
|
77
|
+
}
|
|
@@ -15,7 +15,7 @@ function generateIconTypes(options = {}) {
|
|
|
15
15
|
|
|
16
16
|
// Check if icons.json exists
|
|
17
17
|
if (!fs.existsSync(iconsPath)) {
|
|
18
|
-
console.error('[FrontFriend] Error: icons.json not found. Please run "npx frontfriend
|
|
18
|
+
console.error('[FrontFriend] Error: icons.json not found. Please run "npx frontfriend init" first.');
|
|
19
19
|
process.exit(1);
|
|
20
20
|
}
|
|
21
21
|
|