Skip to content

Commit

Permalink
fix: suggest variables and functions as mixin parameters
Browse files Browse the repository at this point in the history
  • Loading branch information
wkillerud committed Aug 4, 2024
1 parent 7ed7cd3 commit 44627af
Show file tree
Hide file tree
Showing 3 changed files with 62 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,36 @@ test("should not suggest mixin or placeholder in string interpolation", async ()
assert.isUndefined(items.find((item) => item.label === "%placeholder"));
});

test("should not suggest module mixin in string interpolation", async () => {
ls.configure({
completionSettings: {
suggestFromUseOnly: true,
},
});

const one = fileSystemProvider.createDocument(
["$primary: limegreen;", "@mixin mixin($a: 1, $b) {}"],
{
uri: "one.scss",
},
);
const two = fileSystemProvider.createDocument(
['@use "./one";', '.a { background: url("/#{one.'],
{
uri: "two.scss",
},
);

// emulate scanner of language service which adds workspace documents to the cache
ls.parseStylesheet(one);
ls.parseStylesheet(two);

const { items } = await ls.doComplete(two, Position.create(1, 29));
assert.equal(items.length, 1);
assert.ok(items.find((annotation) => annotation.label === "$primary"));
assert.isUndefined(items.find((item) => item.label === "mixin"));
});

test("should suggest symbol from a different document via @use when in string interpolation", async () => {
ls.configure({
completionSettings: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -524,3 +524,29 @@ test("should suggest function in @for $i from 1 through ", async () => {
assert.isUndefined(items.find((item) => item.label === "mixin"));
assert.isUndefined(items.find((item) => item.label === "%placeholder"));
});

test("should suggest variable and function as parameter to mixin, not mixin or placeholder", async () => {
ls.configure({
completionSettings: {
suggestAllFromOpenDocument: true,
suggestFromUseOnly: false,
},
});

const one = fileSystemProvider.createDocument([
'$name: "value";',
"@mixin mixin($a: 1, $b) {}",
"@function compare($a: 1, $b) {}",
"%placeholder { color: blue; }",
".a { @include mixin(",
]);

ls.parseStylesheet(one);

const { items } = await ls.doComplete(one, Position.create(4, 20));

assert.ok(items.find((item) => item.label === "$name"));
assert.ok(items.find((item) => item.label === "compare"));
assert.isUndefined(items.find((item) => item.label === "mixin"));
assert.isUndefined(items.find((item) => item.label === "%placeholder"));
});
6 changes: 6 additions & 0 deletions packages/language-services/src/features/do-complete.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ const rePropertyValue = /.*:\s*/;
const reEmptyPropertyValue = /.*:\s*$/;
const reQuotedValueInString = /["'](?:[^"'\\]|\\.)*["']/g;
const reMixinReference = /.*@include\s+(.*)/;
const reCompletedMixinWithParametersReference = /.*@include\s+(.*)\(/;
const reComment = /^(.*\/\/|.*\/\*|\s*\*)/;
const reSassDoc = /^[\\s]*\/{3}.*$/;
const reQuotes = /["']/;
Expand Down Expand Up @@ -480,6 +481,11 @@ export class DoComplete extends LanguageFeature {

if (!isPropertyValue && reMixinReference.test(lineBeforePosition)) {
context.isMixinContext = true;
if (reCompletedMixinWithParametersReference.test(lineBeforePosition)) {
context.isMixinContext = false;
context.isVariableContext = true;
context.isFunctionContext = true;
}
}

return context;
Expand Down

0 comments on commit 44627af

Please sign in to comment.