File size: 2,537 Bytes
b98ad90
1f05f10
 
 
 
9d7e455
 
 
 
 
1f05f10
 
 
 
 
 
e0d4ec0
1f05f10
 
 
 
e0d4ec0
b98ad90
1f05f10
 
 
 
 
b98ad90
1f05f10
 
b98ad90
e0d4ec0
3dadf94
 
1f05f10
 
 
 
 
 
 
 
b98ad90
 
 
 
 
1f05f10
b98ad90
1f05f10
b98ad90
1f05f10
 
 
 
b98ad90
1f05f10
b98ad90
1f05f10
b98ad90
1f05f10
 
 
9d7e455
 
b98ad90
 
 
1f05f10
 
 
 
 
b98ad90
1f05f10
 
 
 
b98ad90
1f05f10
 
b98ad90
1f05f10
 
b98ad90
1f05f10
 
 
 
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import { createRepo, commit, CommitFile, whoAmI } from "@huggingface/hub";

const c = console;

const FILES_TO_UPLOAD = [
	`${window.location.origin}${window.location.pathname}/mobilenet/model.json`,
	`${window.location.origin}${window.location.pathname}/mobilenet/group1-shard1of2`,
	`${window.location.origin}${window.location.pathname}/mobilenet/group1-shard2of2`,
	`${window.location.origin}${window.location.pathname}/mobilenet/coffee.jpg`,
	`${window.location.origin}${window.location.pathname}/mobilenet/README.md`,
];

function filenameFromURL(url: string): string {
	return url.substring(url.lastIndexOf("/") + 1);
}

window.document.addEventListener("DOMContentLoaded", () => {
	const tokenEl = document.querySelector<HTMLInputElement>("#token")!;
	const repoNameEl = document.querySelector<HTMLInputElement>("#repo_name")!;
	const button = document.querySelector("#submit")!;
	const output = document.querySelector("#logs")!;
	const form = document.getElementsByTagName("form")[0];

	const storedToken = window.localStorage.getItem("hf_token");
	if (storedToken) {
		tokenEl.value = storedToken;
		/// ^to help in dev.
	}

	repoNameEl.value = `tfjs-mobilenet-${Date.now() % 1_000}`;
	/// "random" repo name

	form.addEventListener("submit", async (event) => {
		event.preventDefault();

		const token = tokenEl.value;
		const repoName = repoNameEl.value;
		if (!token || !repoName) {
			alert("You need a token and a repo name");
			return;
		}

		button.setAttribute("disabled", "disabled");

		const credentials = {
			accessToken: token,
		};

		try {
			const { name: username } = await whoAmI({ credentials });
			const name = `${username}/${repoName}`;
			const { repoUrl } = await createRepo({
				repo: {
					type: "model",
					name,
				},
				credentials,
			});

			const operations: CommitFile[] = await Promise.all(
				FILES_TO_UPLOAD.map(async (file) => {
					return {
						operation: "addOrUpdate",
						path: filenameFromURL(file),
						// upload remote file
						content: new URL(file),
					};
				})
			);
			const commitOutput = await commit({
				repo: {
					type: "model",
					name,
				},
				credentials,
				title: "upload model",
				operations,
			});
			c.log(commitOutput);

			button.insertAdjacentHTML(
				"afterend",
				`<div class="text-green-500 mb-6">🎉 Upload complete! Model page is <a target="_blank" class="text-bold underline" href="${repoUrl}">${repoUrl}</a></div>`
			);
		} catch (err) {
			output.append("\n" + err);
		}
		button.removeAttribute("disabled");
	});
});