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:
parent
6273568718
commit
d443befd16
3 changed files with 19 additions and 5 deletions
|
@ -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>;
|
||||
};
|
||||
|
||||
|
|
|
@ -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>;
|
||||
};
|
||||
|
||||
|
|
|
@ -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>
|
||||
|
|
Loading…
Reference in a new issue