(
{expression, sourceSpan}: html.BlockParameter,
triggers: t.DeferredBlockTriggers,
errors: ParseError[],
)
| 62 | |
| 63 | /** Parses a `when` deferred trigger. */ |
| 64 | export function parseNeverTrigger( |
| 65 | {expression, sourceSpan}: html.BlockParameter, |
| 66 | triggers: t.DeferredBlockTriggers, |
| 67 | errors: ParseError[], |
| 68 | ): void { |
| 69 | const neverIndex = expression.indexOf('never'); |
| 70 | const neverSourceSpan = new ParseSourceSpan( |
| 71 | sourceSpan.start.moveBy(neverIndex), |
| 72 | sourceSpan.start.moveBy(neverIndex + 'never'.length), |
| 73 | ); |
| 74 | const prefetchSpan = getPrefetchSpan(expression, sourceSpan); |
| 75 | const hydrateSpan = getHydrateSpan(expression, sourceSpan); |
| 76 | |
| 77 | // This is here just to be safe, we shouldn't enter this function |
| 78 | // in the first place if a block doesn't have the "on" keyword. |
| 79 | if (neverIndex === -1) { |
| 80 | errors.push(new ParseError(sourceSpan, `Could not find "never" keyword in expression`)); |
| 81 | } else { |
| 82 | trackTrigger( |
| 83 | 'never', |
| 84 | triggers, |
| 85 | errors, |
| 86 | new t.NeverDeferredTrigger(neverSourceSpan, sourceSpan, prefetchSpan, null, hydrateSpan), |
| 87 | ); |
| 88 | } |
| 89 | } |
| 90 | |
| 91 | /** Parses a `when` deferred trigger. */ |
| 92 | export function parseWhenTrigger( |
no test coverage detected
searching dependent graphs…