Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Intellisense broken in Visual Studio Code when Prophet is enabled #374

Open
poebrand opened this issue Dec 19, 2023 · 3 comments
Open

Intellisense broken in Visual Studio Code when Prophet is enabled #374

poebrand opened this issue Dec 19, 2023 · 3 comments

Comments

@poebrand
Copy link

poebrand commented Dec 19, 2023

Describe the bug
When Prophet is enabled in Visual Studio Code, Intellisense no longer works normally.

To Reproduce
Steps to reproduce the behavior:

  1. Disable all VS Code extensions.
  2. Create a simple JavaScript function containing an object declaration. Example:
    function logInfo(profile) { var logObject = { action: 'deleteCustomer', customerNumber: profile.customerNo }; }
  3. Within the function, enter the object name followed by a period. Intellisense does show the members of the object.
    image
  4. Enable the Prophet extension.
  5. Within the function, enter the object name followed by a period. Intellisense does not show the members of the object.
    image

Expected behavior
Intellisense continues to work when Prophet is enabled. In the example, entering period after the object name should show the available properties (action, customerNumber).

Screenshots
See above.

Desktop (please complete the following information):

  • OS: Windows 10 Enterprise - Version: 22H@
  • VSCode version: 1.85.1
  • The extension version [e.g. 22]: 1.4.40

Additional context
No other extensions enabled besides Prophet.

If Prophet is extending VS Code intellisense, it would probably be good to have a setting for enabling/disabling that feature.

@SqrTT
Copy link
Owner

SqrTT commented Dec 21, 2023

HI @poebrand
thanks for reporting issue.

Yes, your assumption is correct. Prophet contains it's own language server for JS files for cartridges and this language server is desired to work better in SFCC context (ie resolves paths in SFCC manner, extends types with SFCC types etc). And yes, it's disables internal language server to avoid collisions.
But seems in your case seems language server in not running. Potential reason for it lack of knowledge of SFCC site context. In order to run language server requires to have info about cartridges and cartridges paths to be able to resolve paths like */cartridge_name/some_file or module.superModule

cartridges path may be extracted by extension from site.xml files if present in workspace or from dw.json (via cartridgesPath property). Additionaly current context must be selected via menu in right bottom corner

image

in case Prophet is not eble determinate a path it's shows warning during startup

image

Would you confirm you have proper context selected and issue still persist?

@maxjf1
Copy link

maxjf1 commented Dec 26, 2023

After testing this does solve the issue, the intelisense is a little bit slower but works still

@foegit
Copy link

foegit commented Feb 15, 2024

Hi @SqrTT, it would be really nice to be able to turn the extension's language server off as suggested by @poebrand.
For my projects I usually don't use context feature and I would expect standard InteliSense to be still working.
I tried to play with context, but in my case only downgrading to v1.3.33 helped.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants