UNPKG

31.4 kBJavaScriptView Raw
1'use strict';
2
3var _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
5var _Requestable2 = require('./Requestable');
6
7var _Requestable3 = _interopRequireDefault(_Requestable2);
8
9function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
10
11function _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
13function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
14
15function _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
17function _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 */
27var 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
304module.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