Giter VIP home page Giter VIP logo

Comments (4)

el95149 avatar el95149 commented on September 10, 2024

Took the liberty of forking and suggesting a fix (crude, most likely, but it's a start):
#20

Let me know what you think.
Cheers.

from vue-currency-input.

el95149 avatar el95149 commented on September 10, 2024

Alternatively, without you changing anything in your code:

<template>
    <el-input v-model="internalValue" v-currency="options" class="currency-input"/>
</template>
<script>
    export default {
        props: ['value', 'currency'],
        components: {},
        data: function () {
            return {
                options: {
                    locale: 'el',
                    currency: this.currency,
                    distractionFree: true,
                    validateOnInput: false
                },
                internalValue: null
            }
        },
        watch: {
            value(newValue, oldValue) {
                // only format when value is set programmatically, not typed in  by user
                if (oldValue == null && newValue != null && this.internalValue == null) {
                    this.internalValue = this.formatCurrency(newValue, this.currency, this.options.locale)
                } else {
                    this.internalValue = newValue
                }
            },
            internalValue(newValue) {
                this.$emit('input', this.$parseCurrency(newValue, this.options.locale, this.options.currency))
            }
        },
        methods: {
            formatCurrency(num, currency, locale) {
                if (typeof num === 'string') {
                    return num
                } else if (num && typeof num === 'number') {
                    return new Intl.NumberFormat(locale, { style: 'currency', currency }).format(num)
                }
                return null
            }
        }
    }
</script>

from vue-currency-input.

dm4t2 avatar dm4t2 commented on September 10, 2024

Hi, there's no need to expose a format method or to re-implement it on your own.
Check out this example: https://codesandbox.io/s/element-ui-currency-input-z8gik

from vue-currency-input.

el95149 avatar el95149 commented on September 10, 2024

Ah, perfect, hadn't noticed that format event!
Closing the issue.
Thanks a lot!

from vue-currency-input.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.