**Motivations:** - Keep dependencies up to date for security and features - Automate dependency updates in deployment script - Fix compatibility issues with major version updates (React 19, Next.js 16, nostr-tools 2.x) **Root causes:** - Dependencies were outdated - Deployment script did not update dependencies before deploying - Major version updates introduced breaking API changes **Correctifs:** - Updated all dependencies to latest versions using npm-check-updates - Modified deploy.sh to run npm-check-updates before installing dependencies - Fixed nostr-tools 2.x API changes (generatePrivateKey -> generateSecretKey, signEvent -> finalizeEvent, verifySignature -> verifyEvent) - Fixed React 19 ref types to accept null - Fixed JSX namespace issues (JSX.Element -> React.ReactElement) - Added proper types for event callbacks - Fixed SimplePool.sub typing issues with type assertions **Evolutions:** - Deployment script now automatically updates dependencies to latest versions before deploying - All dependencies updated to latest versions (Next.js 14->16, React 18->19, nostr-tools 1->2, etc.) **Pages affectées:** - package.json - deploy.sh - lib/keyManagement.ts - lib/nostr.ts - lib/nostrRemoteSigner.ts - lib/zapVerification.ts - lib/platformTrackingEvents.ts - lib/sponsoringTracking.ts - lib/articlePublisherHelpersVerification.ts - lib/contentDeliveryVerification.ts - lib/paymentPollingZapReceipt.ts - lib/nostrPrivateMessages.ts - lib/nostrSubscription.ts - lib/nostrZapVerification.ts - lib/markdownRenderer.tsx - components/AuthorFilter.tsx - components/AuthorFilterButton.tsx - components/UserArticlesList.tsx - types/nostr-tools-extended.ts
39 lines
1.0 KiB
TypeScript
39 lines
1.0 KiB
TypeScript
import Image from 'next/image'
|
|
import React from 'react'
|
|
|
|
interface UserProfileHeaderProps {
|
|
displayName: string
|
|
picture?: string
|
|
nip05?: string
|
|
}
|
|
|
|
export function UserProfileHeader({
|
|
displayName,
|
|
picture,
|
|
nip05,
|
|
}: UserProfileHeaderProps) {
|
|
return (
|
|
<div className="flex flex-col md:flex-row items-start md:items-center gap-4">
|
|
{picture ? (
|
|
<Image
|
|
src={picture}
|
|
alt={displayName}
|
|
width={96}
|
|
height={96}
|
|
className="rounded-full object-cover border-2 border-gray-200"
|
|
/>
|
|
) : (
|
|
<div className="w-24 h-24 rounded-full bg-gray-200 flex items-center justify-center border-2 border-gray-300">
|
|
<span className="text-2xl text-gray-400 font-medium">
|
|
{displayName.charAt(0).toUpperCase()}
|
|
</span>
|
|
</div>
|
|
)}
|
|
<div className="flex-1">
|
|
<h1 className="text-2xl font-bold text-gray-900 mb-2">{displayName}</h1>
|
|
{nip05 && <p className="text-sm text-blue-600 mb-2">{nip05}</p>}
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|