1 | ;
|
2 |
|
3 | var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
|
4 |
|
5 | var _Requestable2 = require('./Requestable');
|
6 |
|
7 | var _Requestable3 = _interopRequireDefault(_Requestable2);
|
8 |
|
9 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
10 |
|
11 | function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
|
12 |
|
13 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
14 |
|
15 | function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
|
16 |
|
17 | function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /**
|
18 | * @file
|
19 | * @copyright 2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.
|
20 | * @license Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.
|
21 | * Github.js is freely distributable.
|
22 | */
|
23 |
|
24 | /**
|
25 | * Project encapsulates the functionality to create, query, and modify cards and columns.
|
26 | */
|
27 | var Project = function (_Requestable) {
|
28 | _inherits(Project, _Requestable);
|
29 |
|
30 | /**
|
31 | * Create a Project.
|
32 | * @param {string} id - the id of the project
|
33 | * @param {Requestable.auth} [auth] - information required to authenticate to Github
|
34 | * @param {string} [apiBase=https://api.github.com] - the base Github API URL
|
35 | */
|
36 | function Project(id, auth, apiBase) {
|
37 | _classCallCheck(this, Project);
|
38 |
|
39 | var _this = _possibleConstructorReturn(this, (Project.__proto__ || Object.getPrototypeOf(Project)).call(this, auth, apiBase, 'inertia-preview'));
|
40 |
|
41 | _this.__id = id;
|
42 | return _this;
|
43 | }
|
44 |
|
45 | /**
|
46 | * Get information about a project
|
47 | * @see https://developer.github.com/v3/projects/#get-a-project
|
48 | * @param {Requestable.callback} cb - will receive the project information
|
49 | * @return {Promise} - the promise for the http request
|
50 | */
|
51 |
|
52 |
|
53 | _createClass(Project, [{
|
54 | key: 'getProject',
|
55 | value: function getProject(cb) {
|
56 | return this._request('GET', '/projects/' + this.__id, null, cb);
|
57 | }
|
58 |
|
59 | /**
|
60 | * Edit a project
|
61 | * @see https://developer.github.com/v3/projects/#update-a-project
|
62 | * @param {Object} options - the description of the project
|
63 | * @param {Requestable.callback} cb - will receive the modified project
|
64 | * @return {Promise} - the promise for the http request
|
65 | */
|
66 |
|
67 | }, {
|
68 | key: 'updateProject',
|
69 | value: function updateProject(options, cb) {
|
70 | return this._request('PATCH', '/projects/' + this.__id, options, cb);
|
71 | }
|
72 |
|
73 | /**
|
74 | * Delete a project
|
75 | * @see https://developer.github.com/v3/projects/#delete-a-project
|
76 | * @param {Requestable.callback} cb - will receive true if the operation is successful
|
77 | * @return {Promise} - the promise for the http request
|
78 | */
|
79 |
|
80 | }, {
|
81 | key: 'deleteProject',
|
82 | value: function deleteProject(cb) {
|
83 | return this._request('DELETE', '/projects/' + this.__id, null, cb);
|
84 | }
|
85 |
|
86 | /**
|
87 | * Get information about all columns of a project
|
88 | * @see https://developer.github.com/v3/projects/columns/#list-project-columns
|
89 | * @param {Requestable.callback} [cb] - will receive the list of columns
|
90 | * @return {Promise} - the promise for the http request
|
91 | */
|
92 |
|
93 | }, {
|
94 | key: 'listProjectColumns',
|
95 | value: function listProjectColumns(cb) {
|
96 | return this._requestAllPages('/projects/' + this.__id + '/columns', null, cb);
|
97 | }
|
98 |
|
99 | /**
|
100 | * Get information about a column
|
101 | * @see https://developer.github.com/v3/projects/columns/#get-a-project-column
|
102 | * @param {string} colId - the id of the column
|
103 | * @param {Requestable.callback} cb - will receive the column information
|
104 | * @return {Promise} - the promise for the http request
|
105 | */
|
106 |
|
107 | }, {
|
108 | key: 'getProjectColumn',
|
109 | value: function getProjectColumn(colId, cb) {
|
110 | return this._request('GET', '/projects/columns/' + colId, null, cb);
|
111 | }
|
112 |
|
113 | /**
|
114 | * Create a new column
|
115 | * @see https://developer.github.com/v3/projects/columns/#create-a-project-column
|
116 | * @param {Object} options - the description of the column
|
117 | * @param {Requestable.callback} cb - will receive the newly created column
|
118 | * @return {Promise} - the promise for the http request
|
119 | */
|
120 |
|
121 | }, {
|
122 | key: 'createProjectColumn',
|
123 | value: function createProjectColumn(options, cb) {
|
124 | return this._request('POST', '/projects/' + this.__id + '/columns', options, cb);
|
125 | }
|
126 |
|
127 | /**
|
128 | * Edit a column
|
129 | * @see https://developer.github.com/v3/projects/columns/#update-a-project-column
|
130 | * @param {string} colId - the column id
|
131 | * @param {Object} options - the description of the column
|
132 | * @param {Requestable.callback} cb - will receive the modified column
|
133 | * @return {Promise} - the promise for the http request
|
134 | */
|
135 |
|
136 | }, {
|
137 | key: 'updateProjectColumn',
|
138 | value: function updateProjectColumn(colId, options, cb) {
|
139 | return this._request('PATCH', '/projects/columns/' + colId, options, cb);
|
140 | }
|
141 |
|
142 | /**
|
143 | * Delete a column
|
144 | * @see https://developer.github.com/v3/projects/columns/#delete-a-project-column
|
145 | * @param {string} colId - the column to be deleted
|
146 | * @param {Requestable.callback} cb - will receive true if the operation is successful
|
147 | * @return {Promise} - the promise for the http request
|
148 | */
|
149 |
|
150 | }, {
|
151 | key: 'deleteProjectColumn',
|
152 | value: function deleteProjectColumn(colId, cb) {
|
153 | return this._request('DELETE', '/projects/columns/' + colId, null, cb);
|
154 | }
|
155 |
|
156 | /**
|
157 | * Move a column
|
158 | * @see https://developer.github.com/v3/projects/columns/#move-a-project-column
|
159 | * @param {string} colId - the column to be moved
|
160 | * @param {string} position - can be one of first, last, or after:<column-id>,
|
161 | * where <column-id> is the id value of a column in the same project.
|
162 | * @param {Requestable.callback} cb - will receive true if the operation is successful
|
163 | * @return {Promise} - the promise for the http request
|
164 | */
|
165 |
|
166 | }, {
|
167 | key: 'moveProjectColumn',
|
168 | value: function moveProjectColumn(colId, position, cb) {
|
169 | return this._request('POST', '/projects/columns/' + colId + '/moves', { position: position }, cb);
|
170 | }
|
171 |
|
172 | /**
|
173 | * Get information about all cards of a project
|
174 | * @see https://developer.github.com/v3/projects/cards/#list-project-cards
|
175 | * @param {Requestable.callback} [cb] - will receive the list of cards
|
176 | * @return {Promise} - the promise for the http request
|
177 | */
|
178 |
|
179 | }, {
|
180 | key: 'listProjectCards',
|
181 | value: function listProjectCards(cb) {
|
182 | var _this2 = this;
|
183 |
|
184 | return this.listProjectColumns().then(function (_ref) {
|
185 | var data = _ref.data;
|
186 |
|
187 | return Promise.all(data.map(function (column) {
|
188 | return _this2._requestAllPages('/projects/columns/' + column.id + '/cards', null);
|
189 | }));
|
190 | }).then(function (cardsInColumns) {
|
191 | var cards = cardsInColumns.reduce(function (prev, _ref2) {
|
192 | var data = _ref2.data;
|
193 |
|
194 | prev.push.apply(prev, _toConsumableArray(data));
|
195 | return prev;
|
196 | }, []);
|
197 | if (cb) {
|
198 | cb(null, cards);
|
199 | }
|
200 | return cards;
|
201 | }).catch(function (err) {
|
202 | if (cb) {
|
203 | cb(err);
|
204 | return;
|
205 | }
|
206 | throw err;
|
207 | });
|
208 | }
|
209 |
|
210 | /**
|
211 | * Get information about all cards of a column
|
212 | * @see https://developer.github.com/v3/projects/cards/#list-project-cards
|
213 | * @param {string} colId - the id of the column
|
214 | * @param {Requestable.callback} [cb] - will receive the list of cards
|
215 | * @return {Promise} - the promise for the http request
|
216 | */
|
217 |
|
218 | }, {
|
219 | key: 'listColumnCards',
|
220 | value: function listColumnCards(colId, cb) {
|
221 | return this._requestAllPages('/projects/columns/' + colId + '/cards', null, cb);
|
222 | }
|
223 |
|
224 | /**
|
225 | * Get information about a card
|
226 | * @see https://developer.github.com/v3/projects/cards/#get-a-project-card
|
227 | * @param {string} cardId - the id of the card
|
228 | * @param {Requestable.callback} cb - will receive the card information
|
229 | * @return {Promise} - the promise for the http request
|
230 | */
|
231 |
|
232 | }, {
|
233 | key: 'getProjectCard',
|
234 | value: function getProjectCard(cardId, cb) {
|
235 | return this._request('GET', '/projects/columns/cards/' + cardId, null, cb);
|
236 | }
|
237 |
|
238 | /**
|
239 | * Create a new card
|
240 | * @see https://developer.github.com/v3/projects/cards/#create-a-project-card
|
241 | * @param {string} colId - the column id
|
242 | * @param {Object} options - the description of the card
|
243 | * @param {Requestable.callback} cb - will receive the newly created card
|
244 | * @return {Promise} - the promise for the http request
|
245 | */
|
246 |
|
247 | }, {
|
248 | key: 'createProjectCard',
|
249 | value: function createProjectCard(colId, options, cb) {
|
250 | return this._request('POST', '/projects/columns/' + colId + '/cards', options, cb);
|
251 | }
|
252 |
|
253 | /**
|
254 | * Edit a card
|
255 | * @see https://developer.github.com/v3/projects/cards/#update-a-project-card
|
256 | * @param {string} cardId - the card id
|
257 | * @param {Object} options - the description of the card
|
258 | * @param {Requestable.callback} cb - will receive the modified card
|
259 | * @return {Promise} - the promise for the http request
|
260 | */
|
261 |
|
262 | }, {
|
263 | key: 'updateProjectCard',
|
264 | value: function updateProjectCard(cardId, options, cb) {
|
265 | return this._request('PATCH', '/projects/columns/cards/' + cardId, options, cb);
|
266 | }
|
267 |
|
268 | /**
|
269 | * Delete a card
|
270 | * @see https://developer.github.com/v3/projects/cards/#delete-a-project-card
|
271 | * @param {string} cardId - the card to be deleted
|
272 | * @param {Requestable.callback} cb - will receive true if the operation is successful
|
273 | * @return {Promise} - the promise for the http request
|
274 | */
|
275 |
|
276 | }, {
|
277 | key: 'deleteProjectCard',
|
278 | value: function deleteProjectCard(cardId, cb) {
|
279 | return this._request('DELETE', '/projects/columns/cards/' + cardId, null, cb);
|
280 | }
|
281 |
|
282 | /**
|
283 | * Move a card
|
284 | * @see https://developer.github.com/v3/projects/cards/#move-a-project-card
|
285 | * @param {string} cardId - the card to be moved
|
286 | * @param {string} position - can be one of top, bottom, or after:<card-id>,
|
287 | * where <card-id> is the id value of a card in the same project.
|
288 | * @param {string} colId - the id value of a column in the same project.
|
289 | * @param {Requestable.callback} cb - will receive true if the operation is successful
|
290 | * @return {Promise} - the promise for the http request
|
291 | */
|
292 |
|
293 | }, {
|
294 | key: 'moveProjectCard',
|
295 | value: function moveProjectCard(cardId, position, colId, cb) {
|
296 | return this._request('POST', '/projects/columns/cards/' + cardId + '/moves', { position: position, column_id: colId }, // eslint-disable-line camelcase
|
297 | cb);
|
298 | }
|
299 | }]);
|
300 |
|
301 | return Project;
|
302 | }(_Requestable3.default);
|
303 |
|
304 | module.exports = Project;
|
305 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Project.js"],"names":["Project","id","auth","apiBase","__id","cb","_request","options","_requestAllPages","colId","position","listProjectColumns","then","data","Promise","all","map","column","cardsInColumns","cards","reduce","prev","push","catch","err","cardId","column_id","Requestable","module","exports"],"mappings":"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","file":"Project.js","sourcesContent":["/**\n * @file\n * @copyright  2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.\n * @license    Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.\n *             Github.js is freely distributable.\n */\n\nimport Requestable from './Requestable';\n\n/**\n * Project encapsulates the functionality to create, query, and modify cards and columns.\n */\nclass Project extends Requestable {\n   /**\n    * Create a Project.\n    * @param {string} id - the id of the project\n    * @param {Requestable.auth} [auth] - information required to authenticate to Github\n    * @param {string} [apiBase=https://api.github.com] - the base Github API URL\n    */\n   constructor(id, auth, apiBase) {\n      super(auth, apiBase, 'inertia-preview');\n      this.__id = id;\n   }\n\n   /**\n    * Get information about a project\n    * @see https://developer.github.com/v3/projects/#get-a-project\n    * @param {Requestable.callback} cb - will receive the project information\n    * @return {Promise} - the promise for the http request\n    */\n   getProject(cb) {\n      return this._request('GET', `/projects/${this.__id}`, null, cb);\n   }\n\n   /**\n    * Edit a project\n    * @see https://developer.github.com/v3/projects/#update-a-project\n    * @param {Object} options - the description of the project\n    * @param {Requestable.callback} cb - will receive the modified project\n    * @return {Promise} - the promise for the http request\n    */\n   updateProject(options, cb) {\n      return this._request('PATCH', `/projects/${this.__id}`, options, cb);\n   }\n\n   /**\n    * Delete a project\n    * @see https://developer.github.com/v3/projects/#delete-a-project\n    * @param {Requestable.callback} cb - will receive true if the operation is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteProject(cb) {\n      return this._request('DELETE', `/projects/${this.__id}`, null, cb);\n   }\n\n   /**\n    * Get information about all columns of a project\n    * @see https://developer.github.com/v3/projects/columns/#list-project-columns\n    * @param {Requestable.callback} [cb] - will receive the list of columns\n    * @return {Promise} - the promise for the http request\n    */\n   listProjectColumns(cb) {\n      return this._requestAllPages(`/projects/${this.__id}/columns`, null, cb);\n   }\n\n   /**\n    * Get information about a column\n    * @see https://developer.github.com/v3/projects/columns/#get-a-project-column\n    * @param {string} colId - the id of the column\n    * @param {Requestable.callback} cb - will receive the column information\n    * @return {Promise} - the promise for the http request\n    */\n   getProjectColumn(colId, cb) {\n      return this._request('GET', `/projects/columns/${colId}`, null, cb);\n   }\n\n   /**\n    * Create a new column\n    * @see https://developer.github.com/v3/projects/columns/#create-a-project-column\n    * @param {Object} options - the description of the column\n    * @param {Requestable.callback} cb - will receive the newly created column\n    * @return {Promise} - the promise for the http request\n    */\n   createProjectColumn(options, cb) {\n      return this._request('POST', `/projects/${this.__id}/columns`, options, cb);\n   }\n\n   /**\n    * Edit a column\n    * @see https://developer.github.com/v3/projects/columns/#update-a-project-column\n    * @param {string} colId - the column id\n    * @param {Object} options - the description of the column\n    * @param {Requestable.callback} cb - will receive the modified column\n    * @return {Promise} - the promise for the http request\n    */\n   updateProjectColumn(colId, options, cb) {\n      return this._request('PATCH', `/projects/columns/${colId}`, options, cb);\n   }\n\n   /**\n    * Delete a column\n    * @see https://developer.github.com/v3/projects/columns/#delete-a-project-column\n    * @param {string} colId - the column to be deleted\n    * @param {Requestable.callback} cb - will receive true if the operation is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteProjectColumn(colId, cb) {\n      return this._request('DELETE', `/projects/columns/${colId}`, null, cb);\n   }\n\n   /**\n    * Move a column\n    * @see https://developer.github.com/v3/projects/columns/#move-a-project-column\n    * @param {string} colId - the column to be moved\n    * @param {string} position - can be one of first, last, or after:<column-id>,\n    * where <column-id> is the id value of a column in the same project.\n    * @param {Requestable.callback} cb - will receive true if the operation is successful\n    * @return {Promise} - the promise for the http request\n    */\n   moveProjectColumn(colId, position, cb) {\n      return this._request(\n         'POST',\n         `/projects/columns/${colId}/moves`,\n         {position: position},\n         cb\n      );\n   }\n\n  /**\n   * Get information about all cards of a project\n   * @see https://developer.github.com/v3/projects/cards/#list-project-cards\n   * @param {Requestable.callback} [cb] - will receive the list of cards\n   * @return {Promise} - the promise for the http request\n   */\n   listProjectCards(cb) {\n      return this.listProjectColumns()\n        .then(({data}) => {\n           return Promise.all(data.map((column) => {\n              return this._requestAllPages(`/projects/columns/${column.id}/cards`, null);\n           }));\n        }).then((cardsInColumns) => {\n           const cards = cardsInColumns.reduce((prev, {data}) => {\n              prev.push(...data);\n              return prev;\n           }, []);\n           if (cb) {\n              cb(null, cards);\n           }\n           return cards;\n        }).catch((err) => {\n           if (cb) {\n              cb(err);\n              return;\n           }\n           throw err;\n        });\n   }\n\n   /**\n   * Get information about all cards of a column\n   * @see https://developer.github.com/v3/projects/cards/#list-project-cards\n   * @param {string} colId - the id of the column\n   * @param {Requestable.callback} [cb] - will receive the list of cards\n   * @return {Promise} - the promise for the http request\n   */\n   listColumnCards(colId, cb) {\n      return this._requestAllPages(`/projects/columns/${colId}/cards`, null, cb);\n   }\n\n   /**\n   * Get information about a card\n   * @see https://developer.github.com/v3/projects/cards/#get-a-project-card\n   * @param {string} cardId - the id of the card\n   * @param {Requestable.callback} cb - will receive the card information\n   * @return {Promise} - the promise for the http request\n   */\n   getProjectCard(cardId, cb) {\n      return this._request('GET', `/projects/columns/cards/${cardId}`, null, cb);\n   }\n\n   /**\n   * Create a new card\n   * @see https://developer.github.com/v3/projects/cards/#create-a-project-card\n   * @param {string} colId - the column id\n   * @param {Object} options - the description of the card\n   * @param {Requestable.callback} cb - will receive the newly created card\n   * @return {Promise} - the promise for the http request\n   */\n   createProjectCard(colId, options, cb) {\n      return this._request('POST', `/projects/columns/${colId}/cards`, options, cb);\n   }\n\n   /**\n   * Edit a card\n   * @see https://developer.github.com/v3/projects/cards/#update-a-project-card\n   * @param {string} cardId - the card id\n   * @param {Object} options - the description of the card\n   * @param {Requestable.callback} cb - will receive the modified card\n   * @return {Promise} - the promise for the http request\n   */\n   updateProjectCard(cardId, options, cb) {\n      return this._request('PATCH', `/projects/columns/cards/${cardId}`, options, cb);\n   }\n\n   /**\n   * Delete a card\n   * @see https://developer.github.com/v3/projects/cards/#delete-a-project-card\n   * @param {string} cardId - the card to be deleted\n   * @param {Requestable.callback} cb - will receive true if the operation is successful\n   * @return {Promise} - the promise for the http request\n   */\n   deleteProjectCard(cardId, cb) {\n      return this._request('DELETE', `/projects/columns/cards/${cardId}`, null, cb);\n   }\n\n   /**\n   * Move a card\n   * @see https://developer.github.com/v3/projects/cards/#move-a-project-card\n   * @param {string} cardId - the card to be moved\n   * @param {string} position - can be one of top, bottom, or after:<card-id>,\n   * where <card-id> is the id value of a card in the same project.\n   * @param {string} colId - the id value of a column in the same project.\n   * @param {Requestable.callback} cb - will receive true if the operation is successful\n   * @return {Promise} - the promise for the http request\n   */\n   moveProjectCard(cardId, position, colId, cb) {\n      return this._request(\n         'POST',\n         `/projects/columns/cards/${cardId}/moves`,\n         {position: position, column_id: colId}, // eslint-disable-line camelcase\n         cb\n      );\n   }\n}\n\nmodule.exports = Project;\n"]}
|
306 | //# sourceMappingURL=Project.js.map
|