@nlabs/lex 1.48.0 → 1.48.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.
@@ -1,6 +1,7 @@
1
1
  import findFileUp from "find-file-up";
2
- import { existsSync } from "fs";
3
- import { resolve as pathResolve } from "path";
2
+ import { existsSync, readFileSync } from "fs";
3
+ import { resolve as pathResolve, dirname } from "path";
4
+ import { sync as globSync } from "glob";
4
5
  import { LexConfig } from "../LexConfig.js";
5
6
  function getDirName() {
6
7
  try {
@@ -20,12 +21,49 @@ function getFilePath(relativePath) {
20
21
  }
21
22
  }
22
23
  function getLexPackageJsonPath() {
23
- try {
24
- const lexRoot = eval('require("path").dirname(require("url").fileURLToPath(import.meta.url))');
25
- return pathResolve(lexRoot, "../../package.json");
26
- } catch {
27
- return pathResolve(process.cwd(), "package.json");
24
+ const LEX_PACKAGE_NAME = "@nlabs/lex";
25
+ let startDir;
26
+ if (process.env.LEX_ROOT) {
27
+ startDir = process.env.LEX_ROOT;
28
+ } else {
29
+ try {
30
+ startDir = eval('new URL(".", import.meta.url).pathname');
31
+ } catch (err1) {
32
+ try {
33
+ startDir = eval('__filename ? require("path").dirname(__filename) : null');
34
+ if (!startDir) {
35
+ throw new Error("__filename not available");
36
+ }
37
+ } catch (err2) {
38
+ try {
39
+ if (process.argv[1] && !process.argv[1].includes("node")) {
40
+ startDir = dirname(process.argv[1]);
41
+ } else {
42
+ throw new Error("process.argv[1] not suitable");
43
+ }
44
+ } catch (err3) {
45
+ startDir = process.cwd();
46
+ }
47
+ }
48
+ }
28
49
  }
50
+ let dir = startDir;
51
+ for (let i = 0; i < 8; i++) {
52
+ const pkgPath = pathResolve(dir, "package.json");
53
+ if (existsSync(pkgPath)) {
54
+ try {
55
+ const pkg = JSON.parse(readFileSync(pkgPath, "utf8"));
56
+ if (pkg.name === LEX_PACKAGE_NAME) {
57
+ return pkgPath;
58
+ }
59
+ } catch (error) {
60
+ }
61
+ }
62
+ const parent = dirname(dir);
63
+ if (parent === dir) break;
64
+ dir = parent;
65
+ }
66
+ return pathResolve(process.cwd(), "package.json");
29
67
  }
30
68
  const relativeFilePath = (filename, dirPath = "./", backUp = 0) => {
31
69
  const nestDepth = 10;
@@ -90,8 +128,8 @@ const resolveBinaryPath = (binaryName, packageName) => {
90
128
  return lexPackageBinCjsPath;
91
129
  }
92
130
  }
93
- const checkBinUp = (startDir) => {
94
- let checkDir = startDir;
131
+ const checkBinUp = (startDir2) => {
132
+ let checkDir = startDir2;
95
133
  for (let i = 0; i < 5; i++) {
96
134
  const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);
97
135
  if (existsSync(monorepoBinPath)) {
@@ -115,7 +153,21 @@ const resolveBinaryPath = (binaryName, packageName) => {
115
153
  }
116
154
  return "";
117
155
  };
156
+ const findTailwindCssPath = () => {
157
+ const tailwindPatterns = ["**/tailwind.css"];
158
+ for (const pattern of tailwindPatterns) {
159
+ const files = globSync(pattern, {
160
+ cwd: process.cwd(),
161
+ ignore: ["**/node_modules/**", "**/dist/**", "**/build/**", "**/.storybook/**"]
162
+ });
163
+ if (files.length > 0) {
164
+ return pathResolve(process.cwd(), files[0]);
165
+ }
166
+ }
167
+ return "";
168
+ };
118
169
  export {
170
+ findTailwindCssPath,
119
171
  getDirName,
120
172
  getFilePath,
121
173
  getLexPackageJsonPath,
@@ -124,4 +176,4 @@ export {
124
176
  relativeNodePath,
125
177
  resolveBinaryPath
126
178
  };
127
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/utils/file.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport findFileUp from 'find-file-up';\nimport {existsSync} from 'fs';\nimport {resolve as pathResolve} from 'path';\n\n\nimport {LexConfig} from '../LexConfig.js';\n\n/**\n * Safely get directory name that works in both ESM and Jest environments\n */\nexport function getDirName(): string {\n  try {\n    // Only works in ESM environments\n    // eslint-disable-next-line no-eval\n    return eval('new URL(\".\", import.meta.url).pathname');\n  } catch {\n    // Fallback for Jest or CJS\n    return process.cwd();\n  }\n}\n\n/**\n * Safely get file path that works in both ESM and Jest environments\n */\nexport function getFilePath(relativePath: string): string {\n  try {\n    // Only works in ESM environments\n    // eslint-disable-next-line no-eval\n    return eval('require(\"url\").fileURLToPath(new URL(relativePath, import.meta.url))');\n  } catch {\n    // Fallback for Jest or CJS\n    if(relativePath === '../../../package.json') {\n      return pathResolve(process.cwd(), 'package.json');\n    }\n    return pathResolve(process.cwd(), relativePath);\n  }\n}\n\n/**\n * Get the path to Lex's own package.json, regardless of CWD\n */\nexport function getLexPackageJsonPath(): string {\n  try {\n    // This will always resolve to Lex's own package.json, regardless of CWD\n    // eslint-disable-next-line no-eval\n    const lexRoot = eval('require(\"path\").dirname(require(\"url\").fileURLToPath(import.meta.url))');\n    return pathResolve(lexRoot, '../../package.json');\n  } catch {\n    // Fallback for Jest or CJS environments\n    return pathResolve(process.cwd(), 'package.json');\n  }\n}\n\n// Get file paths relative to Lex\nexport const relativeFilePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(filename, dirPath, nestDepth);\n    const previousPath: string = Array(backUp).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(filename, dirPath, nestDepth);\n};\n\nexport const relativeNodePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n  const modulePath = `node_modules/${filename}`;\n\n  // First, check the Lex package's node_modules directory\n  if(dirPath !== './') {\n    const lexModulePath = pathResolve(dirPath, modulePath);\n    if(existsSync(lexModulePath)) {\n      return lexModulePath;\n    }\n  }\n\n  // Second, check the user's project node_modules directory\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  // Original implementation as fallback\n  if(backUp) {\n    const filePath: string = findFileUp.sync(modulePath, dirPath, nestDepth);\n    const previousPath: string = Array(nestDepth).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(modulePath, dirPath, nestDepth) || `/node_modules/${filename}`;\n};\n\n// Get file paths relative to Lex\nexport const getNodePath = (moduleName: string): string => {\n  const dirName = getDirName();\n  const modulePath: string = `node_modules/${moduleName}`;\n\n  // Try project root first\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  // Then try module local to Lex\n  const repoPath: string = findFileUp.sync(modulePath, dirName);\n  if(repoPath && existsSync(repoPath)) {\n    return repoPath;\n  }\n\n  // Fallback to general search\n  const localPath: string = findFileUp.sync(modulePath, './', 10) || `./${modulePath}`;\n  return localPath;\n};\n\n/**\n * Resolve binary path with fallback logic for monorepo and package scenarios\n * Checks: 1) Lex's node_modules/.bin/, 2) Lex's node_modules/<package>/bin/, 3) Monorepo root node_modules/.bin/ (from process.cwd()), 4) Monorepo root node_modules/.bin/ (from Lex's dir)\n */\nexport const resolveBinaryPath = (binaryName: string, packageName?: string): string => {\n  const lexDir = LexConfig.getLexDir();\n\n  // 1. Check Lex's node_modules/.bin/\n  const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);\n  if(existsSync(lexBinPath)) {\n    return lexBinPath;\n  }\n\n  // 2. Check Lex's node_modules/<package>/bin/ (if packageName provided)\n  if(packageName) {\n    const lexPackageBinPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}`);\n    if(existsSync(lexPackageBinPath)) {\n      return lexPackageBinPath;\n    }\n\n    // Also check for .js extension\n    const lexPackageBinJsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.js`);\n    if(existsSync(lexPackageBinJsPath)) {\n      return lexPackageBinJsPath;\n    }\n\n    // Check for .cjs extension\n    const lexPackageBinCjsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.cjs`);\n    if(existsSync(lexPackageBinCjsPath)) {\n      return lexPackageBinCjsPath;\n    }\n  }\n\n  // 3. Walk up from process.cwd() and check node_modules/.bin/\n  const checkBinUp = (startDir: string) => {\n    let checkDir = startDir;\n    for(let i = 0; i < 5; i++) {\n      const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);\n      if(existsSync(monorepoBinPath)) {\n        return monorepoBinPath;\n      }\n      const parentDir = pathResolve(checkDir, '..');\n      if(parentDir === checkDir) {\n        break;\n      }\n      checkDir = parentDir;\n    }\n    return '';\n  };\n\n  // 3a. Walk up from process.cwd()\n  const fromCwd = checkBinUp(process.cwd());\n  if(fromCwd) {\n    return fromCwd;\n  }\n\n  // 3b. Walk up from Lex's directory\n  const fromLex = checkBinUp(lexDir);\n  if(fromLex) {\n    return fromLex;\n  }\n\n  // Not found\n  return '';\n};"],
  "mappings": "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",
  "names": []
}

179
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/utils/file.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport findFileUp from 'find-file-up';\nimport {existsSync, readFileSync} from 'fs';\nimport {resolve as pathResolve, dirname} from 'path';\nimport {sync as globSync} from 'glob';\n\n\nimport {LexConfig} from '../LexConfig.js';\n\n/**\n * Safely get directory name that works in both ESM and Jest environments\n */\nexport function getDirName(): string {\n  try {\n    // Only works in ESM environments\n    // eslint-disable-next-line no-eval\n    return eval('new URL(\".\", import.meta.url).pathname');\n  } catch {\n    // Fallback for Jest or CJS\n    return process.cwd();\n  }\n}\n\n/**\n * Safely get file path that works in both ESM and Jest environments\n */\nexport function getFilePath(relativePath: string): string {\n  try {\n    // Only works in ESM environments\n    // eslint-disable-next-line no-eval\n    return eval('require(\"url\").fileURLToPath(new URL(relativePath, import.meta.url))');\n  } catch {\n    // Fallback for Jest or CJS\n    if(relativePath === '../../../package.json') {\n      return pathResolve(process.cwd(), 'package.json');\n    }\n    return pathResolve(process.cwd(), relativePath);\n  }\n}\n\n/**\n * Get the path to Lex's own package.json, regardless of CWD\n */\nexport function getLexPackageJsonPath(): string {\n  const LEX_PACKAGE_NAME = '@nlabs/lex';\n  let startDir: string;\n\n  if(process.env.LEX_ROOT) {\n    startDir = process.env.LEX_ROOT;\n  } else {\n    // Try multiple approaches to get the Lex CLI's directory\n    try {\n      // Approach 1: ESM import.meta.url\n      startDir = eval('new URL(\".\", import.meta.url).pathname');\n    } catch(err1) {\n      try {\n        // Approach 2: CJS __filename (if available)\n        startDir = eval('__filename ? require(\"path\").dirname(__filename) : null');\n        if(!startDir) {\n          throw new Error('__filename not available');\n        }\n      } catch(err2) {\n        try {\n          // Approach 3: Use process.argv[1] (the actual script being executed)\n          if(process.argv[1] && !process.argv[1].includes('node')) {\n            startDir = dirname(process.argv[1]);\n          } else {\n            throw new Error('process.argv[1] not suitable');\n          }\n        } catch(err3) {\n          // Approach 4: Fallback to process.cwd()\n          startDir = process.cwd();\n        }\n      }\n    }\n  }\n\n  let dir = startDir;\n  for(let i = 0; i < 8; i++) {\n    const pkgPath = pathResolve(dir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n        if(pkg.name === LEX_PACKAGE_NAME) {\n          return pkgPath;\n        }\n      } catch(error) {\n        // Silently continue if package.json can't be read\n      }\n    }\n    const parent = dirname(dir);\n    if(parent === dir) break;\n    dir = parent;\n  }\n  // Fallback to process.cwd() as last resort\n  return pathResolve(process.cwd(), 'package.json');\n}\n\n// Get file paths relative to Lex\nexport const relativeFilePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(filename, dirPath, nestDepth);\n    const previousPath: string = Array(backUp).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(filename, dirPath, nestDepth);\n};\n\nexport const relativeNodePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n  const modulePath = `node_modules/${filename}`;\n\n  // First, check the Lex package's node_modules directory\n  if(dirPath !== './') {\n    const lexModulePath = pathResolve(dirPath, modulePath);\n    if(existsSync(lexModulePath)) {\n      return lexModulePath;\n    }\n  }\n\n  // Second, check the user's project node_modules directory\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  // Original implementation as fallback\n  if(backUp) {\n    const filePath: string = findFileUp.sync(modulePath, dirPath, nestDepth);\n    const previousPath: string = Array(nestDepth).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(modulePath, dirPath, nestDepth) || `/node_modules/${filename}`;\n};\n\n// Get file paths relative to Lex\nexport const getNodePath = (moduleName: string): string => {\n  const dirName = getDirName();\n  const modulePath: string = `node_modules/${moduleName}`;\n\n  // Try project root first\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  // Then try module local to Lex\n  const repoPath: string = findFileUp.sync(modulePath, dirName);\n  if(repoPath && existsSync(repoPath)) {\n    return repoPath;\n  }\n\n  // Fallback to general search\n  const localPath: string = findFileUp.sync(modulePath, './', 10) || `./${modulePath}`;\n  return localPath;\n};\n\n/**\n * Resolve binary path with fallback logic for monorepo and package scenarios\n * Checks: 1) Lex's node_modules/.bin/, 2) Lex's node_modules/<package>/bin/, 3) Monorepo root node_modules/.bin/ (from process.cwd()), 4) Monorepo root node_modules/.bin/ (from Lex's dir)\n */\nexport const resolveBinaryPath = (binaryName: string, packageName?: string): string => {\n  const lexDir = LexConfig.getLexDir();\n\n  // 1. Check Lex's node_modules/.bin/\n  const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);\n  if(existsSync(lexBinPath)) {\n    return lexBinPath;\n  }\n\n  // 2. Check Lex's node_modules/<package>/bin/ (if packageName provided)\n  if(packageName) {\n    const lexPackageBinPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}`);\n    if(existsSync(lexPackageBinPath)) {\n      return lexPackageBinPath;\n    }\n\n    // Also check for .js extension\n    const lexPackageBinJsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.js`);\n    if(existsSync(lexPackageBinJsPath)) {\n      return lexPackageBinJsPath;\n    }\n\n    // Check for .cjs extension\n    const lexPackageBinCjsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.cjs`);\n    if(existsSync(lexPackageBinCjsPath)) {\n      return lexPackageBinCjsPath;\n    }\n  }\n\n  // 3. Walk up from process.cwd() and check node_modules/.bin/\n  const checkBinUp = (startDir: string) => {\n    let checkDir = startDir;\n    for(let i = 0; i < 5; i++) {\n      const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);\n      if(existsSync(monorepoBinPath)) {\n        return monorepoBinPath;\n      }\n      const parentDir = pathResolve(checkDir, '..');\n      if(parentDir === checkDir) {\n        break;\n      }\n      checkDir = parentDir;\n    }\n    return '';\n  };\n\n  // 3a. Walk up from process.cwd()\n  const fromCwd = checkBinUp(process.cwd());\n  if(fromCwd) {\n    return fromCwd;\n  }\n\n  // 3b. Walk up from Lex's directory\n  const fromLex = checkBinUp(lexDir);\n  if(fromLex) {\n    return fromLex;\n  }\n\n  // Not found\n  return '';\n};\n\nexport const findTailwindCssPath = (): string => {\n  const tailwindPatterns = ['**/tailwind.css'];\n\n  for(const pattern of tailwindPatterns) {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/build/**', '**/.storybook/**']\n    });\n\n    if(files.length > 0) {\n      return pathResolve(process.cwd(), files[0]);\n    }\n  }\n\n  return '';\n};"],
  "mappings": "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",
  "names": ["startDir"]
}

package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.48.0",
3
+ "version": "1.48.1",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -62,14 +62,17 @@
62
62
  "@babel/preset-env": "^7.28.0",
63
63
  "@babel/preset-typescript": "7.27.1",
64
64
  "@luckycatfactory/esbuild-graphql-loader": "^3.8.1",
65
+ "@mdx-js/loader": "^3.1.0",
65
66
  "@nlabs/webpack-plugin-static-site": "*",
66
67
  "@storybook/addon-actions": "^9.0.8",
67
68
  "@storybook/addon-backgrounds": "^9.0.8",
68
69
  "@storybook/addon-controls": "^9.0.8",
69
70
  "@storybook/addon-docs": "^9.0.17",
70
71
  "@storybook/addon-links": "^9.0.17",
72
+ "@storybook/addon-postcss": "^2.0.0",
71
73
  "@storybook/addon-themes": "^9.0.17",
72
74
  "@storybook/addon-viewport": "^9.0.8",
75
+ "@storybook/addon-webpack5-compiler-babel": "^3.0.6",
73
76
  "@storybook/cli": "^9.0.17",
74
77
  "@storybook/react": "^9.0.17",
75
78
  "@storybook/react-webpack5": "^9.0.17",
@@ -194,5 +197,8 @@
194
197
  "@storybook/react-webpack5": "^9.0.17",
195
198
  "storybook": "^9.0.17"
196
199
  },
200
+ "resolutions": {
201
+ "css-loader": "7.1.2"
202
+ },
197
203
  "gitHead": "0f5fb22fc0f0ab1abab5adf62afed24c7c87e4a8"
198
204
  }
@@ -1,15 +0,0 @@
1
- import type { Preview } from '@storybook/react';
2
-
3
- const preview: Preview = {
4
- parameters: {
5
- actions: { argTypesRegex: '^on[A-Z].*' },
6
- controls: {
7
- matchers: {
8
- color: /(background|color)$/i,
9
- date: /Date$/,
10
- },
11
- },
12
- },
13
- };
14
-
15
- export default preview;