Skip to content

Commit

Permalink
Merge pull request #716 from hyoo-ru/number-fix
Browse files Browse the repository at this point in the history
$mol_number fix input
  • Loading branch information
zerkalica authored Nov 20, 2024
2 parents 5c7d576 + 81842e6 commit 909b89c
Showing 1 changed file with 23 additions and 13 deletions.
36 changes: 23 additions & 13 deletions number/number.view.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,13 @@ namespace $.$$ {
*/
export class $mol_number extends $.$mol_number {

value_limited( next? : any ) : number {
if ( next === undefined ) return this.value()
if ( next === '' ) return this.value( Number.NaN )
value_limited( val? : number ) : number {
if (Number.isNaN( val )) return this.value(val)
if ( val === undefined ) return this.value()

const min = this.value_min()
const max = this.value_max()

const val = Number( next )

if( val < min ) return this.value( min )
if( val > max ) return this.value( max )

Expand All @@ -28,23 +26,35 @@ namespace $.$$ {
override event_inc( next? : Event ) {
this.value_limited( ( this.value_limited() || 0 ) + this.precision_change() )
}

override value_string( next? : string ) {
const next_num = this.value_limited( next )

const precisionView = this.precision_view()
value_normalized(next?: string) {
const next_num = this.value_limited( next === undefined ? next : Number(next) )

if (Number.isNaN(next_num)) return ''

const precision_view = this.precision_view()

if( next_num === 0 ) return '0'
if( !next_num ) return ''

if( precisionView >= 1 ) {
return ( next_num / precisionView ).toFixed()
if( precision_view >= 1 ) {
return ( next_num / precision_view ).toFixed()
} else {
const fixedNumber = Math.log10( 1 / precisionView )
return next_num.toFixed( Math.ceil( fixedNumber ) )
const fixed_number = Math.log10( 1 / precision_view )
return next_num.toFixed( Math.ceil( fixed_number ) )
}
}

@ $mol_mem
override value_string( next? : string ) {
const current = this.value_normalized()

if ( next !== undefined) this.value_normalized( next )

return next ?? current

}

@ $mol_mem
override dec_enabled() : boolean {
return this.enabled() && (
Expand Down

0 comments on commit 909b89c

Please sign in to comment.