mirror of
https://github.com/withastro/astro.git
synced 2025-03-31 23:31:30 -05:00
* Revert "fix(compiler): Support dynamic slot names (#9605)"
This reverts commit 8ce40a417c
.
* chore: changeset
* Update .changeset/weak-pans-sit.md
* chore: bump compiler version
* fix failing test
We were expecting the source code to produce an error, but in
2.4.0 of the compiler, that generates valid code
---------
Co-authored-by: Erika <3019731+Princesseuh@users.noreply.github.com>
This commit is contained in:
parent
56db6ae246
commit
c53a31321a
7 changed files with 12 additions and 71 deletions
5
.changeset/weak-pans-sit.md
Normal file
5
.changeset/weak-pans-sit.md
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
"astro": patch
|
||||
---
|
||||
|
||||
Rollbacks the feature which allowed to dynamically generate slots with variable slot names due to unexpected regressions.
|
|
@ -114,7 +114,7 @@
|
|||
"test:e2e:match": "playwright test -g"
|
||||
},
|
||||
"dependencies": {
|
||||
"@astrojs/compiler": "^2.5.0",
|
||||
"@astrojs/compiler": "^2.5.3",
|
||||
"@astrojs/internal-helpers": "workspace:*",
|
||||
"@astrojs/markdown-remark": "workspace:*",
|
||||
"@astrojs/telemetry": "workspace:*",
|
||||
|
|
|
@ -45,11 +45,8 @@ import { addAttribute, Renderer } from './render/index.js';
|
|||
|
||||
export function mergeSlots(...slotted: unknown[]) {
|
||||
const slots: Record<string, () => any> = {};
|
||||
for (let slot of slotted) {
|
||||
for (const slot of slotted) {
|
||||
if (!slot) continue;
|
||||
if (Array.isArray(slot)) {
|
||||
slot = mergeSlots(...slot);
|
||||
}
|
||||
if (typeof slot === 'object') {
|
||||
Object.assign(slots, slot);
|
||||
} else if (typeof slot === 'function') {
|
||||
|
|
|
@ -30,26 +30,6 @@ describe('Slots', () => {
|
|||
expect($('#default').text().trim()).to.equal('Default');
|
||||
});
|
||||
|
||||
it('Dynamic named slots work with map work', async () => {
|
||||
const html = await fixture.readFile('/dynamic-map/index.html');
|
||||
const $ = cheerio.load(html);
|
||||
|
||||
expect($('#a').text().trim()).to.equal('A');
|
||||
expect($('#b').text().trim()).to.equal('B');
|
||||
expect($('#c').text().trim()).to.equal('C');
|
||||
expect($('#default').text().trim()).to.equal('Default');
|
||||
});
|
||||
|
||||
it('Dynamic named slots work with for loop', async () => {
|
||||
const html = await fixture.readFile('/dynamic-for/index.html');
|
||||
const $ = cheerio.load(html);
|
||||
|
||||
expect($('#a').text().trim()).to.equal('A');
|
||||
expect($('#b').text().trim()).to.equal('B');
|
||||
expect($('#c').text().trim()).to.equal('C');
|
||||
expect($('#default').text().trim()).to.equal('Default');
|
||||
});
|
||||
|
||||
it('Conditional named slots work', async () => {
|
||||
const html = await fixture.readFile('/conditional/index.html');
|
||||
const $ = cheerio.load(html);
|
||||
|
|
|
@ -1,24 +0,0 @@
|
|||
---
|
||||
import Slotted from '../components/Slotted.astro';
|
||||
|
||||
const slotNames = ['a', 'b', 'c']
|
||||
---
|
||||
|
||||
<html>
|
||||
<head>
|
||||
<!-- Head Stuff -->
|
||||
</head>
|
||||
<body>
|
||||
<Slotted>
|
||||
{()=>{
|
||||
const slots:any[] = [];
|
||||
for (const slotName of slotNames) {
|
||||
slots.push(<span slot={slotName}>{slotName.toUpperCase()}</span>);
|
||||
}
|
||||
return slots;
|
||||
}
|
||||
}
|
||||
<span>Default</span>
|
||||
</Slotted>
|
||||
</body>
|
||||
</html>
|
|
@ -1,17 +0,0 @@
|
|||
---
|
||||
import Slotted from '../components/Slotted.astro';
|
||||
|
||||
const slots = ['a', 'b', 'c']
|
||||
---
|
||||
|
||||
<html>
|
||||
<head>
|
||||
<!-- Head Stuff -->
|
||||
</head>
|
||||
<body>
|
||||
<Slotted>
|
||||
{slots.map((slotName)=><span slot={slotName}>{slotName.toUpperCase()}</span>)}
|
||||
<span>Default</span>
|
||||
</Slotted>
|
||||
</body>
|
||||
</html>
|
10
pnpm-lock.yaml
generated
10
pnpm-lock.yaml
generated
|
@ -492,8 +492,8 @@ importers:
|
|||
packages/astro:
|
||||
dependencies:
|
||||
'@astrojs/compiler':
|
||||
specifier: ^2.5.0
|
||||
version: 2.5.0
|
||||
specifier: ^2.5.3
|
||||
version: 2.5.3
|
||||
'@astrojs/internal-helpers':
|
||||
specifier: workspace:*
|
||||
version: link:../internal-helpers
|
||||
|
@ -5329,8 +5329,8 @@ packages:
|
|||
resolution: {integrity: sha512-o/ObKgtMzl8SlpIdzaxFnt7SATKPxu4oIP/1NL+HDJRzxfJcAkOTAb/ZKMRyULbz4q+1t2/DAebs2Z1QairkZw==}
|
||||
dev: true
|
||||
|
||||
/@astrojs/compiler@2.5.0:
|
||||
resolution: {integrity: sha512-ZDluNgMIJT+z+HJcZ6QEJ/KqaFkTkrb+Za6c6VZs8G/nb1LBErL14/iU5EVJ9yu25i4QCLweuBJ3m5df34gZJg==}
|
||||
/@astrojs/compiler@2.5.3:
|
||||
resolution: {integrity: sha512-jzj01BRv/fmo+9Mr2FhocywGzEYiyiP2GVHje1ziGNU6c97kwhYGsnvwMkHrncAy9T9Vi54cjaMK7UE4ClX4vA==}
|
||||
|
||||
/@astrojs/language-server@2.5.5(prettier-plugin-astro@0.12.3)(prettier@3.1.1)(typescript@5.2.2):
|
||||
resolution: {integrity: sha512-hk7a8S7bpf//BOA6mMjiYqi/eiYtGPfUfw59eVXdutdRFdwDHtu4jcsLu43ZaId56pAcE8qFjIvJxySvzcxiUA==}
|
||||
|
@ -5344,7 +5344,7 @@ packages:
|
|||
prettier-plugin-astro:
|
||||
optional: true
|
||||
dependencies:
|
||||
'@astrojs/compiler': 2.5.0
|
||||
'@astrojs/compiler': 2.5.3
|
||||
'@jridgewell/sourcemap-codec': 1.4.15
|
||||
'@volar/kit': 1.10.10(typescript@5.2.2)
|
||||
'@volar/language-core': 1.10.10
|
||||
|
|
Loading…
Add table
Reference in a new issue