ParseRelation.js 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. "use strict";
  2. var _Object$defineProperty = require("@babel/runtime-corejs3/core-js-stable/object/define-property");
  3. var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
  4. _Object$defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.default = void 0;
  8. var _isArray = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/array/is-array"));
  9. var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/classCallCheck"));
  10. var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/createClass"));
  11. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
  12. var _ParseOp = require("./ParseOp");
  13. var _ParseObject = _interopRequireDefault(require("./ParseObject"));
  14. var _ParseQuery = _interopRequireDefault(require("./ParseQuery"));
  15. /**
  16. * @flow
  17. */
  18. /**
  19. * Creates a new Relation for the given parent object and key. This
  20. * constructor should rarely be used directly, but rather created by
  21. * Parse.Object.relation.
  22. *
  23. * <p>
  24. * A class that is used to access all of the children of a many-to-many
  25. * relationship. Each instance of Parse.Relation is associated with a
  26. * particular parent object and key.
  27. * </p>
  28. *
  29. * @alias Parse.Relation
  30. */
  31. var ParseRelation = /*#__PURE__*/function () {
  32. /**
  33. * @param {Parse.Object} parent The parent of this relation.
  34. * @param {string} key The key for this relation on the parent.
  35. */
  36. function ParseRelation(parent /*: ?ParseObject*/, key /*: ?string*/) {
  37. (0, _classCallCheck2.default)(this, ParseRelation);
  38. (0, _defineProperty2.default)(this, "parent", void 0);
  39. (0, _defineProperty2.default)(this, "key", void 0);
  40. (0, _defineProperty2.default)(this, "targetClassName", void 0);
  41. this.parent = parent;
  42. this.key = key;
  43. this.targetClassName = null;
  44. }
  45. /*
  46. * Makes sure that this relation has the right parent and key.
  47. */
  48. (0, _createClass2.default)(ParseRelation, [{
  49. key: "_ensureParentAndKey",
  50. value: function (parent /*: ParseObject*/, key /*: string*/) {
  51. this.key = this.key || key;
  52. if (this.key !== key) {
  53. throw new Error('Internal Error. Relation retrieved from two different keys.');
  54. }
  55. if (this.parent) {
  56. if (this.parent.className !== parent.className) {
  57. throw new Error('Internal Error. Relation retrieved from two different Objects.');
  58. }
  59. if (this.parent.id) {
  60. if (this.parent.id !== parent.id) {
  61. throw new Error('Internal Error. Relation retrieved from two different Objects.');
  62. }
  63. } else if (parent.id) {
  64. this.parent = parent;
  65. }
  66. } else {
  67. this.parent = parent;
  68. }
  69. }
  70. /**
  71. * Adds a Parse.Object or an array of Parse.Objects to the relation.
  72. *
  73. * @param {(Parse.Object|Array)} objects The item or items to add.
  74. * @returns {Parse.Object} The parent of the relation.
  75. */
  76. }, {
  77. key: "add",
  78. value: function (objects /*: ParseObject | Array<ParseObject | string>*/) /*: ParseObject*/{
  79. if (!(0, _isArray.default)(objects)) {
  80. objects = [objects];
  81. }
  82. var change = new _ParseOp.RelationOp(objects, []);
  83. var parent = this.parent;
  84. if (!parent) {
  85. throw new Error('Cannot add to a Relation without a parent');
  86. }
  87. if (objects.length === 0) {
  88. return parent;
  89. }
  90. parent.set(this.key, change);
  91. this.targetClassName = change._targetClassName;
  92. return parent;
  93. }
  94. /**
  95. * Removes a Parse.Object or an array of Parse.Objects from this relation.
  96. *
  97. * @param {(Parse.Object|Array)} objects The item or items to remove.
  98. */
  99. }, {
  100. key: "remove",
  101. value: function (objects /*: ParseObject | Array<ParseObject | string>*/) {
  102. if (!(0, _isArray.default)(objects)) {
  103. objects = [objects];
  104. }
  105. var change = new _ParseOp.RelationOp([], objects);
  106. if (!this.parent) {
  107. throw new Error('Cannot remove from a Relation without a parent');
  108. }
  109. if (objects.length === 0) {
  110. return;
  111. }
  112. this.parent.set(this.key, change);
  113. this.targetClassName = change._targetClassName;
  114. }
  115. /**
  116. * Returns a JSON version of the object suitable for saving to disk.
  117. *
  118. * @returns {object} JSON representation of Relation
  119. */
  120. }, {
  121. key: "toJSON",
  122. value: function () /*: { __type: 'Relation', className: ?string }*/{
  123. return {
  124. __type: 'Relation',
  125. className: this.targetClassName
  126. };
  127. }
  128. /**
  129. * Returns a Parse.Query that is limited to objects in this
  130. * relation.
  131. *
  132. * @returns {Parse.Query} Relation Query
  133. */
  134. }, {
  135. key: "query",
  136. value: function query() /*: ParseQuery*/{
  137. var query;
  138. var parent = this.parent;
  139. if (!parent) {
  140. throw new Error('Cannot construct a query for a Relation without a parent');
  141. }
  142. if (!this.targetClassName) {
  143. query = new _ParseQuery.default(parent.className);
  144. query._extraOptions.redirectClassNameForKey = this.key;
  145. } else {
  146. query = new _ParseQuery.default(this.targetClassName);
  147. }
  148. query._addCondition('$relatedTo', 'object', {
  149. __type: 'Pointer',
  150. className: parent.className,
  151. objectId: parent.id
  152. });
  153. query._addCondition('$relatedTo', 'key', this.key);
  154. return query;
  155. }
  156. }]);
  157. return ParseRelation;
  158. }();
  159. var _default = ParseRelation;
  160. exports.default = _default;