blob: f05d62cbbbcfda028c712157e657c2a00d8918ad (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
import React from 'dom-chef';
import select from 'select-dom';
import delegate from 'delegate-it';
import * as pageDetect from 'github-url-detection';
import features from '.';
import * as api from '../github-helpers/api';
import LoadingIcon from '../github-helpers/icon-loading';
async function convertToDraft({delegateTarget: draftButton}: delegate.Event<MouseEvent, HTMLButtonElement>): Promise<void> {
try {
draftButton.append(<LoadingIcon className="ml-2 v-align-text-bottom" width={16}/>);
const tagName = location.pathname.split('/').pop()!;
const release = await api.v3(`releases/tags/${tagName}`);
await api.v3(release.url, {
method: 'PATCH',
body: {
draft: true
}
});
select('.BtnGroup a[href*="releases/edit"]')!.click(); // Visit "Edit release" page
} catch (error: unknown) {
draftButton.textContent = 'Error. Check console or retry';
features.error(__filebasename, error);
}
}
async function init(): Promise<void | false> {
await api.expectToken();
const editButton = select('.BtnGroup a[href*="releases/edit"]');
if (!editButton || select.exists('.label-draft')) {
return false;
}
editButton.after(<button type="button" className="btn BtnGroup-item rgh-convert-draft">Convert to draft</button>);
delegate(document, '.rgh-convert-draft', 'click', convertToDraft);
}
void features.add(__filebasename, {
include: [
pageDetect.isSingleTag
],
init
});
|