@vue/language-core 3.3.3 → 3.3.4

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.
@@ -219,9 +219,14 @@ function* generateComponent(options, ctx, node) {
219
219
  }
220
220
  }
221
221
  if (shouldInheritAttrs) {
222
- const restsVar = ctx.getInternalVariable();
223
- yield `var ${restsVar} = ${names_1.names.omit}(${getPropsVar()}, {\n${propsStr}})${utils_1.endOfLine}`;
224
- ctx.inheritedAttrVars.add(restsVar);
222
+ if (options.vueCompilerOptions.checkRequiredFallthroughAttributes) {
223
+ const restsVar = ctx.getInternalVariable();
224
+ yield `var ${restsVar} = ${names_1.names.omit}(${getPropsVar()}, {\n${propsStr}})${utils_1.endOfLine}`;
225
+ ctx.inheritedAttrVars.add(restsVar);
226
+ }
227
+ else {
228
+ ctx.inheritedAttrVars.add(getPropsVar());
229
+ }
225
230
  }
226
231
  yield* generateStyleScopedClassReferences(options, node);
227
232
  const slotDir = node.props.find(CompilerDOM.isVSlot);
@@ -47,7 +47,7 @@ const boundary_1 = require("../utils/boundary");
47
47
  const camelized_1 = require("../utils/camelized");
48
48
  const interpolation_1 = require("./interpolation");
