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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
12 |
|
13 | 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; }
|
14 |
|
15 | 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; } /**
|
16 | * @file
|
17 | * @copyright 2013 Michael Aufreiter (Development Seed) and 2016 Yahoo Inc.
|
18 | * @license Licensed under {@link https://spdx.org/licenses/BSD-3-Clause-Clear.html BSD-3-Clause-Clear}.
|
19 | * Github.js is freely distributable.
|
20 | */
|
21 |
|
22 | /**
|
23 | * Issue wraps the functionality to get issues for repositories
|
24 | */
|
25 | var Issue = function (_Requestable) {
|
26 | _inherits(Issue, _Requestable);
|
27 |
|
28 | /**
|
29 | * Create a new Issue
|
30 | * @param {string} repository - the full name of the repository (`:user/:repo`) to get issues for
|
31 | * @param {Requestable.auth} [auth] - information required to authenticate to Github
|
32 | * @param {string} [apiBase=https://api.github.com] - the base Github API URL
|
33 | */
|
34 | function Issue(repository, auth, apiBase) {
|
35 | _classCallCheck(this, Issue);
|
36 |
|
37 | var _this = _possibleConstructorReturn(this, (Issue.__proto__ || Object.getPrototypeOf(Issue)).call(this, auth, apiBase));
|
38 |
|
39 | _this.__repository = repository;
|
40 | return _this;
|
41 | }
|
42 |
|
43 | /**
|
44 | * Create a new issue
|
45 | * @see https://developer.github.com/v3/issues/#create-an-issue
|
46 | * @param {Object} issueData - the issue to create
|
47 | * @param {Requestable.callback} [cb] - will receive the created issue
|
48 | * @return {Promise} - the promise for the http request
|
49 | */
|
50 |
|
51 |
|
52 | _createClass(Issue, [{
|
53 | key: 'createIssue',
|
54 | value: function createIssue(issueData, cb) {
|
55 | return this._request('POST', '/repos/' + this.__repository + '/issues', issueData, cb);
|
56 | }
|
57 |
|
58 | /**
|
59 | * List the issues for the repository
|
60 | * @see https://developer.github.com/v3/issues/#list-issues-for-a-repository
|
61 | * @param {Object} options - filtering options
|
62 | * @param {Requestable.callback} [cb] - will receive the array of issues
|
63 | * @return {Promise} - the promise for the http request
|
64 | */
|
65 |
|
66 | }, {
|
67 | key: 'listIssues',
|
68 | value: function listIssues(options, cb) {
|
69 | return this._requestAllPages('/repos/' + this.__repository + '/issues', options, cb);
|
70 | }
|
71 |
|
72 | /**
|
73 | * List the events for an issue
|
74 | * @see https://developer.github.com/v3/issues/events/#list-events-for-an-issue
|
75 | * @param {number} issue - the issue to get events for
|
76 | * @param {Requestable.callback} [cb] - will receive the list of events
|
77 | * @return {Promise} - the promise for the http request
|
78 | */
|
79 |
|
80 | }, {
|
81 | key: 'listIssueEvents',
|
82 | value: function listIssueEvents(issue, cb) {
|
83 | return this._request('GET', '/repos/' + this.__repository + '/issues/' + issue + '/events', null, cb);
|
84 | }
|
85 |
|
86 | /**
|
87 | * List comments on an issue
|
88 | * @see https://developer.github.com/v3/issues/comments/#list-comments-on-an-issue
|
89 | * @param {number} issue - the id of the issue to get comments from
|
90 | * @param {Requestable.callback} [cb] - will receive the comments
|
91 | * @return {Promise} - the promise for the http request
|
92 | */
|
93 |
|
94 | }, {
|
95 | key: 'listIssueComments',
|
96 | value: function listIssueComments(issue, cb) {
|
97 | return this._request('GET', '/repos/' + this.__repository + '/issues/' + issue + '/comments', null, cb);
|
98 | }
|
99 |
|
100 | /**
|
101 | * Get a single comment on an issue
|
102 | * @see https://developer.github.com/v3/issues/comments/#get-a-single-comment
|
103 | * @param {number} id - the comment id to get
|
104 | * @param {Requestable.callback} [cb] - will receive the comment
|
105 | * @return {Promise} - the promise for the http request
|
106 | */
|
107 |
|
108 | }, {
|
109 | key: 'getIssueComment',
|
110 | value: function getIssueComment(id, cb) {
|
111 | return this._request('GET', '/repos/' + this.__repository + '/issues/comments/' + id, null, cb);
|
112 | }
|
113 |
|
114 | /**
|
115 | * Comment on an issue
|
116 | * @see https://developer.github.com/v3/issues/comments/#create-a-comment
|
117 | * @param {number} issue - the id of the issue to comment on
|
118 | * @param {string} comment - the comment to add
|
119 | * @param {Requestable.callback} [cb] - will receive the created comment
|
120 | * @return {Promise} - the promise for the http request
|
121 | */
|
122 |
|
123 | }, {
|
124 | key: 'createIssueComment',
|
125 | value: function createIssueComment(issue, comment, cb) {
|
126 | return this._request('POST', '/repos/' + this.__repository + '/issues/' + issue + '/comments', { body: comment }, cb);
|
127 | }
|
128 |
|
129 | /**
|
130 | * Edit a comment on an issue
|
131 | * @see https://developer.github.com/v3/issues/comments/#edit-a-comment
|
132 | * @param {number} id - the comment id to edit
|
133 | * @param {string} comment - the comment to edit
|
134 | * @param {Requestable.callback} [cb] - will receive the edited comment
|
135 | * @return {Promise} - the promise for the http request
|
136 | */
|
137 |
|
138 | }, {
|
139 | key: 'editIssueComment',
|
140 | value: function editIssueComment(id, comment, cb) {
|
141 | return this._request('PATCH', '/repos/' + this.__repository + '/issues/comments/' + id, { body: comment }, cb);
|
142 | }
|
143 |
|
144 | /**
|
145 | * Delete a comment on an issue
|
146 | * @see https://developer.github.com/v3/issues/comments/#delete-a-comment
|
147 | * @param {number} id - the comment id to delete
|
148 | * @param {Requestable.callback} [cb] - will receive true if the request is successful
|
149 | * @return {Promise} - the promise for the http request
|
150 | */
|
151 |
|
152 | }, {
|
153 | key: 'deleteIssueComment',
|
154 | value: function deleteIssueComment(id, cb) {
|
155 | return this._request('DELETE', '/repos/' + this.__repository + '/issues/comments/' + id, null, cb);
|
156 | }
|
157 |
|
158 | /**
|
159 | * Edit an issue
|
160 | * @see https://developer.github.com/v3/issues/#edit-an-issue
|
161 | * @param {number} issue - the issue number to edit
|
162 | * @param {Object} issueData - the new issue data
|
163 | * @param {Requestable.callback} [cb] - will receive the modified issue
|
164 | * @return {Promise} - the promise for the http request
|
165 | */
|
166 |
|
167 | }, {
|
168 | key: 'editIssue',
|
169 | value: function editIssue(issue, issueData, cb) {
|
170 | return this._request('PATCH', '/repos/' + this.__repository + '/issues/' + issue, issueData, cb);
|
171 | }
|
172 |
|
173 | /**
|
174 | * Get a particular issue
|
175 | * @see https://developer.github.com/v3/issues/#get-a-single-issue
|
176 | * @param {number} issue - the issue number to fetch
|
177 | * @param {Requestable.callback} [cb] - will receive the issue
|
178 | * @return {Promise} - the promise for the http request
|
179 | */
|
180 |
|
181 | }, {
|
182 | key: 'getIssue',
|
183 | value: function getIssue(issue, cb) {
|
184 | return this._request('GET', '/repos/' + this.__repository + '/issues/' + issue, null, cb);
|
185 | }
|
186 |
|
187 | /**
|
188 | * List the milestones for the repository
|
189 | * @see https://developer.github.com/v3/issues/milestones/#list-milestones-for-a-repository
|
190 | * @param {Object} options - filtering options
|
191 | * @param {Requestable.callback} [cb] - will receive the array of milestones
|
192 | * @return {Promise} - the promise for the http request
|
193 | */
|
194 |
|
195 | }, {
|
196 | key: 'listMilestones',
|
197 | value: function listMilestones(options, cb) {
|
198 | return this._request('GET', '/repos/' + this.__repository + '/milestones', options, cb);
|
199 | }
|
200 |
|
201 | /**
|
202 | * Get a milestone
|
203 | * @see https://developer.github.com/v3/issues/milestones/#get-a-single-milestone
|
204 | * @param {string} milestone - the id of the milestone to fetch
|
205 | * @param {Requestable.callback} [cb] - will receive the milestone
|
206 | * @return {Promise} - the promise for the http request
|
207 | */
|
208 |
|
209 | }, {
|
210 | key: 'getMilestone',
|
211 | value: function getMilestone(milestone, cb) {
|
212 | return this._request('GET', '/repos/' + this.__repository + '/milestones/' + milestone, null, cb);
|
213 | }
|
214 |
|
215 | /**
|
216 | * Create a new milestone
|
217 | * @see https://developer.github.com/v3/issues/milestones/#create-a-milestone
|
218 | * @param {Object} milestoneData - the milestone definition
|
219 | * @param {Requestable.callback} [cb] - will receive the milestone
|
220 | * @return {Promise} - the promise for the http request
|
221 | */
|
222 |
|
223 | }, {
|
224 | key: 'createMilestone',
|
225 | value: function createMilestone(milestoneData, cb) {
|
226 | return this._request('POST', '/repos/' + this.__repository + '/milestones', milestoneData, cb);
|
227 | }
|
228 |
|
229 | /**
|
230 | * Edit a milestone
|
231 | * @see https://developer.github.com/v3/issues/milestones/#update-a-milestone
|
232 | * @param {string} milestone - the id of the milestone to edit
|
233 | * @param {Object} milestoneData - the updates to make to the milestone
|
234 | * @param {Requestable.callback} [cb] - will receive the updated milestone
|
235 | * @return {Promise} - the promise for the http request
|
236 | */
|
237 |
|
238 | }, {
|
239 | key: 'editMilestone',
|
240 | value: function editMilestone(milestone, milestoneData, cb) {
|
241 | return this._request('PATCH', '/repos/' + this.__repository + '/milestones/' + milestone, milestoneData, cb);
|
242 | }
|
243 |
|
244 | /**
|
245 | * Delete a milestone (this is distinct from closing a milestone)
|
246 | * @see https://developer.github.com/v3/issues/milestones/#delete-a-milestone
|
247 | * @param {string} milestone - the id of the milestone to delete
|
248 | * @param {Requestable.callback} [cb] - will receive the status
|
249 | * @return {Promise} - the promise for the http request
|
250 | */
|
251 |
|
252 | }, {
|
253 | key: 'deleteMilestone',
|
254 | value: function deleteMilestone(milestone, cb) {
|
255 | return this._request('DELETE', '/repos/' + this.__repository + '/milestones/' + milestone, null, cb);
|
256 | }
|
257 |
|
258 | /**
|
259 | * Create a new label
|
260 | * @see https://developer.github.com/v3/issues/labels/#create-a-label
|
261 | * @param {Object} labelData - the label definition
|
262 | * @param {Requestable.callback} [cb] - will receive the object representing the label
|
263 | * @return {Promise} - the promise for the http request
|
264 | */
|
265 |
|
266 | }, {
|
267 | key: 'createLabel',
|
268 | value: function createLabel(labelData, cb) {
|
269 | return this._request('POST', '/repos/' + this.__repository + '/labels', labelData, cb);
|
270 | }
|
271 |
|
272 | /**
|
273 | * List the labels for the repository
|
274 | * @see https://developer.github.com/v3/issues/labels/#list-all-labels-for-this-repository
|
275 | * @param {Object} options - filtering options
|
276 | * @param {Requestable.callback} [cb] - will receive the array of labels
|
277 | * @return {Promise} - the promise for the http request
|
278 | */
|
279 |
|
280 | }, {
|
281 | key: 'listLabels',
|
282 | value: function listLabels(options, cb) {
|
283 | return this._request('GET', '/repos/' + this.__repository + '/labels', options, cb);
|
284 | }
|
285 |
|
286 | /**
|
287 | * Get a label
|
288 | * @see https://developer.github.com/v3/issues/labels/#get-a-single-label
|
289 | * @param {string} label - the name of the label to fetch
|
290 | * @param {Requestable.callback} [cb] - will receive the label
|
291 | * @return {Promise} - the promise for the http request
|
292 | */
|
293 |
|
294 | }, {
|
295 | key: 'getLabel',
|
296 | value: function getLabel(label, cb) {
|
297 | return this._request('GET', '/repos/' + this.__repository + '/labels/' + label, null, cb);
|
298 | }
|
299 |
|
300 | /**
|
301 | * Edit a label
|
302 | * @see https://developer.github.com/v3/issues/labels/#update-a-label
|
303 | * @param {string} label - the name of the label to edit
|
304 | * @param {Object} labelData - the updates to make to the label
|
305 | * @param {Requestable.callback} [cb] - will receive the updated label
|
306 | * @return {Promise} - the promise for the http request
|
307 | */
|
308 |
|
309 | }, {
|
310 | key: 'editLabel',
|
311 | value: function editLabel(label, labelData, cb) {
|
312 | return this._request('PATCH', '/repos/' + this.__repository + '/labels/' + label, labelData, cb);
|
313 | }
|
314 |
|
315 | /**
|
316 | * Delete a label
|
317 | * @see https://developer.github.com/v3/issues/labels/#delete-a-label
|
318 | * @param {string} label - the name of the label to delete
|
319 | * @param {Requestable.callback} [cb] - will receive the status
|
320 | * @return {Promise} - the promise for the http request
|
321 | */
|
322 |
|
323 | }, {
|
324 | key: 'deleteLabel',
|
325 | value: function deleteLabel(label, cb) {
|
326 | return this._request('DELETE', '/repos/' + this.__repository + '/labels/' + label, null, cb);
|
327 | }
|
328 | }]);
|
329 |
|
330 | return Issue;
|
331 | }(_Requestable3.default);
|
332 |
|
333 | module.exports = Issue;
|
334 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Issue.js"],"names":["Issue","repository","auth","apiBase","__repository","issueData","cb","_request","options","_requestAllPages","issue","id","comment","body","milestone","milestoneData","labelData","label","Requestable","module","exports"],"mappings":"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","file":"Issue.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 * Issue wraps the functionality to get issues for repositories\n */\nclass Issue extends Requestable {\n   /**\n    * Create a new Issue\n    * @param {string} repository - the full name of the repository (`:user/:repo`) to get issues for\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(repository, auth, apiBase) {\n      super(auth, apiBase);\n      this.__repository = repository;\n   }\n\n   /**\n    * Create a new issue\n    * @see https://developer.github.com/v3/issues/#create-an-issue\n    * @param {Object} issueData - the issue to create\n    * @param {Requestable.callback} [cb] - will receive the created issue\n    * @return {Promise} - the promise for the http request\n    */\n   createIssue(issueData, cb) {\n      return this._request('POST', `/repos/${this.__repository}/issues`, issueData, cb);\n   }\n\n   /**\n    * List the issues for the repository\n    * @see https://developer.github.com/v3/issues/#list-issues-for-a-repository\n    * @param {Object} options - filtering options\n    * @param {Requestable.callback} [cb] - will receive the array of issues\n    * @return {Promise} - the promise for the http request\n    */\n   listIssues(options, cb) {\n      return this._requestAllPages(`/repos/${this.__repository}/issues`, options, cb);\n   }\n\n   /**\n    * List the events for an issue\n    * @see https://developer.github.com/v3/issues/events/#list-events-for-an-issue\n    * @param {number} issue - the issue to get events for\n    * @param {Requestable.callback} [cb] - will receive the list of events\n    * @return {Promise} - the promise for the http request\n    */\n   listIssueEvents(issue, cb) {\n      return this._request('GET', `/repos/${this.__repository}/issues/${issue}/events`, null, cb);\n   }\n\n   /**\n    * List comments on an issue\n    * @see https://developer.github.com/v3/issues/comments/#list-comments-on-an-issue\n    * @param {number} issue - the id of the issue to get comments from\n    * @param {Requestable.callback} [cb] - will receive the comments\n    * @return {Promise} - the promise for the http request\n    */\n   listIssueComments(issue, cb) {\n      return this._request('GET', `/repos/${this.__repository}/issues/${issue}/comments`, null, cb);\n   }\n\n   /**\n    * Get a single comment on an issue\n    * @see https://developer.github.com/v3/issues/comments/#get-a-single-comment\n    * @param {number} id - the comment id to get\n    * @param {Requestable.callback} [cb] - will receive the comment\n    * @return {Promise} - the promise for the http request\n    */\n   getIssueComment(id, cb) {\n      return this._request('GET', `/repos/${this.__repository}/issues/comments/${id}`, null, cb);\n   }\n\n   /**\n    * Comment on an issue\n    * @see https://developer.github.com/v3/issues/comments/#create-a-comment\n    * @param {number} issue - the id of the issue to comment on\n    * @param {string} comment - the comment to add\n    * @param {Requestable.callback} [cb] - will receive the created comment\n    * @return {Promise} - the promise for the http request\n    */\n   createIssueComment(issue, comment, cb) {\n      return this._request('POST', `/repos/${this.__repository}/issues/${issue}/comments`, {body: comment}, cb);\n   }\n\n   /**\n    * Edit a comment on an issue\n    * @see https://developer.github.com/v3/issues/comments/#edit-a-comment\n    * @param {number} id - the comment id to edit\n    * @param {string} comment - the comment to edit\n    * @param {Requestable.callback} [cb] - will receive the edited comment\n    * @return {Promise} - the promise for the http request\n    */\n   editIssueComment(id, comment, cb) {\n      return this._request('PATCH', `/repos/${this.__repository}/issues/comments/${id}`, {body: comment}, cb);\n   }\n\n   /**\n    * Delete a comment on an issue\n    * @see https://developer.github.com/v3/issues/comments/#delete-a-comment\n    * @param {number} id - the comment id to delete\n    * @param {Requestable.callback} [cb] - will receive true if the request is successful\n    * @return {Promise} - the promise for the http request\n    */\n   deleteIssueComment(id, cb) {\n      return this._request('DELETE', `/repos/${this.__repository}/issues/comments/${id}`, null, cb);\n   }\n\n   /**\n    * Edit an issue\n    * @see https://developer.github.com/v3/issues/#edit-an-issue\n    * @param {number} issue - the issue number to edit\n    * @param {Object} issueData - the new issue data\n    * @param {Requestable.callback} [cb] - will receive the modified issue\n    * @return {Promise} - the promise for the http request\n    */\n   editIssue(issue, issueData, cb) {\n      return this._request('PATCH', `/repos/${this.__repository}/issues/${issue}`, issueData, cb);\n   }\n\n   /**\n    * Get a particular issue\n    * @see https://developer.github.com/v3/issues/#get-a-single-issue\n    * @param {number} issue - the issue number to fetch\n    * @param {Requestable.callback} [cb] - will receive the issue\n    * @return {Promise} - the promise for the http request\n    */\n   getIssue(issue, cb) {\n      return this._request('GET', `/repos/${this.__repository}/issues/${issue}`, null, cb);\n   }\n\n   /**\n    * List the milestones for the repository\n    * @see https://developer.github.com/v3/issues/milestones/#list-milestones-for-a-repository\n    * @param {Object} options - filtering options\n    * @param {Requestable.callback} [cb] - will receive the array of milestones\n    * @return {Promise} - the promise for the http request\n    */\n   listMilestones(options, cb) {\n      return this._request('GET', `/repos/${this.__repository}/milestones`, options, cb);\n   }\n\n   /**\n    * Get a milestone\n    * @see https://developer.github.com/v3/issues/milestones/#get-a-single-milestone\n    * @param {string} milestone - the id of the milestone to fetch\n    * @param {Requestable.callback} [cb] - will receive the milestone\n    * @return {Promise} - the promise for the http request\n    */\n   getMilestone(milestone, cb) {\n      return this._request('GET', `/repos/${this.__repository}/milestones/${milestone}`, null, cb);\n   }\n\n   /**\n    * Create a new milestone\n    * @see https://developer.github.com/v3/issues/milestones/#create-a-milestone\n    * @param {Object} milestoneData - the milestone definition\n    * @param {Requestable.callback} [cb] - will receive the milestone\n    * @return {Promise} - the promise for the http request\n    */\n   createMilestone(milestoneData, cb) {\n      return this._request('POST', `/repos/${this.__repository}/milestones`, milestoneData, cb);\n   }\n\n   /**\n    * Edit a milestone\n    * @see https://developer.github.com/v3/issues/milestones/#update-a-milestone\n    * @param {string} milestone - the id of the milestone to edit\n    * @param {Object} milestoneData - the updates to make to the milestone\n    * @param {Requestable.callback} [cb] - will receive the updated milestone\n    * @return {Promise} - the promise for the http request\n    */\n   editMilestone(milestone, milestoneData, cb) {\n      return this._request('PATCH', `/repos/${this.__repository}/milestones/${milestone}`, milestoneData, cb);\n   }\n\n   /**\n    * Delete a milestone (this is distinct from closing a milestone)\n    * @see https://developer.github.com/v3/issues/milestones/#delete-a-milestone\n    * @param {string} milestone - the id of the milestone to delete\n    * @param {Requestable.callback} [cb] - will receive the status\n    * @return {Promise} - the promise for the http request\n    */\n   deleteMilestone(milestone, cb) {\n      return this._request('DELETE', `/repos/${this.__repository}/milestones/${milestone}`, null, cb);\n   }\n\n   /**\n    * Create a new label\n    * @see https://developer.github.com/v3/issues/labels/#create-a-label\n    * @param {Object} labelData - the label definition\n    * @param {Requestable.callback} [cb] - will receive the object representing the label\n    * @return {Promise} - the promise for the http request\n    */\n   createLabel(labelData, cb) {\n      return this._request('POST', `/repos/${this.__repository}/labels`, labelData, cb);\n   }\n\n  /**\n   * List the labels for the repository\n   * @see https://developer.github.com/v3/issues/labels/#list-all-labels-for-this-repository\n   * @param {Object} options - filtering options\n   * @param {Requestable.callback} [cb] - will receive the array of labels\n   * @return {Promise} - the promise for the http request\n   */\n   listLabels(options, cb) {\n      return this._request('GET', `/repos/${this.__repository}/labels`, options, cb);\n   }\n\n  /**\n   * Get a label\n   * @see https://developer.github.com/v3/issues/labels/#get-a-single-label\n   * @param {string} label - the name of the label to fetch\n   * @param {Requestable.callback} [cb] - will receive the label\n   * @return {Promise} - the promise for the http request\n   */\n   getLabel(label, cb) {\n      return this._request('GET', `/repos/${this.__repository}/labels/${label}`, null, cb);\n   }\n\n  /**\n   * Edit a label\n   * @see https://developer.github.com/v3/issues/labels/#update-a-label\n   * @param {string} label - the name of the label to edit\n   * @param {Object} labelData - the updates to make to the label\n   * @param {Requestable.callback} [cb] - will receive the updated label\n   * @return {Promise} - the promise for the http request\n   */\n   editLabel(label, labelData, cb) {\n      return this._request('PATCH', `/repos/${this.__repository}/labels/${label}`, labelData, cb);\n   }\n\n  /**\n   * Delete a label\n   * @see https://developer.github.com/v3/issues/labels/#delete-a-label\n   * @param {string} label - the name of the label to delete\n   * @param {Requestable.callback} [cb] - will receive the status\n   * @return {Promise} - the promise for the http request\n   */\n   deleteLabel(label, cb) {\n      return this._request('DELETE', `/repos/${this.__repository}/labels/${label}`, null, cb);\n   }\n}\n\nmodule.exports = Issue;\n"]}
|
335 | //# sourceMappingURL=Issue.js.map
|