Giter VIP home page Giter VIP logo

Comments (2)

slipszenko avatar slipszenko commented on September 10, 2024

I've managed to achieve the effect that I was after with the following code:

<template>
  <div class="input-group">
    <div class="input-group-prepend">
      <span class="input-group-text">{{ currencySymbol }}</span>
    </div>
    <currency-input
      :value="initialValue"
      :currency="{ prefix: '' }"
      :locale="$i18n.locale"
      @input="emitChangeInCents"
      class="form-control pr-1 border-radius-box-right" />
  </div>
</template>

<script>
import { CurrencyInput } from 'vue-currency-input';

export default {
  props: {
    value: Number,
    currencySymbol: String,
  },
  data() {
    return {
      // Value must be passed vue-currency-input as dollars/euros/etc.
      initialValue: this.value / 100,
    };
  },
  methods: {
    emitChangeInCents(newValue) {
      // We must return the value in cents
      let valueInCents = 0;

      if (newValue !== null) {
        valueInCents = parseInt((newValue * 100).toFixed(0), 10);
      }

      this.$emit('input', valueInCents);
    },
  },
  components: {
    CurrencyInput,
  },
};
</script>

Thanks!

from vue-currency-input.

jonasesr avatar jonasesr commented on September 10, 2024

This would be a cool feature. You have to keep in mind that not every language has 2 fraction digits. Regarding to this list: https://www.currency-iso.org/dam/downloads/lists/list_one.xml there are several currencies with 3 or 4 fraction digits. A very nice feature would be to set the property valueAsInteger and parses it based on the minimumFractionDigit Option of the Intl.NumberFormat

        const formatter = new Intl.NumberFormat('de-DE', { style: 'currency', currency: 'EUR' }).format(number)
        const options = formatter.resolvedOptions()
        let valueInCents = 0;

        if (value !== null) {
            valueInCents = Number.isInteger(value)
                ? value * Math.pow(10, options.minimumFractionDigits)
                : parseInt((`${value}`).replace('.', ''), 10);
        }

        this.$emit('input', valueInCents);

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.