import React, { useEffect, useState } from 'react' import classnames from 'classnames' import { useModal as useModal } from '~utils/useModal' import SearchModal from '~components/SearchModal' import UncapIndicator from '~components/UncapIndicator' import PlusIcon from '~public/icons/plus.svg' import './index.scss' interface Props { onReceiveData: (weapon: Weapon, position: number) => void weapon: Weapon | undefined position: number editable: boolean unitType: 0 | 1 } const WeaponUnit = (props: Props) => { const [imageUrl, setImageUrl] = useState('') const { open, openModal, closeModal } = useModal() const openModalIfEditable = (props.editable) ? openModal : () => {} const classes = classnames({ WeaponUnit: true, 'mainhand': props.unitType == 0, 'grid': props.unitType == 1, 'editable': props.editable, 'filled': (props.weapon !== undefined) }) const weapon = props.weapon useEffect(() => { generateImageUrl() }) function generateImageUrl() { let imgSrc = "" if (props.weapon) { const weapon = props.weapon! if (props.unitType == 0) imgSrc = `/images/weapon-main/${weapon.granblue_id}.jpg` else imgSrc = `/images/weapon-grid/${weapon.granblue_id}.jpg` } setImageUrl(imgSrc) } function sendData(object: Character | Weapon | Summon, position: number) { if (isWeapon(object)) { props.onReceiveData(object, position) } } function isWeapon(object: Character | Weapon | Summon): object is Weapon { return (object as Weapon).proficiency !== undefined } return (