0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -05:00

Added recommendation URL to "Edit recommendation" modal

refs https://github.com/TryGhost/Product/issues/3857
This commit is contained in:
Djordje Vlaisavljevic 2023-09-18 11:43:21 +01:00
parent 6273568718
commit d443befd16
3 changed files with 19 additions and 5 deletions

View file

@ -111,7 +111,7 @@ const AddRecommendationModalConfirm: React.FC<AddRecommendationModalProps> = ({r
}
}}
>
<RecommendationReasonForm errors={errors} formState={formState} updateForm={updateForm}/>
<RecommendationReasonForm errors={errors} formState={formState} showURL={false} updateForm={updateForm}/>
</Modal>;
};

View file

@ -75,7 +75,7 @@ const EditRecommendationModalConfirm: React.FC<AddRecommendationModalProps> = ({
}
}}
>
<RecommendationReasonForm errors={errors} formState={formState} updateForm={updateForm as any}/>
<RecommendationReasonForm errors={errors} formState={formState} showURL={true} updateForm={updateForm as any}/>
</Modal>;
};

View file

@ -5,28 +5,42 @@ import React from 'react';
import RecommendationIcon from './RecommendationIcon';
import TextArea from '../../../../admin-x-ds/global/form/TextArea';
import TextField from '../../../../admin-x-ds/global/form/TextField';
import URLTextField from '../../../../admin-x-ds/global/form/URLTextField';
import {EditOrAddRecommendation, Recommendation} from '../../../../api/recommendations';
import {ErrorMessages} from '../../../../hooks/useForm';
interface Props<T extends EditOrAddRecommendation> {
showURL?: boolean,
formState: T,
errors: ErrorMessages,
updateForm: (fn: (state: T) => T) => void
}
const RecommendationReasonForm: React.FC<Props<EditOrAddRecommendation | Recommendation>> = ({formState, updateForm, errors}) => {
const RecommendationReasonForm: React.FC<Props<EditOrAddRecommendation | Recommendation>> = ({showURL, formState, updateForm, errors}) => {
return <Form
marginBottom={false}
marginTop
>
{showURL && <URLTextField
disabled={true}
title='URL'
value={formState.url}
onChange={u => updateForm((state) => {
return {
...state,
url: u
};
})}
/>}
<div>
<Heading className='mb-2 block text-2xs font-semibold uppercase tracking-wider' grey={true} level={6}>Preview</Heading>
<a className='flex flex-col rounded-sm border border-grey-300 p-3' href={formState.url} rel="noopener noreferrer" target="_blank">
<div className="mb-1 flex items-center gap-2">
<RecommendationIcon {...formState} />
<span className='line-clamp-1 font-medium'>{formState.title}</span>
<span className='text-[1.6rem] font-semibold text-grey-900'>{formState.title}</span>
</div>
<span className='line-clamp-1 text-xs leading-snug text-grey-700'>{formState.url}</span>
<span className='text-md font-medium leading-snug text-grey-700'>{formState.reason}</span>
</a>
{formState.one_click_subscribe && <Hint>This is a Ghost site, so your readers can subscribe with just one click</Hint>}
</div>