ConfirmUploadState component in FilePizza codebase.

In this article, we will review ConfirmUploadState component in FilePizza codebase. ConfirmUploadState This is the component that you see once you upload a file on FilePizza. When you look at the code below for ConfirmUploadState component, it makes sense. function ConfirmUploadState({ uploadedFiles, password, onChangePassword, onCancel, onStart, onRemoveFile, }: { uploadedFiles: UploadedFile[] password: string onChangePassword: (pw: string) => void onCancel: () => void onStart: () => void onRemoveFile: (index: number) => void }): JSX.Element { const fileListData = useUploaderFileListData(uploadedFiles) return ( You are about to start uploading{' '} {pluralize(uploadedFiles.length, 'file', 'files')}. ) } You can see, there’s StartButton, CancelButton and the UploadFileList components, most importantly PasswordField. PasswordField import React, { JSX, useCallback } from 'react' import InputLabel from './InputLabel' export default function PasswordField({ value, onChange, isRequired = false, isInvalid = false, }: { value: string onChange: (v: string) => void isRequired?: boolean isInvalid?: boolean }): JSX.Element { const handleChange = useCallback( function (e: React.ChangeEvent): void { onChange(e.target.value) }, [onChange], ) return ( {isRequired ? 'Password' : 'Password (optional)'} ) } The password entered here is managed in the root component, UploadPage and is passed as a prop to UploadingState component that has WebRTCProvider as shown below This password is passed as a parameter to a function named useUploaderConnections export default function Uploader({ files, password, onStop, }: { files: UploadedFile[] password: string onStop: () => void }): JSX.Element { const { peer, stop } = useWebRTCPeer() const { isLoading, error, longSlug, shortSlug, longURL, shortURL } = useUploaderChannel(peer.id) const connections = useUploaderConnections(peer, files, password) useUploaderConnections hook seems to large and complicated, I might write more about this in another article. About me: Hey, my name is Ramu Narasinga. I study large open-source projects and create content about their codebase architecture and best practices, sharing it through articles, videos. I am open to work on interesting projects. Send me an email at ramu.narasinga@gmail.com My Github — https://github.com/ramu-narasinga My website — https://ramunarasinga.com My Youtube channel — https://www.youtube.com/@thinkthroo Learning platform — https://thinkthroo.com Codebase Architecture — https://app.thinkthroo.com/architecture Best practices — https://app.thinkthroo.com/best-practices Production-grade projects — https://app.thinkthroo.com/production-grade-projects References: https://github.com/kern/filepizza/blob/main/src/app/page.tsx#L55 https://github.com/kern/filepizza/blob/main/src/app/page.tsx#L146 https://github.com/kern/filepizza/blob/main/src/hooks/useUploaderConnections.ts#L29

Apr 3, 2025 - 05:38
 0
ConfirmUploadState component in FilePizza codebase.

In this article, we will review ConfirmUploadState component in FilePizza codebase.

Image description

ConfirmUploadState

This is the component that you see once you upload a file on FilePizza.

Image description

When you look at the code below for ConfirmUploadState component, it makes sense.

function ConfirmUploadState({
  uploadedFiles,
  password,
  onChangePassword,
  onCancel,
  onStart,
  onRemoveFile,
}: {
  uploadedFiles: UploadedFile[]
  password: string
  onChangePassword: (pw: string) => void
  onCancel: () => void
  onStart: () => void
  onRemoveFile: (index: number) => void
}): JSX.Element {
  const fileListData = useUploaderFileListData(uploadedFiles)
  return (
    
      
        You are about to start uploading{' '}
        {pluralize(uploadedFiles.length, 'file', 'files')}.
      
      
      
      
) }

You can see, there’s StartButton, CancelButton and the UploadFileList components, most importantly PasswordField.

PasswordField

import React, { JSX, useCallback } from 'react'
import InputLabel from './InputLabel'

export default function PasswordField({
  value,
  onChange,
  isRequired = false,
  isInvalid = false,
}: {
  value: string
  onChange: (v: string) => void
  isRequired?: boolean
  isInvalid?: boolean
}): JSX.Element {
  const handleChange = useCallback(
    function (e: React.ChangeEvent): void {
      onChange(e.target.value)
    },
    [onChange],
  )

  return (
    
{isRequired ? 'Password' : 'Password (optional)'}
) }

The password entered here is managed in the root component, UploadPage and is passed as a prop to UploadingState component that has WebRTCProvider as shown below


  

This password is passed as a parameter to a function named useUploaderConnections

export default function Uploader({
  files,
  password,
  onStop,
}: {
  files: UploadedFile[]
  password: string
  onStop: () => void
}): JSX.Element {
  const { peer, stop } = useWebRTCPeer()
  const { isLoading, error, longSlug, shortSlug, longURL, shortURL } =
    useUploaderChannel(peer.id)
  const connections = useUploaderConnections(peer, files, password)

useUploaderConnections hook seems to large and complicated, I might write more about this in another article.

About me:

Hey, my name is Ramu Narasinga. I study large open-source projects and create content about their codebase architecture and best practices, sharing it through articles, videos.

I am open to work on interesting projects. Send me an email at ramu.narasinga@gmail.com

My Github — https://github.com/ramu-narasinga

My website — https://ramunarasinga.com

My Youtube channel — https://www.youtube.com/@thinkthroo

Learning platform — https://thinkthroo.com

Codebase Architecture — https://app.thinkthroo.com/architecture

Best practices — https://app.thinkthroo.com/best-practices

Production-grade projects — https://app.thinkthroo.com/production-grade-projects

References:

  1. https://github.com/kern/filepizza/blob/main/src/app/page.tsx#L55

  2. https://github.com/kern/filepizza/blob/main/src/app/page.tsx#L146

  3. https://github.com/kern/filepizza/blob/main/src/hooks/useUploaderConnections.ts#L29