File "modal.js"

Full Path: /home/fresvfqn/waterdamagerestorationandrepairsmithtown.com/wp-content/plugins/surerank/src/apps/admin-general/schema/modal.js
File size: 4.58 KB
MIME-type: text/x-java
Charset: utf-8

import { Button, Dialog, Select, Container } from '@bsf/force-ui';
import { Plus, X } from 'lucide-react';
import { __ } from '@wordpress/i18n';
import { useEffect } from '@wordpress/element';

const Modal = ( {
	selectedSchema,
	setSelectedSchema,
	selectedType,
	setSelectedType,
	schemaTypeOptions,
	defaultSchemas,
	handleAddSchema,
} ) => {
	const renderSchemaTypeOptions = () => {
		const options = schemaTypeOptions[ selectedSchema ];
		const isGrouped = Object.values( options ).every(
			( item ) => item.label && item.options
		);

		if ( isGrouped ) {
			return Object.values( options ).map( ( group, index ) => (
				<Select.OptionGroup key={ index } label={ group.label }>
					{ Object.entries( group.options ).map( ( [ key ] ) => (
						<Select.Option key={ key } value={ key }>
							{ key }
						</Select.Option>
					) ) }
				</Select.OptionGroup>
			) );
		}

		return Object.entries( options || {} ).map( ( [ key, value ] ) => (
			<Select.Option key={ key } value={ key }>
				{ value }
			</Select.Option>
		) );
	};

	useEffect( () => {
		if ( selectedType === '' ) {
			setSelectedType( selectedSchema );
		}
	}, [ selectedSchema, selectedType, setSelectedType ] );

	return (
		<Dialog
			trigger={
				<Button
					icon={ <Plus aria-label="icon" role="img" /> }
					iconPosition="left"
					size="md"
					variant="outline"
				>
					{ __( 'Add Schema', 'surerank' ) }
				</Button>
			}
		>
			<Dialog.Panel className="gap-2 p-3">
				{ ( { close } ) => (
					<>
						<Dialog.Header className="p-2">
							<div className="flex items-center justify-between">
								<Dialog.Title>
									{ __( 'Add Schema', 'surerank' ) }
								</Dialog.Title>
								<Button
									className="text-text-secondary [&_svg]:text-text-secondary [&_svg]:size-4 p-0"
									variant="ghost"
									onClick={ close }
									icon={ <X aria-label="icon" role="img" /> }
								/>
							</div>
						</Dialog.Header>
						<Dialog.Body className="p-2">
							<Container
								align="start"
								containerType="flex"
								direction="column"
								gap="xs"
								justify="start"
							>
								<Container.Item className="w-full pb-1">
									<label className="text-base block font-medium text-field-label">
										{ __( 'Choose Schema', 'surerank' ) }
									</label>
								</Container.Item>
								<Container.Item className="w-full">
									<Select
										combobox
										size="md"
										value={ selectedSchema }
										onChange={ ( value ) => {
											setSelectedSchema( value );
											const schemaTypeOptionsAvailable =
												schemaTypeOptions[ value ] &&
												Object.keys(
													schemaTypeOptions[ value ]
												).length;
											if (
												! schemaTypeOptionsAvailable
											) {
												setSelectedType( value );
											} else {
												setSelectedType( '' );
											}
										} }
									>
										<Select.Button />
										<Select.Options>
											{ defaultSchemas.map(
												( schema, index ) => (
													<Select.Option
														key={ index }
														value={ schema.title }
													>
														{ schema.title }
													</Select.Option>
												)
											) }
										</Select.Options>
									</Select>
								</Container.Item>
							</Container>
							{ selectedSchema &&
								schemaTypeOptions[ selectedSchema ] && (
									<div className="flex flex-col mt-3 gap-1.5">
										<label className="text-base block font-medium text-field-label">
											{ __( 'Schema Type', 'surerank' ) }
										</label>
										<Select
											combobox
											size="md"
											value={
												selectedType || selectedSchema
											}
											onChange={ ( value ) =>
												setSelectedType( value )
											}
										>
											<Select.Button
												render={ ( selectedValue ) =>
													selectedValue
												}
												type="button"
											/>
											<Select.Options>
												{ renderSchemaTypeOptions() }
											</Select.Options>
										</Select>
									</div>
								) }
						</Dialog.Body>
						<Dialog.Footer className="p-2">
							<Button variant="outline" onClick={ close }>
								{ __( 'Cancel', 'surerank' ) }
							</Button>
							<Button
								variant="primary"
								onClick={ () => {
									handleAddSchema();
									close();
								} }
								disabled={ ! selectedSchema }
							>
								{ __( 'Add Schema', 'surerank' ) }
							</Button>
						</Dialog.Footer>
						<Dialog.Backdrop className="bg-misc-overlay" />
					</>
				) }
			</Dialog.Panel>
		</Dialog>
	);
};

export default Modal;