Skip to content

Commit 046f531

Browse files
authored
Merge branch 'master' into advance-rfc-1046
2 parents d02547e + 4696af0 commit 046f531

16 files changed

+1941
-28
lines changed

.github/workflows/generate-rfc-frontmatter-json.yml

+2-1
Original file line numberDiff line numberDiff line change
@@ -20,8 +20,9 @@ jobs:
2020
run: |
2121
node rfcs-tooling/scripts/list-frontmatter.mjs text/*.md > rfc-data.json
2222
23-
- uses: actions/upload-artifact@v3
23+
- uses: actions/upload-artifact@v4
2424
with:
2525
name: rfc-data
2626
path: rfc-data.json
2727
if-no-files-found: error
28+
overwrite: true

.github/workflows/open-advancement-pr.yml

+2-1
Original file line numberDiff line numberDiff line change
@@ -88,8 +88,9 @@ jobs:
8888
echo '{ "file": "${{ inputs.rfc-path }}", "number": "${{ inputs.rfc-number }}", "pr": "${{ steps.create-pr.outputs.pull-request-url }}", "advancementStage": "${{ inputs.new-stage }}" }' > advance-rfc-${{ inputs.rfc-number }}.json
8989
9090
- name: Upload artifact of open RFC PRs
91-
uses: actions/upload-artifact@v3
91+
uses: actions/upload-artifact@v4
9292
with:
9393
name: advancement-prs
9494
path: advance-rfc-${{ inputs.rfc-number }}.json
95+
overwrite: true
9596
if-no-files-found: error

0000-template.md

+2-1
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,8 @@ project-link: Leave as is
3030
suite: Leave as is
3131
-->
3232

33-
<-- Replace "RFC title" with the title of your RFC -->
33+
<!-- Replace "RFC title" with the title of your RFC -->
34+
3435
# RFC title
3536

3637
## Summary

README.md

+2
Original file line numberDiff line numberDiff line change
@@ -119,6 +119,8 @@ Read more about the RFC [Stages].
119119
## Stages
120120
[Stages]: #stages
121121

122+
Here are all the stages that an RFC can be in:
123+
122124
| Stage| Description| Requires FCP to enter? |
123125
| -----| -----------|----- |
124126
| [0 - Proposed](#Proposed) | A proposal for a change to Ember or its processes that is offered for community and team evaluation. | no |

text/0724-road-to-typescript.md

+2-1
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
---
2-
stage: released
2+
stage: recommended
33
start-date: 2021-03-11T00:00:00.000Z
44
release-date:
55
release-versions:
@@ -13,6 +13,7 @@ prs:
1313
accepted: 'https://github.com/emberjs/rfcs/pull/724'
1414
ready-for-release: 'https://github.com/emberjs/rfcs/pull/869'
1515
released: 'https://github.com/emberjs/rfcs/pull/948'
16+
recommended: 'https://github.com/emberjs/rfcs/pull/952'
1617
project-link:
1718
---
1819

text/0931-template-compiler-api.md

+6-5
Original file line numberDiff line numberDiff line change
@@ -1,17 +1,18 @@
11
---
2-
stage: accepted
3-
start-date: 2023-05-31
4-
release-date: # In format YYYY-MM-DDT00:00:00.000Z
2+
stage: ready-for-release
3+
start-date: 2023-05-31T00:00:00.000Z
4+
release-date:
55
release-versions:
6-
teams: # delete teams that aren't relevant
6+
teams:
77
- cli
88
- data
99
- framework
1010
- learning
1111
- steering
1212
- typescript
1313
prs:
14-
accepted: https://github.com/emberjs/rfcs/pull/931
14+
accepted: 'https://github.com/emberjs/rfcs/pull/931'
15+
ready-for-release: 'https://github.com/emberjs/rfcs/pull/933'
1516
project-link:
1617
suite:
1718
---

text/1001-deprecate-named-inject.md

+3-1
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,16 @@
11
---
2-
stage: ready-for-release
2+
stage: released
33
start-date: 2023-12-26T00:00:00.000Z
44
release-date:
55
release-versions:
6+
ember-source: 6.3.0
67
teams:
78
- framework
89
- typescript
910
prs:
1011
accepted: 'https://github.com/emberjs/rfcs/pull/1001'
1112
ready-for-release: 'https://github.com/emberjs/rfcs/pull/1013'
13+
released: 'https://github.com/emberjs/rfcs/pull/1061'
1214
project-link:
1315
---
1416

text/1003-deprecation-import-ember-from-ember.md

+4-3
Original file line numberDiff line numberDiff line change
@@ -1,17 +1,18 @@
11
---
2-
stage: accepted
2+
stage: ready-for-release
33
start-date: 2024-01-22T00:00:00.000Z
44
release-date:
55
release-versions:
6-
teams: # delete teams that aren't relevant
6+
teams:
77
- cli
88
- data
99
- framework
1010
- learning
1111
- steering
1212
- typescript
1313
prs:
14-
accepted: https://github.com/emberjs/rfcs/pull/1003
14+
accepted: 'https://github.com/emberjs/rfcs/pull/1003'
15+
ready-for-release: 'https://github.com/emberjs/rfcs/pull/1015'
1516
project-link:
1617
---
1718

text/1009-move-deprecation-workflow-to-apps.md

+7-6
Original file line numberDiff line numberDiff line change
@@ -1,18 +1,19 @@
11
---
2-
stage: accepted
3-
start-date: 2024-02-22T00:00:00.000Z
4-
release-date: # In format YYYY-MM-DDT00:00:00.000Z
2+
stage: ready-for-release
3+
start-date: 2024-02-22T00:00:00.000Z
4+
release-date:
55
release-versions:
6-
teams: # delete teams that aren't relevant
6+
teams:
77
- cli
88
- data
99
- framework
1010
- learning
1111
- typescript
1212
prs:
13-
accepted: https://github.com/emberjs/rfcs/pull/1009
13+
accepted: 'https://github.com/emberjs/rfcs/pull/1009'
14+
ready-for-release: 'https://github.com/emberjs/rfcs/pull/1048'
1415
project-link:
15-
suite:
16+
suite:
1617
---
1718

1819
<!---

text/1029-deprecate-app-prefix.md

+4-3
Original file line numberDiff line numberDiff line change
@@ -1,13 +1,14 @@
11
---
2-
stage: accepted
2+
stage: ready-for-release
33
start-date: 2024-05-20T00:00:00.000Z
44
release-date:
55
release-versions:
6-
teams: # delete teams that aren't relevant
6+
teams:
77
- cli
88
- learning
99
prs:
10-
accepted: https://github.com/emberjs/rfcs/pull/1029
10+
accepted: 'https://github.com/emberjs/rfcs/pull/1029'
11+
ready-for-release: 'https://github.com/emberjs/rfcs/pull/1044'
1112
project-link:
1213
---
1314

text/1046-template-tag-in-routes.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -34,7 +34,7 @@ suite: Leave as is
3434

3535
## Summary
3636

37-
Allow `app/templates/*.hbs` to convert to `app/temlates/*.gjs`.
37+
Allow `app/templates/*.hbs` to convert to `app/templates/*.gjs`.
3838

3939
## Motivation
4040

@@ -163,7 +163,7 @@ No new typescript-specific features are required. If you're authoring route temp
163163

164164
This RFC was directly inspired by a first attempt at updating the Guides for Template Tag. It became immediately apparent that we can write _much_ clearer guides if we can teach all GJS, instead of a mix of GJS and HBS.
165165

166-
Starting at https://guides.emberjs.com/release/components/ when the first `application.hbs` file is introduced, we would use `.gjs` instead. In those opening examples that are empahsizing HTML, the only change to the content would be wrapping `<template></template>` around the HTML.
166+
Starting at https://guides.emberjs.com/release/components/ when the first `application.hbs` file is introduced, we would use `.gjs` instead. In those opening examples that are emphasizing HTML, the only change to the content would be wrapping `<template></template>` around the HTML.
167167

168168
Progressing to https://guides.emberjs.com/release/components/introducing-components/, learners extract their first component. It now becomes possible to do that within the same file. This allows teaching fewer things in a single step. First, people can learn what a component is. Second, it can be refactored into a separate file. We can avoid teaching anything about "pascal case" and naming rules, because everything just follows javascript naming rules.
169169

text/1055-vanilla-prettier-setup-in-blueprints.md

+5-4
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,15 @@
11
---
2-
stage: accepted
2+
stage: ready-for-release
33
start-date: 2024-12-03T00:00:00.000Z
4-
release-date:
4+
release-date:
55
release-versions:
66
teams:
77
- cli
88
prs:
9-
accepted: https://github.com/emberjs/rfcs/pull/1055
9+
accepted: 'https://github.com/emberjs/rfcs/pull/1055'
10+
ready-for-release: 'https://github.com/emberjs/rfcs/pull/1063'
1011
project-link:
11-
suite:
12+
suite:
1213
---
1314

1415
# Vanilla Prettier Setup in Blueprints

text/1065-remove-ember-fetch.md

+151
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,151 @@
1+
---
2+
stage: accepted
3+
start-date: 2025-01-10T00:00:00.000Z
4+
release-date:
5+
release-versions:
6+
teams: # delete teams that aren't relevant
7+
- cli
8+
- data
9+
- framework
10+
- learning
11+
prs:
12+
accepted: https://github.com/emberjs/rfcs/pull/1065
13+
project-link:
14+
---
15+
16+
<!---
17+
Directions for above:
18+
19+
stage: Leave as is
20+
start-date: Fill in with today's date, 2032-12-01T00:00:00.000Z
21+
release-date: Leave as is
22+
release-versions: Leave as is
23+
teams: Include only the [team(s)](README.md#relevant-teams) for which this RFC applies
24+
prs:
25+
accepted: Fill this in with the URL for the Proposal RFC PR
26+
project-link: Leave as is
27+
-->
28+
29+
# Deprecate and Remove ember-fetch
30+
31+
## Summary
32+
33+
This RFC proposes removing `ember-fetch` from the blueprint for new projects, and recommends alternative, more native, ways of having "managed fetch".
34+
35+
## Motivation
36+
37+
The package, `ember-fetch`, does a fair bit of deceptive and incorrect behavior that is incompatible with modern JavaScript tooling, such as _being_ `ember-fetch`, yet only importing from `fetch`.
38+
39+
## Transition Path
40+
41+
- Remove ember-fetch from all blueprints
42+
- Deprecate the npm package and archive the github repo.
43+
- Migrate to an alternative for "managed fetch"
44+
45+
### What does `ember-fetch` do?
46+
47+
_Primarily_, it wraps the native `fetch` in `waitForPromise` from `@ember/test-waiters` (aka "settled state integration").
48+
49+
50+
Secondarily, but not popularly used, are a series of utilities (e.g.: for checking kinds of errors). These could be copied into projects that use them and modified to fit each project's needs.
51+
52+
### Using native `fetch`
53+
54+
If you only use `ember-fetch` in route model-hooks, then the settled-state integration isn't used (or rather, you rely on the routing's settled-state integration, and `ember-fetch`'s settled-state integration is extraneous)
55+
56+
57+
### Direct replacement
58+
59+
60+
To replace `ember-fetch`'s core-functionality using the least amount of effort involves adding a new utility in `@ember/test-waiters`, `waitForFetch`:
61+
62+
```ts
63+
// in @ember/test-waiters
64+
import { waitForPromise } from './wait-for-promise';
65+
66+
export async function waitForFetch<Value>(fetchPromise: Promise<Value>) {
67+
waitForPromise(fetchPromise);
68+
69+
let response = await fetchPromise;
70+
71+
return new Proxy(response, {
72+
get(target, prop, receiver) {
73+
let original = Reflect.get(target, prop, receiver);
74+
75+
if (['json', 'text', 'arrayBuffer', 'blob', 'formData'].includes(prop)) {
76+
return (...args) => {
77+
let parsePromise = original.call(target, ...args);
78+
79+
return waitForPromise(parsePromise);
80+
}
81+
}
82+
83+
return original;
84+
}
85+
});
86+
}
87+
```
88+
89+
90+
To have a single import mirroring the behavior of `ember-fetch`, _in full_, folks can still provide a single export that does:
91+
92+
```ts
93+
import { waitForFetch } from '@ember/test-waiters';
94+
95+
export function wrappedFetch(...args: Parameters<typeof fetch>) {
96+
return waitForFetch(fetch(...args));
97+
}
98+
```
99+
100+
101+
And then throughout your project, you could find and replace all imports of `import fetch from 'fetch';` with `import { wrappedFetch } from 'app-name/utils/wrapped-fetch';`
102+
103+
104+
105+
### Using a service
106+
107+
Potentially an easier-to-manage implementation uses a service such as the following:
108+
109+
```ts
110+
import Service from '@ember/service';
111+
import { waitFor } from '@ember/test-waiters';
112+
113+
export default class Fetch extends Service {
114+
115+
@waitFor
116+
@action
117+
requestJson(...args: Parameters<typeof fetch>) {
118+
return fetch(...args).then(response => response.json());
119+
}
120+
121+
@waitFor
122+
@action
123+
requestText(...args: Parameters<typeof fetch>) {
124+
return fetch(...args).then(response => response.text());
125+
}
126+
}
127+
```
128+
129+
### Using warp-drive / ember-data
130+
131+
Docs available on https://github.com/emberjs/data/
132+
133+
## How We Teach This
134+
135+
- Add a deprecation notice to the ember-fetch README
136+
- Archive the ember-fetch repo
137+
- Remove ember-fetch from the blueprints
138+
- Remove ember-fetch from the guides (only one reference per version)
139+
140+
## Drawbacks
141+
142+
- if we keep ember-fetch is not compatible with modern tooling and modern SSR approaches
143+
144+
## Alternatives
145+
146+
- n/a
147+
- ask folks to wrap and proxy fetch themselves
148+
149+
## Unresolved questions
150+
151+
none

0 commit comments

Comments
 (0)