import { useEffect,useState } from "react"
import { useParams } from "react-router"

import { CreateDelayer, ErrorHandler, LoadingSpinner } from "@hrbolek/uoisfrontend-shared"
import { useAsyncAction } from "@hrbolek/uoisfrontend-gql-shared"
import { StateMachnineManagement,AdmissionButton, AdmissionLargeCard} from "../Components"
import { PaymentGenerator } from "../Components/PaymentGenerator"
import { AdmissionReadAsyncAction } from "../Queries"
import AdmissionUpdateAsyncAction from "../Queries/PaymentInfoUpdateAsyncAction"
import { AdmissionPageNavbar } from "./AdmissionPageNavbar"
import { AdmissionTimeline } from "../Components/AdmissionTimeline"
import { ProgramStatusManager } from "../Components/ProgramStatusManager"
import { AdmissionList } from "../Components/AdmissionList"

/**
 * A page content component for displaying detailed information about an admission entity.
 *
 * This component utilizes AdmissionLargeCard to create a structured layout and displays 
 * the serialized representation of the admission object within the card's content.
 *
 * @component
 * @param {Object} props - The properties for the AdmissionPageContent component.
 * @param {Object} props.admission - The object representing the admission entity.
 * @param {string|number} props.admission.id - The unique identifier for the admission entity.
 * @param {string} props.admission.name - The name or label of the admission entity.
 *
 * @returns {JSX.Element} A JSX element rendering the page content for an admission entity.
 *
 * @example
 * // Example usage:
 * const admissionEntity = { id: 123, name: "Sample Entity" };
 * 
 * <AdmissionPageContent admission={admissionEntity} />
 */


// This component serves as the main content area for the admission page, displaying detailed information about a specific admission entity.
export const AdmissionPageContent = ({
    admission, isEditMode
  }) => {
    

    
    return (
      <>
        <AdmissionPageNavbar admission={admission} />
        <AdmissionLargeCard admission={admission} isEditMode={isEditMode}>
        
        <AdmissionList />
          {/* Right side: timeline */}
          <div style={{ width: "320px", minWidth: "250px" }}>
            <AdmissionTimeline admission={admission} />
          </div>
      </AdmissionLargeCard>
      </>
    );
  };

/**
 * A lazy-loading component for displaying content of an admission entity.
 *
 * This component is created using createLazyComponent and wraps AdmissionPageContent to provide
 * automatic data fetching for the admission entity. It uses the AdmissionReadAsyncAction to fetch
 * the entity data and dynamically injects it into the wrapped component as the admission prop.
 *
 * @constant
 * @type {React.Component}
 *
 * @param {Object} props - The props for the lazy-loading component.
 * @param {string|number} props.admission - The identifier of the admission entity to fetch and display.
 *
 * @returns {JSX.Element} A component that fetches the admission entity data and displays it
 * using AdmissionPageContent, or shows loading and error states as appropriate.
 *
 * @example
 * // Example usage:
 * const admissionId = "12345";
 *
 * <AdmissionPageContentLazy admission={admissionId} />
 */
const AdmissionPageContentLazy = ({admission, isEditMode}) => {
    const { error, loading, entity, fetch } = useAsyncAction(AdmissionReadAsyncAction, admission)
    const [delayer] = useState(() => CreateDelayer())

    const handleChange = async(e) => {
        // console.log("GroupCategoryPageContentLazy.handleChange.e", e)
        const data = e.target.value
        const serverResponse = await delayer(() => fetch(data))
        // console.log("GroupCategoryPageContentLazy.serverResponse", serverResponse)
    }
    const handleBlur = async(e) => {
        // console.log("GroupCategoryPageContentLazy.handleBlur.e", e)
        const data = e.target.value
        const serverResponse = await delayer(() => fetch(data))
        // console.log("GroupCategoryPageContentLazy.serverResponse", serverResponse)
    }

    return (<>
        {loading && <LoadingSpinner />}
        {error && <ErrorHandler errors={error} />}
        {entity && <AdmissionPageContent admission={entity} isEditMode={isEditMode} onChange={handleChange} onBlur={handleBlur} />}
    </>)
}

/**
 * A page component for displaying lazy-loaded content of an admission entity.
 *
 * This component extracts the id parameter from the route using useParams,
 * constructs an admission object, and passes it to the AdmissionPageContentLazy component.
 * The AdmissionPageContentLazy component handles the lazy-loading and rendering of the entity's content.
 *
 * @component
 * @returns {JSX.Element} The rendered page component displaying the lazy-loaded content for the admission entity.
 *
 * @example
 * // Example route setup:
 * <Route path="/admission/:id" element={<AdmissionPage />} />
 *
 * // Navigating to "/admission/12345" will render the page for the admission entity with ID 12345.
 */
export const AdmissionPage = ({isEditMode}) => {
    const {id} = useParams()
    const admission = {id}
    return <AdmissionPageContentLazy isEditMode={isEditMode} admission={admission} />
}