feat(lab): Handling of bool options
This commit is contained in:
parent
e957b325c9
commit
de154e4abc
1 changed files with 77 additions and 1 deletions
|
@ -20,7 +20,38 @@ const values = {
|
||||||
}
|
}
|
||||||
</span>
|
</span>
|
||||||
)
|
)
|
||||||
}
|
},
|
||||||
|
bool: props => {
|
||||||
|
const dflt = props.pattern.config.options[props.option].bool
|
||||||
|
const current = props.gist?.options?.[props.option]
|
||||||
|
return (
|
||||||
|
<span className={
|
||||||
|
(dflt==current || typeof current === 'undefined')
|
||||||
|
? 'text-secondary'
|
||||||
|
: 'text-accent'
|
||||||
|
}>
|
||||||
|
{props.gist?.options?.[props.option]
|
||||||
|
? props.app.t('app.yes')
|
||||||
|
: props.app.t('app.no')
|
||||||
|
}
|
||||||
|
</span>
|
||||||
|
)
|
||||||
|
},
|
||||||
|
count: props => {
|
||||||
|
return <p>No val yet</p>
|
||||||
|
},
|
||||||
|
deg: props => {
|
||||||
|
return <p>No val yet</p>
|
||||||
|
},
|
||||||
|
list: props => {
|
||||||
|
return <p>No val yet</p>
|
||||||
|
},
|
||||||
|
mm: props => {
|
||||||
|
return <p>No val yet</p>
|
||||||
|
},
|
||||||
|
constant: props => {
|
||||||
|
return <p>No val yet</p>
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
const Tmp = props => <p>not yet</p>
|
const Tmp = props => <p>not yet</p>
|
||||||
|
@ -41,6 +72,51 @@ const Option = props => {
|
||||||
const Input = inputs[type]
|
const Input = inputs[type]
|
||||||
const Value = values[type]
|
const Value = values[type]
|
||||||
|
|
||||||
|
const toggleBoolean = () => {
|
||||||
|
const dflt = props.pattern.config.options[props.option].bool
|
||||||
|
const current = props.gist?.options?.[props.option]
|
||||||
|
if (typeof current === 'undefined')
|
||||||
|
props.updateGist(['options', props.option], !dflt)
|
||||||
|
else props.unsetGist(['options', props.option])
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (type === 'bool') return (
|
||||||
|
<li className="flex flex-row">
|
||||||
|
<button className={`
|
||||||
|
flex flex-row
|
||||||
|
w-full
|
||||||
|
justify-between
|
||||||
|
px-2
|
||||||
|
text-left
|
||||||
|
text-base-content
|
||||||
|
sm:text-neutral-content
|
||||||
|
items-center
|
||||||
|
pr-6
|
||||||
|
`} onClick={toggleBoolean}>
|
||||||
|
<div className={`
|
||||||
|
grow pl-2 border-l-2
|
||||||
|
${linkClasses}
|
||||||
|
hover:border-secondary
|
||||||
|
sm:hover:border-secondary-focus
|
||||||
|
text-base-content sm:text-neutral-content
|
||||||
|
`}>
|
||||||
|
<span className={`
|
||||||
|
text-3xl mr-2 inline-block p-0 leading-3
|
||||||
|
translate-y-3
|
||||||
|
`}>
|
||||||
|
<>°</>
|
||||||
|
</span>
|
||||||
|
<span>
|
||||||
|
{ props.app.t(`options.${props.pattern.config.name}.${props.option}.title`) }
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<Value type={type} {...props} />
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
|
||||||
|
)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<li className="flex flex-row">
|
<li className="flex flex-row">
|
||||||
<details className="grow">
|
<details className="grow">
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue