Skip to content

Commit

Permalink
Merge pull request #1 from Serabe/update-on-rfc
Browse files Browse the repository at this point in the history
Update on RFC
  • Loading branch information
Serabe authored Aug 10, 2017
2 parents 980b0e6 + dcadbc1 commit 7bd7e66
Showing 1 changed file with 3 additions and 7 deletions.
10 changes: 3 additions & 7 deletions text/0000-deprecation-ember-string.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@

# Summary

This PR proposes the deprecation of `Ember.String`. The following methods will be moved to an addon:
This PR proposes the deprecation of extending `String` with the methods in `Ember.String` and accessing those directly. Furthermore, the following methods will be moved to a new `@ember/string` addon.

- `camelize`
- `capitalize`
Expand All @@ -18,13 +18,11 @@ This PR proposes the deprecation of `Ember.String`. The following methods will b

The remaining methods (`htmlSafe` and `isHTMLSafe`) will be moved to `@ember/component`.

In both cases, the String prototype won't be extended anymore.

# Motivation

`Ember.String` was introduced long ago, even before 1.0 was released. It was a time without the current ecosystem of addons. There were no ES6 modules, no Ember CLI and no Ember addons. Global mode was the way to go and prototypes of classes like `String`, `Array` and `Function` were being extended.

A lot of nice-to-have functionality was added at that time but now Ember is lifting weight. These functions belong in an addon, where it can be maintained and evolve without being tied to the core of the framework.
A lot of nice-to-have functionality was added at that time but now Ember has a better ecosystem. These functions belong in an addon, where it can be maintained and evolve without being tied to the core of the framework.

Also, this would let people swap the function for similar implementations but different behaviour in edge cases.

Expand All @@ -43,8 +41,6 @@ Ember guides' section on _disabling prototype extension_ would need to remove re

Main usage of these functions are in blueprints or connecting to APIs where converting the type of case of keys was needed. It is also used in Ember Data.

Furthermore, when people have moved to the new shims, moving to an addon would be as easy as to change the import path.

For `htmlSafe` and `isHTMLSafe`, the move is easier since the methods are easier related to components than to strings.

In any case, a basic Ember Watson recipe would be easy to provide.
Expand All @@ -53,7 +49,7 @@ In any case, a basic Ember Watson recipe would be easy to provide.

A lot of addons that deal with names depend on this behaviour, so they will need to install the addon. Also, Ember Data and some external serializers require these functions.

`htmlSafe` and `isHTMLSafe` would need to change packages as well, thus the reason to try and provide an Ember Watson recipe.
`htmlSafe` and `isHTMLSafe` would need to change packages, thus the reason to try and provide an Ember Watson recipe.

# Alternatives

Expand Down

0 comments on commit 7bd7e66

Please sign in to comment.