| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228 |
- import { useI18n } from "vue-i18n";
- /**
- * @description Corta uma string em um determinado tamanho.
- * @param {string} string string a ser cortada.
- * @param {string} size tamanho da string.
- * @returns {string} string cortada.
- */
- const excerpt = (string, size = 30) => {
- if (size == null) return string;
- if (string.length > size) {
- string = string.substring(0, size) + "...";
- }
- return string;
- };
- /**
- * @description Formata uma data de DD/MM/YYYY para YYYY-MM-DD
- * @param {string} date data.
- * @param {string} time tempo.
- * @throws {Error} Caso a data seja nula ou invalida.
- * @returns {string} data formatada.
- */
- const formatDateDMYtoYMD = (date, time) => {
- if (!date) throw new Error(useI18n().t("validation.rules.required"));
- const testDate =
- /^([0-2][0-9]|(3)[0-1])(\/)(((0)[0-9])|((1)[0-2]))(\/)\d{4}$/;
- if (testDate.test(date) === false) throw new Error(useI18n().t("validation.rules.date"));
- const [day, month, year] = date.split("/");
- return `${year}-${month}-${day} ${time ? time : ""}`;
- };
- /**
- * @description Converte uma data e hora para o formato brasileiro.
- * @param {string} dateTimeString data e hora.
- * @returns {string} data e hora no formato brasileiro.
- * @throws {Error} Caso a data seja nula ou invalida.
- * @returns {string} data formatada.
- * @example
- * // convertDateTime("2023-05-23T13:07:27.000000Z");
- * // Output: 23/05/2023 10:07:27
- */
- const convertDateTime = (dateTimeString) => {
- const dateTime = new Date(dateTimeString);
- const options = {
- timeZone: "America/Sao_Paulo",
- day: "2-digit",
- month: "2-digit",
- year: "numeric",
- hour: "2-digit",
- minute: "2-digit",
- second: "2-digit",
- };
- const formattedDateTime = dateTime
- .toLocaleString("pt-BR", options)
- .replace(",", "");
- return formattedDateTime;
- };
- /**
- * @description Formata uma data de YYYY-MM-DD para DD/MM/YYYY
- * @param {string} dateTime data e hora.
- * @returns {string} data e hora no formato brasileiro.
- * @example
- * // formatDateYMDtoDMY("2023-05-23T13:07:27.000000Z");
- * // Output: 23/05/2023 10:07:27
- */
- const formatDateYMDtoDMY = (dateTime) => {
- const [datePart, timePart] = dateTime.split(" ");
- const [year, month, day] = datePart.split("-");
- const formattedDate = `${day}/${month}/${year}`;
- if (timePart) {
- const [hours, minutes, seconds] = timePart.split(":");
- const formattedTime = `${hours}:${minutes}:${seconds}`;
- return `${formattedDate} ${formattedTime}`;
- }
- return formattedDate;
- };
- /**
- * @description Checa a moeda selecionada.
- * @param {number} moeda moeda selecionada.
- * @returns {object} opções de moeda.
- */
- const checaMoeda = (moeda) => {
- let currencyOptions = {};
- if (moeda == 1) {
- currencyOptions = {
- locale: "pt-BR",
- currency: "BRL",
- currencyDisplay: "symbol",
- hideCurrencySymbolOnFocus: false,
- hideGroupingSeparatorOnFocus: false,
- hideNegligibleDecimalDigitsOnFocus: false,
- autoDecimalDigits: true,
- useGrouping: true,
- accountingSign: false,
- };
- } else if (moeda == 2) {
- currencyOptions = {
- currency: "PYG",
- locale: "es-PY",
- valueAsInteger: true,
- distractionFree: true,
- precision: 0,
- autoDecimalMode: true,
- valueRange: { min: 0 },
- allowNegative: true,
- };
- } else if (moeda == 3) {
- currencyOptions = {
- locale: "en-US",
- currency: "USD",
- currencyDisplay: "symbol",
- hideCurrencySymbolOnFocus: true,
- hideGroupingSeparatorOnFocus: true,
- hideNegligibleDecimalDigitsOnFocus: false,
- autoDecimalDigits: true,
- useGrouping: true,
- accountingSign: false,
- };
- }
- return currencyOptions;
- };
- /**
- * @description Filtra a moeda.
- * @param {number} value valor.
- * @returns {string} valor formatado.
- */
- const filterCurrency = (value) => {
- if (value) {
- value = parseFloat(value);
- return value.toLocaleString("pt-BR", {
- style: "currency",
- currency: "BRL",
- });
- }
- return value;
- };
- /**
- * @description Filtra a unidade de medida.
- * @param {number} value valor.
- * @returns {string} valor formatado.
- */
- const filterUnidadeMedida = (value) => {
- return value.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ".");
- };
- /**
- * @description Valida se a data é válida.
- * @param {string} date data.
- * @returns {boolean} true se a data é válida, false caso contrário.
- */
- const validaData = (date) => {
- const regex = /^(0[1-9]|[12][0-9]|3[01])\/(0[1-9]|1[0-2])\/\d{4}$/;
- return regex.test(date);
- };
- /**
- * @description Valida se a hora é válida.
- * @param {string} time hora.
- * @returns {boolean} true se a hora é válida, false caso contrário.
- */
- const validaHora = (time) => {
- const regex = /^([0-1][0-9]|2[0-3]):[0-5][0-9]$/;
- return regex.test(time);
- };
- /**
- * @description Valida se a data e hora são válidas.
- * @param {string} dataHora data e hora.
- * @returns {boolean} true se a data e hora são válidas, false caso contrário.
- */
- const validaDataHora = (dataHora) => {
- const regex =
- /^(0[1-9]|[12][0-9]|3[01])\/(0[1-9]|1[0-2])\/\d{4}\s([0-1][0-9]|2[0-3]):[0-5][0-9]$/;
- return regex.test(dataHora);
- };
- /**
- * @description Formata a quantidade.
- * @param {number} value valor.
- * @returns {string} valor formatado.
- */
- const formatQuantity = (value) => {
- if (value) {
- return value
- .toString()
- .replace(/[^0-9]/g, "")
- .replace(/\B(?=(\d{3})+(?!\d))/g, ".");
- }
- return value;
- };
- /**
- * @description Formata a moeda.
- * @param {number} value valor.
- * @returns {string} valor formatado.
- */
- const formatCurrency = (value) => {
- if (value != null) {
- value = parseFloat(value);
- return value.toLocaleString("pt-BR", {
- minimumFractionDigits: 2,
- style: "currency",
- currency: "BRL",
- });
- }
- return value;
- };
- export {
- formatDateDMYtoYMD,
- formatDateYMDtoDMY,
- excerpt,
- convertDateTime,
- checaMoeda,
- filterCurrency,
- filterUnidadeMedida,
- validaData,
- validaHora,
- validaDataHora,
- formatQuantity,
- formatCurrency,
- };
|