A collection of utilities methods for Vtex stores.
dist/
├── vtex-utils.js (UMD)
├── vtex-utils.min.js (UMD, compressed)
├── vtex-utils.common.js (CommonJS, default)
└── vtex-utils.esm.js (ES Module)
Download the script here and include it.
<script type="text/javascript" src="/arquivos/vtex-utils.min.js"></script>
VtexUtils.js supports npm under the name vtex-utils
.
npm install vtex-utils --save
VtexUtils.js can also be loaded as an CommonJS or ES6 module (recomended).
// CommomJS
var VtexUtils = require('vtex-utils');
// ES6 module
import VtexUtils from 'vtex-utils';
With UMD (Universal Module Definition), the package is available on VTEX
namespace.
// Initialize constructor
var vtexUtils = new VTEX.VtexUtils();
// VtexHelpers
var vtexHelpers = vtexUtils.vtexHelpers;
// GlobalHelpers (from UtilifyJS)
var globalHelpers = vtexUtils.globalHelpers;
// LocationHelpers (from UtilifyJS)
var locationHelpers = vtexUtils.locationHelpers;
// Storage (from Store2 | https://github.com/nbubna/store)
var storage = vtexUtils.storage
Docs for vtexUtils.globalHelpers
and vtexUtils.locationHelpers
methods can be found on UtilifyJS
Formats Vtex price
-
number:
- Type:
Integer
- The number to format
- Type:
-
thousands (optional):
- Type:
String
- Default:
'.'
- The thousands delimiter
- Type:
-
decimals (optional):
- Type:
String
- Default:
','
- The decimal delimiter
- Type:
-
length (optional):
- Type:
Integer
- Default:
2
- The length of decimal
- Type:
-
currency (optional):
- Type:
String
- Default:
'R$ '
- Set currency
- Type:
vtexHelpers.formatPrice(1234); // R$ 12,34
vtexHelpers.formatPrice(123456); // R$ 1.234,56
vtexHelpers.formatPrice(123456, null, ',', 3); // R$ 1234,560
vtexHelpers.formatPrice(123456, ',', '.', 2, '$ '); // $ 1,234.56
Unformat Vtex price. Value can be a single string or an array of values
-
value:
- Type:
String|Array
- Price formatted
- Type:
-
decimal (optional):
- Type:
String
- Default:
','
- The decimal delimiter
- Type:
-
formatNumber (optional):
- Type:
Boolean
- Default:
false
- Thousands separator (pt-BR default:
'.'
)
- Type:
var priceFormatted = 'R$ 1.234,56';
vtexHelpers.unformatPrice(priceFormatted); // {unformatted: 123456, real: '1234', cents: '56'}
vtexHelpers.unformatPrice(priceFormatted, null, true); // {unformatted: 123456, real: '1.234', cents: '56'}
vtexHelpers.unformatPrice(['R$ 12,34', 'R$ 23,45', 'R$ 34,56']);
/*
[
{unformatted: 1234, real: '12', cents: '34'}
{unformatted: 2345, real: '23', cents: '45'}
{unformatted: 3456, real: '34', cents: '56'}
]
*/
Take the value of the installment with min price and max installments given
-
price:
- Type:
String|Number
- Price to get installments. Can be formatted price or a integer value.
- Type:
-
minPrice:
- Type:
String|Number
- Min price for each installment. Can be formatted price or a integer value.
- Type:
-
maxInstallments:
- Type:
Number
- Max installments
- Type:
-
interest (optional):
- Type:
Number
- Default:
0
- Interest rate
- Type:
vtexHelpers.setInstallment('R$ 3.499,00', 'R$ 430,00', 10) // {installments: 8, installmentValue: 43737, interest: 0}
vtexHelpers.setInstallment(349900, 43000, 10) // {installments: 8, installmentValue: 43737, interest: 0}
Get the percentage of a discount
-
oldPrice:
- Type:
String|Number
- Original price. Can be formatted price or a integer value.
- Type:
-
newPrice:
- Type:
String|Number
- Price with discount. Can be formatted price or a integer value.
- Type:
-
length (optional):
- Type:
Number
- Default:
0
- Number of decimals
- Type:
vtexHelpers.getPercentage('R$ 179,90', 'R$ 149,50'); // 17 (17% OFF)
vtexHelpers.getPercentage(17990, 14900, 2); // 17.18 (17.18% OFF)
Returns a discount amount or adding a set value.
-
price:
- Type:
String|Number
- Price to apply discount. Can be formatted price or a integer value.
- Type:
-
percent:
- Type:
String|Number
- Percentage to apply. Can be formatted price or a integer value.
- Type:
-
formatted (optional):
- Type:
Boolean
- Default:
false
- Format result
- Type:
vtexHelpers.applyDiscountPercent('R$ 9,55', 37.27); // {discountPrice: 355, priceWithDiscount: 599, priceWithIncrease: 1310}
vtexHelpers.applyDiscountPercent('R$ 9,55', '37.27%'); // {discountPrice: 355, priceWithDiscount: 599, priceWithIncrease: 1310}
vtexHelpers.applyDiscountPercent('R$ 9,55', '37,27%'); // {discountPrice: 355, priceWithDiscount: 599, priceWithIncrease: 1310}
vtexHelpers.applyDiscountPercent(955, 37.27, true); // {discountPrice: 'R$ 3,55', priceWithDiscount: 'R$ 5,99', priceWithIncrease: 'R$ 13,10'}
Formats price from Vtex API /api/catalog_system/pub/products/search/
to use in formatPrice
method
- val:
- Type:
Number
- Value to convert
- Type:
vtexHelpers.fixProductSearchPrice(250.25); // 25025
Get first available SKU from Vtex API /api/catalog_system/
end point
Returns an object with first available SKU or false if all are unvailable
- product:
- Type:
Object
- Product full data
- Type:
vtexjs.catalog.getProductWithVariations(1234)
.then(function(res) {
var availableSku = vtexHelpers.getFirstAvailableSku(res);
window.console.log(availableSku);
});
Get the original VTEX image source from a thumb
- src:
- Type:
String
- The source of the thumb
- Type:
vtexHelpers.getOriginalImage('http://domain.vteximg.com.br/arquivos/ids/155242-292-292/image.png');
// http://domain.vteximg.com.br/arquivos/ids/155242/image.png
Change the width & height from a given VTEX image source
-
src:
- Type:
String
- The source of the image
- Type:
-
width:
- Type:
String | Integer
- The new image with
- Type:
-
height:
- Type:
String | Integer
- The new image height
- Type:
vtexHelpers.getResizedImage('http://domain.vteximg.com.br/arquivos/ids/155242-292-292/image.png', 500, 600);
// http://domain.vteximg.com.br/arquivos/ids/155242-500-600/image.png
vtexHelpers.getResizedImage('http://domain.vteximg.com.br/arquivos/ids/155242/image.png', 100, 100);
// http://domain.vteximg.com.br/arquivos/ids/155242-100-100/image.png
Resize proportionally an VTEX image by aspect ratio
-
src:
- Type:
String
- The source of the image
- Type:
-
type:
- Type:
String
- Type to resize (width or height)
- Type:
-
newSize:
- Type:
Number
- New size to redimensioning
- Type:
-
aspectRatio:
- Type:
Number
- Image aspect ratio (calculate by (width / height))
- Type:
var imgSrc = 'http://domain.vteximg.com.br/arquivos/ids/155242-292-292/image.png';
var newSize = 250;
var aspectRatio = (10/15);
vtexHelpers.getResizeImageByRatio(imgSrc, 'width', newSize, aspectRatio);
// http://domain.vteximg.com.br/arquivos/ids/155242-250-375/image.png
vtexHelpers.getResizeImageByRatio(imgSrc, 'height', newSize, aspectRatio);
// http://domain.vteximg.com.br/arquivos/ids/155242-167-250/image.png
Get the Vtex server time
- callback:
- Type:
Function
- The callback to call when the request finishes. The callback will a javascript Date object.
- Type:
vtexHelpers.getServerTime(function(date) {
window.console.log(date.getFullYear());
});
Get category tree
-
categoryId (optional):
- Type:
Integer
- Default:
undefined
- Return the specific Category
- Type:
-
depth (optional):
- Type:
Integer
- Default:
50
- The tree depth
- Type:
vtexHelpers.getCategories().then(function(res) {
window.console.log(res)
}); // Return all categories
vtexHelpers.getCategories(1000001, 1).then(function(res) {
window.console.log(res));
}); // Return first level from category id
Get product specification
-
data:
- Type:
Object
- Vtex API data from
/api/catalog_system/pub/products/search/
endpoint
- Type:
-
specName:
- Type:
String
- Specification name
- Type:
-
defaultVal (optional):
- Type:
Boolean|String
- Default:
false
- Value to return if spec doesn't exists
- Type:
// Data from API '/api/catalog_system/pub/products/search/'
var response = {
Características: ["Cor real", "Ocasião", "Composição", "Cor"],
Composição: ["Liga Mista, Pedra Natural Pirita"],
Cor: ["Dourado"],
Cor real: ["Ouro"],
Ocasião: ["Weekend"],
allSpecifications: ["Cor real", "Ocasião", "Composição", "Cor"],
// More data...
};
vtexHelpers.getProductSpec(response, 'Cor'); // 'Dourado'
vtexHelpers.getProductSpec(response, 'Cores'); // false
vtexHelpers.getProductSpec(response, 'Cores', 'Branco'); // 'Branco'
Get product shipping value.
-
postalCode:
- Type:
String
- Postal code to calculate. Can be
xxxxx-xxx
orxxxxxxxx
format
- Type:
-
skuId (optional):
- Type:
Integer
- Default:
skuId
- Sku ID to calculate. If not passed, get first sku available on product page from
skuJson
global variable. If this method used on other pages,skuId
is required
- Type:
-
quantity (optional):
- Type:
Integer
- Default:
1
- Product quantity to calculate
- Type:
// On product page with a valid postal code
vtexHelpers.getShipping('01010-010')
.then(function(res) {
if ( !res.error ) {
console.log('SUCCESS', res);
}
if ( res.error ) {
console.log('INVALID TYPE', res);
}
});
/*
Case success, will return an object with properties:
{
error: false,
formattedResponse: {
shippingValue: 'R$ 10,00',
shippingText: 'Entrega em 4 dias úteis para o CEP 01010-010',
shippingType: 'Frete Transportadora'
}
fullResponse: '<table><thead>...' // Original content from api
}
Case failed (invalid postal code, invalid sku ID, etc.), will return
{
error: true,
formattedResponse: {
shippingText: 'Não é possível calcular o valor do Frete para o CEP informado'
}
fullResponse: '<div class="cep-invalido" id="divFreteInvalido">...' // Original content from api
}
*/
Replace break lines from product descriptions/more
- str:
- Type:
String
- String to replace
- Type:
var string = 'Foo\nBar\n\rBaz\r';
vtexHelpers.replaceBreakLines(string); // 'Foo<br />Bar<br /><br />Baz<br />'
Convert a string IDs given into an integer array values
-
str:
- Type:
String
- String with IDs
- Type:
-
separator (optional):
- Type:
String
- Default:
','
- Separator to split
- Type:
var commaStr = '1, 2, 3, 4';
stringIdsToArray(str); // [1, 2, 3, 4]
var dashedStr = ' - 1 - 2 - 3 - 4 - ';
stringIdsToArray(dashedStr, '-'); // [1, 2, 3, 4]
Check if the user is logged into Vtex
vtexHelpers.checkLogin().then(function(res) {
// If user defined
console.log(res);
})
.fail((err) => {
// If user isn't defined
console.log(err)
});
Open default Vtex popup login.
Before use, don't forget to import Vtex Controller <vtex.cmc:welcomeMessage/>
-
noReload (optional):
- Type:
Boolean
- Default:
false
- Reload page after login
- Type:
-
url (optional):
- Type:
Boolean
- Default:
'/'
- Url to rdirect
- Type:
vtexHelpers.openPopupLogin(); // Open popup and reload page after success login
vtexHelpers.openPopupLogin(true); // Open popup and don't reload page after success login
vtexHelpers.openPopupLogin(false, '/account'); // Open popup and don't reload page after success login and redirect to Account page
Use $(window).on('closed.vtexid', callback)
event to set any property if noReload
is true
If noReload
is true
, it'll ignore url
param
Open default Vtex popup login.
Require vtexjs
.
-
items:
- Type:
Array
- An Array of Objects with item(s) to add
- Type:
-
expectedOrderFormSections (optional):
- Type:
Array
- Default:
null
- Fields to retrieve
- Type:
-
salesChannel (optional):
- Type:
Integer/String
- Default:
1
- Sales Channel id
- Type:
var items = [{
id: 1,
quantity: 1,
seller: '1',
}, {
id: 2,
quantity: 2,
seller: '1',
}];
vtexHelpers.addToCart(items).then(function(res) {
window.console.log(res);
})
.fail(function(err) {
window.console.log(err);
});
Remove all items from cart.
Require vtexjs
.
vtexHelpers.clearCart()
.then(function(res) {
window.console.log(res)
})
.fail(function(err) {
window.console.log(err)
});
Send notify me data for unavailable products.
Return a promise.
-
name:
- Type:
String
- Customer name
- Type:
-
email:
- Type:
String
- Customer e-mail
- Type:
-
skuId:
- Type:
Integer
- Sku ID (if product ID passed, will return a fail promise)
- Type:
var name = 'Test Notify';
var email = '[email protected]';
var skuId = 12321;
vtexHelpers.notifyMe(name, email, skuId)
.then(function(res) {
console.log(res.successMessage); // Cadastrado com sucesso. Assim que o produto for disponibilizado você receberá um email avisando.
})
.fail(function(err) {
console.log(err.errorMessage); // Não foi possível cadastrar. Tente mais tarde.
});
Docs for RivetsUtilify can be found here
To set RivetsUtilify:
// Import RivetsUtilify
<script type="text/javascript" src="rivets-utilify.min.js"></script>
// Initialize constructor
var vtexUtils = new VTEX.VtexUtils();
// Sets method
vtexUtils.setRivetsUtilify(RivetsUtilify);
Tests are using mocha. To run the tests use:
$ npm test
VtexUtils.js is open-sourced software licensed under the MIT license.
jQuery 1.8.3+
vtexjs