49
49
  function* generateElementEvents(options, ctx, node, componentOriginalVar, getCtxVar, getPropsVar) {
50
- let emitsVar;
50
+ const definitions = [];
51
51
  for (const prop of node.props) {
52
52
  if (prop.type === CompilerDOM.NodeTypes.DIRECTIVE
53
53
  && (prop.name === 'on'
@@ -55,12 +55,8 @@ function* generateElementEvents(options, ctx, node, componentOriginalVar, getCtx
55
55
  || options.vueCompilerOptions.strictVModel
56
56
  && prop.name === 'model'
57
57
  && (!prop.arg || prop.arg.type === CompilerDOM.NodeTypes.SIMPLE_EXPRESSION && prop.arg.isStatic))) {
58
- if (!emitsVar) {
59
- emitsVar = ctx.getInternalVariable();
60
- yield `let ${emitsVar}!: ${names_1.names.ResolveEmits}<typeof ${componentOriginalVar}, typeof ${getCtxVar()}.emit>${utils_1.endOfLine}`;
61
- }
62
58
  let source = prop.arg?.loc.source ?? 'model-value';
63
- let start = prop.arg?.loc.start.offset;
59
+ let offset = prop.arg?.loc.start.offset;
64
60
  let propPrefix = 'on-';
65
61
  let emitPrefix = '';
66
62
  if (prop.name === 'model') {
@@ -69,32 +65,55 @@ function* generateElementEvents(options, ctx, node, componentOriginalVar, getCtx
69
65
  }
70
66
  else if (source.startsWith('vue:')) {
71
67
  source = source.slice('vue:'.length);
72
- start = start + 'vue:'.length;
68
+ offset = offset + 'vue:'.length;
73
69
  propPrefix = 'onVnode-';
74
70
  emitPrefix = 'vnode-';
75
71
  }
76
72
  const propName = (0, shared_1.camelize)(propPrefix + source);
77
73
  const emitName = emitPrefix + source;
78
- const camelizedEmitName = (0, shared_1.camelize)(emitName);
79
- yield `const ${ctx.getInternalVariable()}: ${names_1.names.NormalizeComponentEvent}<typeof ${getPropsVar()}, typeof ${emitsVar}, '${propName}', '${emitName}', '${camelizedEmitName}'> = (${utils_1.newLine}`;
80
- if (prop.name === 'on') {
81
- yield `{ `;
82
- yield* generateEventArg(options, source, start, emitPrefix.slice(0, -1), codeFeatures_1.codeFeatures.navigation);
83
- yield `: {} as any } as typeof ${emitsVar},${utils_1.newLine}`;
84
- }
85
- yield `{ `;
86
- if (prop.name === 'on') {
87
- yield* generateEventArg(options, source, start, propPrefix.slice(0, -1));
88
- yield `: `;
89
- yield* generateEventExpression(options, ctx, prop);
90
- }
91
- else {
92
- yield `'${propName}': `;
93
- yield* generateModelEventExpression(options, ctx, prop);
94
- }
95
- yield `})${utils_1.endOfLine}`;
74
+ definitions.push({
75
+ prop,
76
+ source,
77
+ offset,
78
+ emitPrefix,
79
+ propPrefix,
80
+ propName,
81
+ emitName,
82
+ });
83
+ }
84
+ }
85
+ if (!definitions.length) {
86
+ return;
87
+ }
88
+ const emitsVar = ctx.getInternalVariable();
89
+ yield `let ${emitsVar}!: ${names_1.names.ResolveEmits}<typeof ${componentOriginalVar}, typeof ${getCtxVar()}.emit>${utils_1.endOfLine}`;
90
+ yield `const ${ctx.getInternalVariable()}: `;
91
+ for (let i = 0; i < definitions.length; i++) {
92
+ const { propName, emitName } = definitions[i];
93
+ if (i > 0) {
94
+ yield ` & `;
95
+ }
96
+ yield `${names_1.names.NormalizeComponentEvent}<typeof ${getPropsVar()}, typeof ${emitsVar}, '${propName}', '${emitName}', '${(0, shared_1.camelize)(emitName)}'>`;
97
+ }
98
+ yield ` = {${utils_1.newLine}`;
99
+ for (const { prop, source, offset, emitPrefix, propPrefix, propName } of definitions) {
100
+ if (prop.name === 'on') {
101
+ yield `...{ `;
102
+ yield* generateEventArg(options, source, offset, emitPrefix.slice(0, -1), codeFeatures_1.codeFeatures.navigation);
103
+ yield `: {} as any } as typeof ${emitsVar},${utils_1.newLine}`;
104
+ }
105
+ if (prop.name === 'on') {
106
+ yield* generateEventArg(options, source, offset, propPrefix.slice(0, -1));
107
+ yield `: `;
108
+ yield* generateEventExpression(options, ctx, prop);
109
+ }
110
+ else {
111
+ yield `'${propName}': `;
112
+ yield* generateModelEventExpression(options, ctx, prop);
96
113
  }
114
+ yield `,${utils_1.newLine}`;
97
115
  }
116
+ yield `}${utils_1.endOfLine}`;
98
117
  }
99
118
  function* generateEventArg(options, name, start, directive = 'on', features) {
100
119
  features ??= {
@@ -239,7 +239,8 @@ function getShouldCamelize(options, node, prop, propName) {
239
239
  || node.tagType === CompilerDOM.ElementTypes.SLOT) && (prop.type !== CompilerDOM.NodeTypes.DIRECTIVE
240
240
  || prop.arg?.type === CompilerDOM.NodeTypes.SIMPLE_EXPRESSION && prop.arg.isStatic)
241
241
  && (0, shared_2.hyphenateAttr)(propName) === propName
242
- && !options.vueCompilerOptions.htmlAttributes.some(pattern => (0, picomatch_1.isMatch)(propName, pattern));
242
+ && (node.tagType === CompilerDOM.ElementTypes.SLOT
243
+ || !options.vueCompilerOptions.htmlAttributes.some(pattern => (0, picomatch_1.isMatch)(propName, pattern)));
243
244
  }
244
245
  function getPropsCodeFeatures(checkUnknownProps) {
245
246
  return {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vue/language-core",
3
- "version": "3.3.3",
3
+ "version": "3.3.4",
4
4
  "license": "MIT",
5
5
  "files": [
6
6
  "index.d.ts",
@@ -34,5 +34,5 @@
34
34
  "@volar/typescript": "2.4.28",
35
35
  "@vue/compiler-sfc": "^3.5.0"
36
36
  },
37
- "gitHead": "5c41b5f8637c29551e7f3f1e0674606e5963cd0a"
37
+ "gitHead": "043a77b6182db32f4076f84a767c1c674ef2b149"
38
38
  }