mirror of
https://github.com/frappe/books.git
synced 2025-01-03 07:12:21 +00:00
fix: TypeError, .round is not a func
- type vue files for Currency, Float, Int, Data - use Number for safe parse cause faster
This commit is contained in:
parent
7c99a76e20
commit
368714a84a
@ -1,9 +1,9 @@
|
||||
import { Fyo } from 'fyo';
|
||||
import { Doc } from 'fyo/model/doc';
|
||||
import { DateTime } from 'luxon';
|
||||
import { Money } from 'pesa';
|
||||
import { Field, FieldType, FieldTypeEnum } from 'schemas/types';
|
||||
import { getIsNullOrUndef, safeParseFloat, titleCase } from 'utils';
|
||||
import { isPesa } from '.';
|
||||
import {
|
||||
DEFAULT_CURRENCY,
|
||||
DEFAULT_DATE_FORMAT,
|
||||
@ -138,8 +138,8 @@ function formatNumber(value: unknown, fyo: Fyo): string {
|
||||
value = fyo.pesa(value.toFixed(20));
|
||||
}
|
||||
|
||||
if ((value as Money).round) {
|
||||
const floatValue = safeParseFloat((value as Money).round());
|
||||
if (isPesa(value)) {
|
||||
const floatValue = safeParseFloat(value.round());
|
||||
return numberFormatter.format(floatValue);
|
||||
}
|
||||
|
||||
|
@ -9,7 +9,7 @@
|
||||
class="text-end"
|
||||
:class="[inputClasses, containerClasses]"
|
||||
:type="inputType"
|
||||
:value="value?.round()"
|
||||
:value="round(value)"
|
||||
:placeholder="inputPlaceholder"
|
||||
:readonly="isReadOnly"
|
||||
:tabindex="isReadOnly ? '-1' : '0'"
|
||||
@ -29,13 +29,16 @@
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
<script lang="ts">
|
||||
// @ts-nocheck
|
||||
import { isPesa } from 'fyo/utils';
|
||||
import { Money } from 'pesa';
|
||||
import { fyo } from 'src/initFyo';
|
||||
import { nextTick } from 'vue';
|
||||
import { safeParseFloat } from 'utils/index';
|
||||
import { defineComponent, nextTick } from 'vue';
|
||||
import Float from './Float.vue';
|
||||
|
||||
export default {
|
||||
export default defineComponent({
|
||||
name: 'Currency',
|
||||
extends: Float,
|
||||
emits: ['input', 'focus'],
|
||||
@ -51,17 +54,44 @@ export default {
|
||||
this.showInput = true;
|
||||
this.$emit('focus', e);
|
||||
},
|
||||
parse(value) {
|
||||
return fyo.pesa(value);
|
||||
round(v: unknown) {
|
||||
if (!isPesa(v)) {
|
||||
v = this.parse(v);
|
||||
}
|
||||
|
||||
if (isPesa(v)) {
|
||||
return v.round();
|
||||
}
|
||||
|
||||
return fyo.pesa(0).round();
|
||||
},
|
||||
onBlur(e) {
|
||||
let { value } = e.target;
|
||||
if (value !== 0 && !value) {
|
||||
value = fyo.pesa(0).round();
|
||||
parse(value: unknown): Money {
|
||||
if (isPesa(value)) {
|
||||
return value;
|
||||
}
|
||||
|
||||
if (typeof value === 'string') {
|
||||
value = safeParseFloat(value);
|
||||
}
|
||||
|
||||
if (typeof value === 'number') {
|
||||
return fyo.pesa(value);
|
||||
}
|
||||
|
||||
if (typeof value === 'bigint') {
|
||||
return fyo.pesa(value);
|
||||
}
|
||||
|
||||
return fyo.pesa(0);
|
||||
},
|
||||
onBlur(e: FocusEvent) {
|
||||
const target = e.target;
|
||||
if (!(target instanceof HTMLInputElement)) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.showInput = false;
|
||||
this.triggerChange(value);
|
||||
this.triggerChange(target.value);
|
||||
},
|
||||
activateInput() {
|
||||
if (this.isReadOnly) {
|
||||
@ -79,5 +109,5 @@ export default {
|
||||
return fyo.format(this.value ?? fyo.pesa(0), this.df, this.doc);
|
||||
},
|
||||
},
|
||||
};
|
||||
});
|
||||
</script>
|
||||
|
@ -1,13 +1,14 @@
|
||||
<script>
|
||||
import Base from './Base';
|
||||
<script lang="ts">
|
||||
import Base from './Base.vue';
|
||||
import { defineComponent } from 'vue';
|
||||
|
||||
export default {
|
||||
export default defineComponent({
|
||||
name: 'Data',
|
||||
extends: Base,
|
||||
computed: {
|
||||
inputType() {
|
||||
return 'text';
|
||||
}
|
||||
}
|
||||
};
|
||||
},
|
||||
},
|
||||
});
|
||||
</script>
|
||||
|
@ -1,19 +1,20 @@
|
||||
<script>
|
||||
<script lang="ts">
|
||||
import { safeParseFloat } from 'utils/index';
|
||||
import { defineComponent } from 'vue';
|
||||
import Int from './Int.vue';
|
||||
|
||||
export default {
|
||||
export default defineComponent({
|
||||
name: 'Float',
|
||||
extends: Int,
|
||||
computed: {
|
||||
inputType() {
|
||||
return 'number';
|
||||
}
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
parse(value) {
|
||||
return safeParseFloat(value)
|
||||
parse(value: unknown): number {
|
||||
return safeParseFloat(value);
|
||||
},
|
||||
},
|
||||
};
|
||||
});
|
||||
</script>
|
||||
|
@ -1,7 +1,9 @@
|
||||
<script>
|
||||
import Data from "./Data.vue";
|
||||
<script lang="ts">
|
||||
import Data from './Data.vue';
|
||||
import { defineComponent } from 'vue';
|
||||
import { safeParseInt } from 'utils/index';
|
||||
|
||||
export default {
|
||||
export default defineComponent({
|
||||
name: 'Int',
|
||||
extends: Data,
|
||||
computed: {
|
||||
@ -10,10 +12,9 @@ export default {
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
parse(value) {
|
||||
const parsedValue = parseInt(value, 10);
|
||||
return isNaN(parsedValue) ? 0 : parsedValue;
|
||||
parse(value: unknown): number {
|
||||
return safeParseInt(value);
|
||||
},
|
||||
},
|
||||
};
|
||||
});
|
||||
</script>
|
||||
|
@ -180,11 +180,11 @@ function safeParseNumber(value: unknown, parser: (v: string) => number) {
|
||||
}
|
||||
|
||||
export function safeParseFloat(value: unknown): number {
|
||||
return safeParseNumber(value, parseFloat);
|
||||
return safeParseNumber(value, Number);
|
||||
}
|
||||
|
||||
export function safeParseInt(value: unknown): number {
|
||||
return safeParseNumber(value, parseInt);
|
||||
return safeParseNumber(value, (v: string) => Math.trunc(Number(v)));
|
||||
}
|
||||
|
||||
export function joinMapLists<A, B>(
|
||||
|
Loading…
Reference in New Issue
Block a user