plebdevs/src/components/course/CourseLesson.js

136 lines
5.6 KiB
JavaScript
Raw Normal View History

import React, { useEffect, useState } from "react";
import { Tag } from "primereact/tag";
import Image from "next/image";
import { useImageProxy } from "@/hooks/useImageProxy";
import { useNostr } from "@/hooks/useNostr";
import { getSatAmountFromInvoice } from "@/utils/lightning";
import { parseEvent } from "@/utils/nostr";
import { useLocalStorageWithEffect } from "@/hooks/useLocalStorage";
import ZapDisplay from "@/components/zaps/ZapDisplay";
import dynamic from "next/dynamic";
const BitcoinConnectPayButton = dynamic(
() => import('@getalby/bitcoin-connect-react').then((mod) => mod.PayButton),
2024-07-30 17:16:09 -05:00
{
ssr: false,
}
);
const MDDisplay = dynamic(
() => import("@uiw/react-markdown-preview"),
2024-07-30 17:16:09 -05:00
{
ssr: false,
}
);
const CourseLesson = ({ lesson, course }) => {
2024-07-30 17:16:09 -05:00
const [bitcoinConnect, setBitcoinConnect] = useState(false);
const [zaps, setZaps] = useState([]);
2024-08-01 16:31:52 -05:00
const [zapAmount, setZapAmount] = useState(0);
2024-07-30 17:16:09 -05:00
const { fetchZapsForEvent } = useNostr();
const { returnImageProxy } = useImageProxy();
2024-07-30 17:16:09 -05:00
useEffect(() => {
if (typeof window === 'undefined') return;
const bitcoinConnectConfig = window.localStorage.getItem('bc:config');
if (bitcoinConnectConfig) {
setBitcoinConnect(true);
}
}, []);
const handleZapEvent = async () => {
return;
}
2024-07-30 17:16:09 -05:00
useEffect(() => {
if (!zaps || zaps.length === 0) return;
let total = 0;
zaps.forEach((zap) => {
const bolt11Tag = zap.tags.find(tag => tag[0] === "bolt11");
const invoice = bolt11Tag ? bolt11Tag[1] : null;
if (invoice) {
const amount = getSatAmountFromInvoice(invoice);
total += amount;
2024-07-30 17:16:09 -05:00
}
});
setZapAmount(total);
}, [zaps]);
2024-07-30 17:16:09 -05:00
useEffect(() => {
const fetchZaps = async () => {
if (lesson) {
const zaps = await fetchZapsForEvent(lesson);
setZaps(zaps);
}
2024-07-30 17:16:09 -05:00
}
fetchZaps();
}, [fetchZapsForEvent, lesson]);
2024-07-30 17:16:09 -05:00
return (
<div className='w-full px-24 pt-12 mx-auto mt-4 max-tab:px-0 max-mob:px-0 max-tab:pt-2 max-mob:pt-2'>
<div className='w-full flex flex-row justify-between max-tab:flex-col max-mob:flex-col'>
<div className='w-[75vw] mx-auto flex flex-row items-start justify-between max-tab:flex-col max-mob:flex-col max-tab:w-[95vw] max-mob:w-[95vw]'>
<div className='flex flex-col items-start max-w-[45vw] max-tab:max-w-[100vw] max-mob:max-w-[100vw]'>
<div className='pt-2 flex flex-row justify-start w-full'>
{lesson && lesson.topics && lesson.topics.length > 0 && (
lesson.topics.map((topic, index) => (
2024-07-30 17:16:09 -05:00
<Tag className='mr-2 text-white' key={index} value={topic}></Tag>
))
)
}
</div>
<h1 className='text-4xl mt-6'>{lesson?.title}</h1>
<p className='text-xl mt-6'>{lesson?.summary}</p>
2024-07-30 17:16:09 -05:00
<div className='flex flex-row w-full mt-6 items-center'>
<Image
alt="avatar thumbnail"
src={returnImageProxy(lesson.author?.avatar, lesson.author?.pubkey)}
2024-07-30 17:16:09 -05:00
width={50}
height={50}
className="rounded-full mr-4"
/>
<p className='text-lg'>
Created by{' '}
<a rel='noreferrer noopener' target='_blank' className='text-blue-500 hover:underline'>
{lesson.author?.username}
2024-07-30 17:16:09 -05:00
</a>
</p>
</div>
</div>
<div className='flex flex-col max-tab:mt-12 max-mob:mt-12'>
{lesson && (
2024-07-30 17:16:09 -05:00
<div className='flex flex-col items-center justify-between rounded-lg h-72 p-4 bg-gray-700 drop-shadow-md'>
<Image
alt="resource thumbnail"
src={returnImageProxy(lesson.image)}
2024-07-30 17:16:09 -05:00
width={344}
height={194}
className="w-[344px] h-[194px] object-cover object-top rounded-lg"
/>
{bitcoinConnect ? (
<div>
<BitcoinConnectPayButton onClick={handleZapEvent} />
</div>
) : (
<div className="w-full flex justify-end">
<ZapDisplay zapAmount={zapAmount} event={parseEvent(course)} />
2024-07-30 17:16:09 -05:00
</div>
)}
</div>
)}
</div>
</div>
</div>
<div className='w-[75vw] mx-auto mt-12 p-12 border-t-2 border-gray-300 max-tab:p-0 max-mob:p-0 max-tab:max-w-[100vw] max-mob:max-w-[100vw]'>
{
lesson?.content && <MDDisplay source={lesson.content} />
2024-07-30 17:16:09 -05:00
}
</div>
</div>
)
}
export default CourseLesson;