diff --git a/FEATURES.md b/FEATURES.md index f1de3c14e0e..a3904ed37eb 100644 --- a/FEATURES.md +++ b/FEATURES.md @@ -33,30 +33,6 @@ entry in `config/features.json`. Enables `pushPayload` to return the model(s) that are created or updated via the internal `store.push`. [PR 4110](https://github.com/emberjs/data/pull/4110) -- `ds-serialize-ids-and-types` - - Enables a new `ids-and-type` strategy (in addition to the already existing `ids` and `records`) for - serializing has many relationships using the `DS.EmbeddedRecordsMixin` that will include both - `id` and `type` of each model as an object. - - For instance, if a use has many pets, which is a polymorphic relationship, the generated payload would be: - - ```js - { - "user": { - "id": "1" - "name": "Bertin Osborne", - "pets": [ - { "id": "1", "type": "Cat" }, - { "id": "2", "type": "Parrot"} - ] - } - } - ``` - - This is particularly useful for polymorphic relationships not backed by STI when just including the id - of the records is not enough. - - `ds-extended-errors` Enables `extend` method on errors. It means you can extend from `DS.AdapterError`. diff --git a/addon/serializers/embedded-records-mixin.js b/addon/serializers/embedded-records-mixin.js index 32ff71fe03a..0bdc29290de 100644 --- a/addon/serializers/embedded-records-mixin.js +++ b/addon/serializers/embedded-records-mixin.js @@ -1,6 +1,5 @@ import Ember from 'ember'; import { warn } from "ember-data/-private/debug"; -import isEnabled from 'ember-data/-private/features'; var get = Ember.get; var set = Ember.set; @@ -365,8 +364,6 @@ export default Ember.Mixin.create({ } ``` - Note that the `ids-and-types` strategy is still behind the `ds-serialize-ids-and-types` feature flag. - @method serializeHasMany @param {DS.Snapshot} snapshot @param {Object} json @@ -384,16 +381,12 @@ export default Ember.Mixin.create({ json[serializedKey] = snapshot.hasMany(attr, { ids: true }); } else if (this.hasSerializeRecordsOption(attr)) { this._serializeEmbeddedHasMany(snapshot, json, relationship); - } else { - if (isEnabled("ds-serialize-ids-and-types")) { - if (this.hasSerializeIdsAndTypesOption(attr)) { - this._serializeHasManyAsIdsAndTypes(snapshot, json, relationship); - } - } + } else if (this.hasSerializeIdsAndTypesOption(attr)) { + this._serializeHasManyAsIdsAndTypes(snapshot, json, relationship); } }, - /** + /* Serializes a hasMany relationship as an array of objects containing only `id` and `type` keys. This has its use case on polymorphic hasMany relationships where the server is not storing diff --git a/config/features.json b/config/features.json index e499e6ff6ed..9ae9b4b894a 100644 --- a/config/features.json +++ b/config/features.json @@ -3,7 +3,6 @@ "ds-improved-ajax": null, "ds-transform-pass-options": true, "ds-pushpayload-return": null, - "ds-serialize-ids-and-types": true, "ds-extended-errors": null, "ds-links-in-record-array": null } diff --git a/tests/integration/serializers/embedded-records-mixin-test.js b/tests/integration/serializers/embedded-records-mixin-test.js index 0d8f4351931..4b151636adb 100644 --- a/tests/integration/serializers/embedded-records-mixin-test.js +++ b/tests/integration/serializers/embedded-records-mixin-test.js @@ -5,7 +5,6 @@ import testInDebug from 'dummy/tests/helpers/test-in-debug'; import {module, test} from 'qunit'; import DS from 'ember-data'; -import isEnabled from 'ember-data/-private/features'; var get = Ember.get; var HomePlanet, SuperVillain, CommanderVillain, NormalMinion, EvilMinion, YellowMinion, RedMinion, SecretLab, SecretWeapon, BatCave, Comment, @@ -1074,38 +1073,36 @@ test("serialize with embedded objects (hasMany relationships, including related }); }); -if (isEnabled("ds-serialize-ids-and-types")) { - test("serialize has many relationship using the `ids-and-types` strategy", function(assert) { - run(function() { - yellowMinion = env.store.createRecord('yellow-minion', { id: 1, name: "Yellowy" }); - redMinion = env.store.createRecord('red-minion', { id: 1, name: "Reddy" }); - commanderVillain = env.store.createRecord('commander-villain', { id: 1, name: "Jeff", minions: [yellowMinion, redMinion] }); - }); +test("serialize has many relationship using the `ids-and-types` strategy", function(assert) { + run(function() { + yellowMinion = env.store.createRecord('yellow-minion', { id: 1, name: "Yellowy" }); + redMinion = env.store.createRecord('red-minion', { id: 1, name: "Reddy" }); + commanderVillain = env.store.createRecord('commander-villain', { id: 1, name: "Jeff", minions: [yellowMinion, redMinion] }); + }); - env.registry.register('serializer:commander-villain', DS.RESTSerializer.extend(DS.EmbeddedRecordsMixin, { - attrs: { - minions: { serialize: 'ids-and-types' } - } - })); - var serializer, json; - run(function() { - serializer = env.container.lookup("serializer:commander-villain"); - var snapshot = commanderVillain._createSnapshot(); - json = serializer.serialize(snapshot); - }); + env.registry.register('serializer:commander-villain', DS.RESTSerializer.extend(DS.EmbeddedRecordsMixin, { + attrs: { + minions: { serialize: 'ids-and-types' } + } + })); + var serializer, json; + run(function() { + serializer = env.container.lookup("serializer:commander-villain"); + var snapshot = commanderVillain._createSnapshot(); + json = serializer.serialize(snapshot); + }); - assert.deepEqual(json, { - name: 'Jeff', - minions: [{ - id: '1', - type: 'yellow-minion' - }, { - id: '1', - type: 'red-minion' - }] - }); + assert.deepEqual(json, { + name: 'Jeff', + minions: [{ + id: '1', + type: 'yellow-minion' + }, { + id: '1', + type: 'red-minion' + }] }); -} +}); test("normalizeResponse with embedded object (belongsTo relationship)", function(assert) { env.registry.register('serializer:super-villain', DS.RESTSerializer.extend(DS.EmbeddedRecordsMixin, {