1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-18 07:52:23 +01:00

Fix styles on multi-select

This commit is contained in:
vincent 2022-04-05 19:31:13 +02:00
parent 1435a46c99
commit c50d94b2a9
2 changed files with 7 additions and 5 deletions

View File

@ -25,22 +25,24 @@ type selectOption<TOptionValue> = { value: TOptionValue, label: string };
*/
export const FormMultiSelect = <TFieldValues extends FieldValues, TContext extends object, TOptionValue>({ id, label, className, control, placeholder, options, valuesDefault, error, rules, disabled }: FormSelectProps<TFieldValues, TContext, TOptionValue>) => {
const classNames = `
form-multi-select ${className || ''}
form-item ${className || ''}
${error && error[id] ? 'is-incorrect' : ''}
${rules && rules.required ? 'is-required' : ''}
${disabled ? 'is-disabled' : ''}`;
return (
<label className={classNames}>
{label && <div className="form-multi-select-header">
{label && <div className="form-item-header">
<p>{label}</p>
</div>}
<div className="form-multi-select-field">
<div className="form-item-field">
<Controller name={id as FieldPath<TFieldValues>}
control={control}
defaultValue={valuesDefault as UnpackNestedValue<FieldPathValue<TFieldValues, Path<TFieldValues>>>}
render={({ field: { onChange, value, ref } }) =>
<Select inputRef={ref}
classNamePrefix="rs"
className="rs"
value={options.filter(c => value?.includes(c.value))}
onChange={val => onChange(val.map(c => c.value))}
placeholder={placeholder}

View File

@ -20,10 +20,10 @@
}
&-field {
height: 4rem;
min-height: 4rem;
display: grid;
grid-template-areas: "icon field addon";
grid-template-columns: min-content 1fr min-content;
grid-template-columns: min-content minmax(0, 1fr) min-content;
border: 1px solid var(--gray-soft-dark);
border-radius: var(--border-radius);
transition: border-color ease-in-out 0.15s;