⭐
絶対にGitHubのスターがほしいときに設置するボタン
TL;DR
このボタンを配置することで、少なくともユーザーは、あなたのリポジトリのスターボタンを見ることになります。
寛大なユーザーであればスターを押してくれるかもしれませんが、「スター乞食乙」と思われる可能性のほうが高いです。
うごき
やってること
ボタンを押すと
- ちょうどGitHubのスターボタンがある位置に赤枠をアニメーション付きで表示
- cursorをnoneしてポインタを隠し、ポインタのimgを赤枠のところに表示
- 1秒後にスターしてほしいリポジトリに遷移
します
(gifでポインタが実際に移動しているように見えるのは、そういうふうに動かしてるだけ。。)
なんでこうなったのか
GitHub APIにスターを付けるエンドポイントはあるんですが、認証を挟んでtokenを取る必要があります。
また、iframeでボタンのところだけ表示するとかできないかと思いましたが、GitHubはdenyしています。
$ curl --dump-header - https://github.com/tachibanayu24/dev-toolkit
...
x-frame-options: deny
...
当然ですがユーザーのポインタを勝手に動かすこともできないので、こうなってしまいました。
(ネタです。実際にデプロイしないです。)
コード
どうでもいいと思いますがコードです。
(Reactでtailwindです)
const [clicked, setClicked] = useState(false);
const handleGiveStar = () => {
setClicked(true);
setTimeout(() => {
window.location.href = "https://github.com/tachibanayu24/dev-toolkit";
}, 1000);
};
return (
<div
className={`flex justify-center items-center w-screen h-screen relative ${
clicked && "cursor-none"
}`}
>
{clicked && (
// ohNoはthemingしているカスタムのアニメーションです
<div
className={`animate-ohNo h-[28px] w-[137.25px] border-solid border-red-500 border-4 absolute right-10 top-20`}
>
<img
className="absolute top-2 left-10"
// macOSのポインタの画像をエンコードしたものです
src=""
/>
</div>
)}
<div>
<button
className={`bg-yellow-400 p-4 rounded-full shadow-lg font-bold ${
clicked && "cursor-none"
}`}
onClick={handleGiveStar}
>
スターして!
</button>
</div>
</div>
Discussion