diff options
| author | 2021-04-22 12:10:06 -0700 | |
|---|---|---|
| committer | 2021-04-22 15:10:06 -0400 | |
| commit | 5eb232501f8f02236e52cf945b7fa3ce5a2ec260 (patch) | |
| tree | a2abbdec0c191d8ded6534b0e8a8cb05d4db5ec4 /src/compiler/codegen/index.ts | |
| parent | f5384b139d7bb2b8a748dd4a344c1e91d850c76e (diff) | |
| download | astro-5eb232501f8f02236e52cf945b7fa3ce5a2ec260.tar.gz astro-5eb232501f8f02236e52cf945b7fa3ce5a2ec260.tar.zst astro-5eb232501f8f02236e52cf945b7fa3ce5a2ec260.zip | |
Allow multiple JSX children appear in Mustache tag (#125)
* fix(www): link styles (#100)
Co-authored-by: Nate Moore <nate@skypack.dev>
* Add `assets/` (#102)
* chore: add assets
* docs: update readme
Co-authored-by: Nate Moore <nate@skypack.dev>
* docs: fix readme
* docs: fix readme
* chore: remove github banner
* Allow multiple JSX in mustache
* Manually discard package-lock update (due to local use of npm v7)
* Tidy up
* Revert mode ts-ignore
Co-authored-by: Nate Moore <natemoo-re@users.noreply.github.com>
Co-authored-by: Nate Moore <nate@skypack.dev>
Diffstat (limited to 'src/compiler/codegen/index.ts')
| -rw-r--r-- | src/compiler/codegen/index.ts | 23 | 
1 files changed, 16 insertions, 7 deletions
| diff --git a/src/compiler/codegen/index.ts b/src/compiler/codegen/index.ts index 8d968e1ea..a10268883 100644 --- a/src/compiler/codegen/index.ts +++ b/src/compiler/codegen/index.ts @@ -75,7 +75,8 @@ function getAttributes(attrs: Attribute[]): Record<string, string> {      }      switch (val.type) {        case 'MustacheTag': { -        result[attr.name] = '(' + val.expression.codeStart + ')'; +        // FIXME: this won't work when JSX element can appear in attributes (rare but possible). +        result[attr.name] = '(' + val.expression.codeChunks[0] + ')';          continue;        }        case 'Text': @@ -101,7 +102,8 @@ function getTextFromAttribute(attr: any): string {        break;      }      case 'MustacheTag': { -      return attr.expression.codeStart; +      // FIXME: this won't work when JSX element can appear in attributes (rare but possible). +      return attr.expression.codeChunks[0];      }    }    throw new Error(`Unknown attribute type ${attr.type}`); @@ -520,13 +522,20 @@ function compileHtml(enterNode: TemplateNode, state: CodegenState, compileOption      enter(node: TemplateNode) {        switch (node.type) {          case 'Expression': { -          let child = ''; +          let children: string[] = [];            // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -          if (node.children!.length) { -            // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -            child = compileHtml(node.children![0], state, compileOptions); +          for (const child of node.children!) { +            children.push(compileHtml(child, state, compileOptions)); +          } +          let raw = ''; +          let nextChildIndex = 0; +          // eslint-disable-next-line @typescript-eslint/no-non-null-assertion +          for (const chunk of node.codeChunks!) { +            raw += chunk; +            if (nextChildIndex < children.length) { +              raw += children[nextChildIndex++]; +            }            } -          let raw = node.codeStart + child + node.codeEnd;            // TODO Do we need to compile this now, or should we compile the entire module at the end?            let code = compileExpressionSafe(raw).trim().replace(/\;$/, '');            outSource += `,(${code})`; | 
