allow signing and show PdfView without any marks (never created) #287
@ -17,7 +17,7 @@ interface MarkFormFieldProps {
|
|||||||
handleCurrentUserMarkChange: (mark: CurrentUserMark) => void
|
handleCurrentUserMarkChange: (mark: CurrentUserMark) => void
|
||||||
handleSelectedMarkValueChange: (value: string) => void
|
handleSelectedMarkValueChange: (value: string) => void
|
||||||
handleSubmit: (event: React.MouseEvent<HTMLButtonElement>) => void
|
handleSubmit: (event: React.MouseEvent<HTMLButtonElement>) => void
|
||||||
selectedMark: CurrentUserMark
|
selectedMark: CurrentUserMark | null
|
||||||
selectedMarkValue: string
|
selectedMarkValue: string
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -34,26 +34,23 @@ const MarkFormField = ({
|
|||||||
}: MarkFormFieldProps) => {
|
}: MarkFormFieldProps) => {
|
||||||
const [displayActions, setDisplayActions] = useState(true)
|
const [displayActions, setDisplayActions] = useState(true)
|
||||||
const [complete, setComplete] = useState(false)
|
const [complete, setComplete] = useState(false)
|
||||||
|
|
||||||
const isReadyToSign = () =>
|
const isReadyToSign = () =>
|
||||||
isCurrentUserMarksComplete(currentUserMarks) ||
|
isCurrentUserMarksComplete(currentUserMarks) ||
|
||||||
isCurrentValueLast(currentUserMarks, selectedMark, selectedMarkValue)
|
isCurrentValueLast(currentUserMarks, selectedMark, selectedMarkValue)
|
||||||
const isCurrent = (currentMark: CurrentUserMark) =>
|
const isCurrent = (currentMark: CurrentUserMark) =>
|
||||||
currentMark.id === selectedMark.id && !complete
|
currentMark.id === selectedMark?.id && !complete
|
||||||
const isDone = (currentMark: CurrentUserMark) =>
|
const isDone = (currentMark: CurrentUserMark) =>
|
||||||
isCurrent(currentMark) ? !!selectedMarkValue : currentMark.isCompleted
|
isCurrent(currentMark) ? !!selectedMarkValue : currentMark.isCompleted
|
||||||
const findNext = () => {
|
const findNext = () => {
|
||||||
return (
|
return (
|
||||||
currentUserMarks[selectedMark.id] ||
|
currentUserMarks[selectedMark!.id] ||
|
||||||
findNextIncompleteCurrentUserMark(currentUserMarks)
|
findNextIncompleteCurrentUserMark(currentUserMarks)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
const handleFormSubmit = (event: React.FormEvent<HTMLFormElement>) => {
|
const handleFormSubmit = (event: React.FormEvent<HTMLFormElement>) => {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
console.log('handle form submit runs...')
|
|
||||||
|
|
||||||
// Without this line, we lose mark values when switching
|
// Without this line, we lose mark values when switching
|
||||||
handleCurrentUserMarkChange(selectedMark)
|
handleCurrentUserMarkChange(selectedMark!)
|
||||||
|
|
||||||
if (!complete) {
|
if (!complete) {
|
||||||
isReadyToSign()
|
isReadyToSign()
|
||||||
@ -63,15 +60,16 @@ const MarkFormField = ({
|
|||||||
}
|
}
|
||||||
|
|
||||||
const toggleActions = () => setDisplayActions(!displayActions)
|
const toggleActions = () => setDisplayActions(!displayActions)
|
||||||
const markLabel = getToolboxLabelByMarkType(selectedMark.mark.type)
|
const markLabel = selectedMark
|
||||||
|
? getToolboxLabelByMarkType(selectedMark.mark.type)
|
||||||
|
: ''
|
||||||
const handleCurrentUserMarkClick = (mark: CurrentUserMark) => {
|
const handleCurrentUserMarkClick = (mark: CurrentUserMark) => {
|
||||||
setComplete(false)
|
setComplete(false)
|
||||||
handleCurrentUserMarkChange(mark)
|
handleCurrentUserMarkChange(mark)
|
||||||
}
|
}
|
||||||
|
|
||||||
const handleSelectCompleteMark = () => {
|
const handleSelectCompleteMark = () => {
|
||||||
handleCurrentUserMarkChange(selectedMark)
|
if (currentUserMarks.length) handleCurrentUserMarkChange(selectedMark!)
|
||||||
setComplete(true)
|
setComplete(true)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -106,14 +104,15 @@ const MarkFormField = ({
|
|||||||
<div className={styles.actionsWrapper}>
|
<div className={styles.actionsWrapper}>
|
||||||
<div className={styles.actionsTop}>
|
<div className={styles.actionsTop}>
|
||||||
<div className={styles.actionsTopInfo}>
|
<div className={styles.actionsTopInfo}>
|
||||||
{!complete && (
|
{!complete && selectedMark ? (
|
||||||
<p className={styles.actionsTopInfoText}>Add {markLabel}</p>
|
<p className={styles.actionsTopInfoText}>Add {markLabel}</p>
|
||||||
|
) : (
|
||||||
|
<p className={styles.actionsTopInfoText}>Finish</p>
|
||||||
)}
|
)}
|
||||||
{complete && <p className={styles.actionsTopInfoText}>Finish</p>}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className={styles.inputWrapper}>
|
<div className={styles.inputWrapper}>
|
||||||
{!complete && (
|
{!complete && selectedMark ? (
|
||||||
<form onSubmit={(e) => handleFormSubmit(e)}>
|
<form onSubmit={(e) => handleFormSubmit(e)}>
|
||||||
<MarkInput
|
<MarkInput
|
||||||
markType={selectedMark.mark.type}
|
markType={selectedMark.mark.type}
|
||||||
@ -129,9 +128,7 @@ const MarkFormField = ({
|
|||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
)}
|
) : (
|
||||||
|
|
||||||
{complete && (
|
|
||||||
<div className={styles.actionsBottom}>
|
<div className={styles.actionsBottom}>
|
||||||
<Button
|
<Button
|
||||||
onClick={handleSignAndComplete}
|
onClick={handleSignAndComplete}
|
||||||
|
@ -101,8 +101,7 @@ const PdfMarking = (props: PdfMarkingProps) => {
|
|||||||
*/
|
*/
|
||||||
const handleSubmit = (event: React.MouseEvent<HTMLButtonElement>) => {
|
const handleSubmit = (event: React.MouseEvent<HTMLButtonElement>) => {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
if (!selectedMarkValue || !selectedMark) return
|
if (selectedMarkValue && selectedMark) {
|
||||||
|
|
||||||
const updatedMark: CurrentUserMark = getUpdatedMark(
|
const updatedMark: CurrentUserMark = getUpdatedMark(
|
||||||
selectedMark,
|
selectedMark,
|
||||||
selectedMarkValue
|
selectedMarkValue
|
||||||
@ -116,6 +115,8 @@ const PdfMarking = (props: PdfMarkingProps) => {
|
|||||||
setCurrentUserMarks(updatedCurrentUserMarks)
|
setCurrentUserMarks(updatedCurrentUserMarks)
|
||||||
setSelectedMark(null)
|
setSelectedMark(null)
|
||||||
setUpdatedMarks(updatedMark.mark)
|
setUpdatedMarks(updatedMark.mark)
|
||||||
|
}
|
||||||
|
|
||||||
handleSign()
|
handleSign()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -152,7 +153,6 @@ const PdfMarking = (props: PdfMarkingProps) => {
|
|||||||
centerIcon={faPen}
|
centerIcon={faPen}
|
||||||
rightIcon={faCircleInfo}
|
rightIcon={faCircleInfo}
|
||||||
>
|
>
|
||||||
{currentUserMarks?.length > 0 && (
|
|
||||||
<PdfView
|
<PdfView
|
||||||
currentFile={currentFile}
|
currentFile={currentFile}
|
||||||
files={files}
|
files={files}
|
||||||
@ -162,9 +162,7 @@ const PdfMarking = (props: PdfMarkingProps) => {
|
|||||||
currentUserMarks={currentUserMarks}
|
currentUserMarks={currentUserMarks}
|
||||||
otherUserMarks={otherUserMarks}
|
otherUserMarks={otherUserMarks}
|
||||||
/>
|
/>
|
||||||
)}
|
|
||||||
</StickySideColumns>
|
</StickySideColumns>
|
||||||
{selectedMark !== null && (
|
|
||||||
<MarkFormField
|
<MarkFormField
|
||||||
handleSubmit={handleSubmit}
|
handleSubmit={handleSubmit}
|
||||||
handleSelectedMarkValueChange={handleChange}
|
handleSelectedMarkValueChange={handleChange}
|
||||||
@ -173,7 +171,6 @@ const PdfMarking = (props: PdfMarkingProps) => {
|
|||||||
currentUserMarks={currentUserMarks}
|
currentUserMarks={currentUserMarks}
|
||||||
handleCurrentUserMarkChange={handleCurrentUserMarkChange}
|
handleCurrentUserMarkChange={handleCurrentUserMarkChange}
|
||||||
/>
|
/>
|
||||||
)}
|
|
||||||
</Container>
|
</Container>
|
||||||
</>
|
</>
|
||||||
)
|
)
|
||||||
|
@ -123,9 +123,10 @@ const isLast = <T>(index: number, arr: T[]) => index === arr.length - 1
|
|||||||
|
|
||||||
const isCurrentValueLast = (
|
const isCurrentValueLast = (
|
||||||
currentUserMarks: CurrentUserMark[],
|
currentUserMarks: CurrentUserMark[],
|
||||||
selectedMark: CurrentUserMark,
|
selectedMark: CurrentUserMark | null,
|
||||||
selectedMarkValue: string
|
selectedMarkValue: string
|
||||||
) => {
|
) => {
|
||||||
|
if (selectedMark && currentUserMarks.length > 0) {
|
||||||
const filteredMarks = currentUserMarks.filter(
|
const filteredMarks = currentUserMarks.filter(
|
||||||
(mark) => mark.id !== selectedMark.id
|
(mark) => mark.id !== selectedMark.id
|
||||||
)
|
)
|
||||||
@ -134,6 +135,9 @@ const isCurrentValueLast = (
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
const getUpdatedMark = (
|
const getUpdatedMark = (
|
||||||
selectedMark: CurrentUserMark,
|
selectedMark: CurrentUserMark,
|
||||||
selectedMarkValue: string
|
selectedMarkValue: string
|
||||||
|
Loading…
Reference in New Issue
Block a user