From f1c8da60e1ca9045e4534e4b7e89505281da7b2a Mon Sep 17 00:00:00 2001 From: Kelvin Oghenerhoro Omereshone Date: Fri, 13 Sep 2024 17:30:06 +0100 Subject: [PATCH] fix(language-server): normalize helper path --- .../go-to-definitions/go-to-helper.js | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/packages/language-server/go-to-definitions/go-to-helper.js b/packages/language-server/go-to-definitions/go-to-helper.js index 3e5da2e..fab8ab1 100644 --- a/packages/language-server/go-to-definitions/go-to-helper.js +++ b/packages/language-server/go-to-definitions/go-to-helper.js @@ -4,6 +4,17 @@ const fs = require('fs').promises const findProjectRoot = require('../helpers/find-project-root') const findFnLine = require('../helpers/find-fn-line') +function camelToKebabCase(str) { + return str.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`) +} + +function normalizeHelperPath(helperPath) { + const parts = helperPath.split('/') + const fileName = parts.pop() // Get the last part (file name) + const normalizedFileName = camelToKebabCase(fileName) + return [...parts, normalizedFileName].join('/') +} + module.exports = async function goToHelper(document, position) { const helperInfo = extractHelperInfo(document, position) @@ -12,9 +23,11 @@ module.exports = async function goToHelper(document, position) { } const projectRoot = await findProjectRoot(document.uri) + const normalizedHelperPath = normalizeHelperPath( + helperInfo.helperPath.join('/') + ) const fullHelperPath = - path.join(projectRoot, 'api', 'helpers', ...helperInfo.helperPath) + '.js' - + path.join(projectRoot, 'api', 'helpers', normalizedHelperPath) + '.js' if (fullHelperPath) { const fnLineNumber = await findFnLine(fullHelperPath) return lsp.Location.create(