Only validate tipRandom if enabled (#1284)

* Only validate tipRandom if enabled

* Use consistent naming scheme for zap settings

---------

Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
This commit is contained in:
ekzyis 2024-08-03 19:51:15 -05:00 committed by GitHub
parent 5d0e071939
commit 288fa37197
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 6 additions and 3 deletions

View File

@ -542,17 +542,20 @@ export const actSchema = object({
export const settingsSchema = object().shape({ export const settingsSchema = object().shape({
tipDefault: intValidator.required('required').positive('must be positive'), tipDefault: intValidator.required('required').positive('must be positive'),
tipRandom: boolean(),
tipRandomMin: intValidator.nullable().positive('must be positive') tipRandomMin: intValidator.nullable().positive('must be positive')
.when(['tipRandomMax'], ([max], schema) => { .when(['tipRandom', 'tipRandomMax'], ([enabled, max], schema) => {
let res = schema let res = schema
if (!enabled) return res
if (max) { if (max) {
res = schema.required('minimum and maximum must either both be omitted or specified').nonNullable() res = schema.required('minimum and maximum must either both be omitted or specified').nonNullable()
} }
return res.lessThan(max, 'must be less than maximum') return res.lessThan(max, 'must be less than maximum')
}), }),
tipRandomMax: intValidator.nullable().positive('must be positive') tipRandomMax: intValidator.nullable().positive('must be positive')
.when(['tipRandomMin'], ([min], schema) => { .when(['tipRandom', 'tipRandomMin'], ([enabled, min], schema) => {
let res = schema let res = schema
if (!enabled) return res
if (min) { if (min) {
res = schema.required('minimum and maximum must either both be omitted or specified').nonNullable() res = schema.required('minimum and maximum must either both be omitted or specified').nonNullable()
} }

View File

@ -1040,7 +1040,7 @@ const TipRandomField = () => {
groupClassName='mb-0' groupClassName='mb-0'
label={ label={
<div className='d-flex align-items-center'> <div className='d-flex align-items-center'>
random zap values random zaps
<Info> <Info>
<ul className='fw-bold'> <ul className='fw-bold'>
<li>Set a minimum and maximum zap amount</li> <li>Set a minimum and maximum zap amount</li>