Referência da API Shopify Scripts

Os scripts são compilados por meio de uma API Ruby que proporciona considerável controle e flexibilidade.

Há diferentes tipos de script. A atribuição do tipo de script acontece quando o script é criado no app Script Editor com base no modelo que você escolheu para começar:

Scripts de itens de linha

Esses scripts afetam itens de linha em um carrinho e podem alterar preços e conceder descontos. Esses script são executados sempre que uma alteração é feita no carrinho.

Os scripts de item de linha para desconto se aplicam apenas ao primeiro pagamento de uma assinatura. Os pagamentos seguintes não são afetados.

Alguns métodos só podem ser usados em scripts de itens de linha.

Scripts de frete

Esses scripts interagem com o frete e podem afetar as formas e os descontos concedidos no frete. Eles são executados ao acessar a página de opções de frete do checkout.

Os scripts de frete que concedem descontos à taxa de frete de uma assinatura se aplicam apenas ao primeiro pagamento. Os pagamentos seguintes não são afetados.

Alguns métodos só podem ser usados em scripts de frete.

Scripts de pagamento

Esses scripts interagem com pagamentos e podem renomear, ocultar e reordenar gateways de pagamento. Observe que os scripts de pagamento não interagem com os gateways de pagamento mostrados antes da tela de checkout, como o Apple Pay. Esses scripts são executados quando o checkout acessa a página de pagamentos.

Alguns métodos só podem ser usados em scripts de pagamento.

Métodos gerais

Os métodos a seguir podem ser usados em qualquer tipo de script:

Entrada

Métodos de entrada de script
MétodoTipo de devoluçãoDescrição
.cartCarrinhoRetorna um objeto "cart" mutável.
.localestringRetorna a localidade do cliente. Por exemplo, en , fr ou pt-BR.

Carrinho

O objeto "carrinho" só está disponível na loja virtual. Alguns carrinhos abandonados têm acesso ao objeto "carrinho". No entanto, se um carrinho foi fechado e, em seguida, o cliente decidir acessá-lo, ele será enviado para o carrinho pré-preenchido e o objeto "carrinho" não existirá mais. Isso ocorre porque a vitrine foi ignorada pelo e-mail de carrinho abandonado.

Métodos de script usando o objeto Cart
MétodoTipo de devoluçãoDescrição
.customerClienteRetorna o proprietário do carrinho (caso aplicável).
.shipping_addressEndereço de entregaRetorna o endereço de entrega do proprietário do carrinho (caso aplicável).
.discount_codevaria Retorna:

O discount_code está presente se houver um desconto aplicado ao carrinho. Isso não significa necessariamente que o preço do carrinho mudará. Por exemplo, se há um desconto aplicável a carrinhos acima de US$ 50 e um script reduz o preço do carrinho para menos de US$ 50, o discount_code ainda está presente, mas o preço do carrinho não é alterado.

Veja um exemplo de discount_code.

.line_items Listar<LineItem>Retorna uma lista contendo os itens de linha do carrinho.
.presentment_currency Listar<String>Retorna a moeda (de apresentação) local do cliente (em formato ISO 4217). Por exemplo, USD.
.subtotal_priceDinheiroRetorna o preço do subtotal do carrinho depois da aplicação de descontos aos itens de linha, mas antes da aplicação de códigos de desconto.
.total_weightgramasRetorna o peso total de todos os itens de linha do carrinho.

CartDiscount::FixedAmount

Métodos de script usando o objeto CartDiscount::FixedAmount
MétodoTipo de devoluçãoDescrição
.codeStringRetorna o código de desconto usado para aplicar o desconto.
.amountDinheiroRetorna a quantia em dinheiro do desconto.
.reject({ message: String })nilRecusa o código de desconto aplicado ao carrinho. É preciso haver uma mensagem.
.rejected?BooleanoRetorna se o código de desconto foi recusado.

CartDiscount::Percentage

Métodos de script usando o objeto CartDiscount::Percentage
MétodoTipo de devoluçãoDescrição
.codeStringRetorna o código de desconto usado para aplicar o desconto.
.percentageDecimalRetorna o valor percentual do desconto.
.reject({ message: String })nilRecusa o código de desconto aplicado ao carrinho. É preciso haver uma mensagem.
.rejected?BooleanoRetorna se o código de desconto foi recusado.

CartDiscount::Shipping

Métodos de script usando o objeto CartDiscount::Shipping
MétodoTipo de devoluçãoDescrição
.codeStringRetorna o código de desconto usado para aplicar o desconto.
.reject({ message: String })nilRecusa o código de desconto aplicado ao carrinho. É preciso haver uma mensagem.
.rejected?BooleanoRetorna se o código de desconto foi recusado.

Cliente

Métodos de script usando o objeto Customer
MétodoTipo de devoluçãoDescrição
.idInteiroRetorna o número de ID do cliente.
.emailStringRetorna o endereço de e-mail do cliente.
.tags Listar <Tag>Retorna uma lista de strings representando qualquer conjunto de tags de um cliente.
.orders_countInteiroRetorna o número total de pedidos feitos pelo cliente.
.total_spentDinheiroRetorna o valor total gasto pelo cliente em todos os pedidos.
.accepts_marketing?BooleanoRetorna se o cliente aceita marketing.

LineItem

<tdgrams
Métodos de script usando o objeto LineItem
MétodoTipo de devoluçãoDescrição
.gramsRetorna o peso total do item de linha.
.line_priceDinheiroO preço do item de linha.
.discounted?BooleanoRetorna se o preço de um item de linha foi descontado por um script ou código de desconto aplicado manualmente. O uso de códigos de desconto não afeta o valor retornado.
.propertieshashRetorna as propriedades que foram especificadas para os itens de linha.
.variantVarianteRetorna a variante de produto específica representada pelo item de linha.
.quantityInteiroRetorna a quantidade do item de linha.
.selling_plan_idInteiroRetorna o ID do plano de venda do item de linha. Esse método é útil quando a loja vende assinaturas e você quer que o script detecte quando uma variante de produto é vendida como assinatura.

Lista

Métodos de script usando o objeto List
MétodoTipo de devoluçãoDescrição
.newListaCria um novo objeto para representar uma lista.
.[]Element ou nil

Retorna o elemento no índice especificado.

.&Lista

Retorna uma nova lista contendo elementos comuns às duas listas, sem duplicatas.

.delete_ifListaExclua elementos usando um bloco de código opcional. Confira a documentação do método delete_if do Ruby.
.empty?Booleano

Retorna true (verdadeiro) se a lista não incluir elementos.

.firstElement ou nil

Retorna o primeiro elemento ou nil (nulo) se a lista estiver vazia.

.index(*args, &block)int ou nil

Retorna o índice do primeiro elemento da lista. Se for oferecido um bloco em vez de um argumento, retorna o índice do primeiro elemento para o qual o bloco é verdadeiro.

.rindex(*args, &block)int ou nil

Retorna o índice do último elemento da lista. Se for oferecido um bloco em vez de um argumento, retorna o índice do primeiro elemento para o qual o bloco é verdadeiro.

.lastElement ou nil

Retorna o último elemento ou nil se a lista estiver vazia.

.lengthint

Retorna o número de elementos da lista.

.sizeint

Alias para comprimento.

.each(*args, &block)Lista

Chama um bloco uma vez para cada elemento na lista, passando o elemento como parâmetro ao bloco.

Endereço de entrega

Métodos de script usando o objeto ShippingAddress
MétodoTipo de devoluçãoDescrição
.namestringRetorna o nome da pessoa associada ao endereço de entrega.
.address1stringRetorna a parte do endereço de entrega referente ao endereço postal.
.address2stringRetorna o campo adicional opcional do endereço de entrega referente ao endereço postal.
.phonestringRetorna o número de celular do endereço de entrega.
.citystringRetorna a cidade do endereço de entrega.
.zipstringRetorna o CEP do endereço de entrega.
.provincestringRetorna a província/estado do endereço de entrega.
.province_codestringRetorna o valor abreviado da província/estado do endereço de entrega.
.country_codestringRetorna o valor abreviado do país do endereço de entrega.

Dinheiro

Métodos de script usando o objeto Money
MétodoTipo de devoluçãoDescrição
.derived_from_presentment(customer_cents:X)DinheiroConverte um valor (em centavos) na moeda (de apresentação) local do cliente para a moeda de sua loja. Este método aceita o parâmetro customer_cents, que exibe os números em centavos. Por exemplo, Money.derived_from_presentment(customer_cents: 500).
.newDinheiroCria um novo objeto para representar um preço.
.zeroDinheiro

Cria um novo objeto com o preço zero.

+DinheiroAdiciona dois objetos Money.
-DinheiroSubtrai um objeto Money de outro objeto.
*DinheiroMultiplica um objeto Money por um número.

Exemplos de Money

Money.new(cents: 1000)

Cria um objeto Money representando mil centavos de dólar ou US$ 10.

Money.new(cents: 100) * 50

Cria um objeto Money representando US$ 1, multiplicando esse valor por 50. Retorna um objeto Money representando US$ 50.

Variante

Métodos de script usando o objeto Variant
MétodoTipo de devoluçãoDescrição
.idInteiroRetorna o número de ID da variante.
.priceDinheiroRetorna o preço unitário da variante.
.productProdutoRetorna o produto associado da variante.
.skus Listar<String>Retorna as SKUs (Unidades de manutenção de estoque) da variante, que geralmente são usadas para acompanhar o estoque.
.titleStringRetorna o título da variante.

Produto

Métodos de script usando o objeto Product
MétodoTipo de devoluçãoDescrição
.idInteiroRetorna o número de ID do produto.
.gift_card?BooleanoRetorna se o produto é um cartão-presente.
.tags Listar <Tag>Retorna uma lista de strings representando as tags definidas para esse produto.
.product_typeStringUma categorização com a qual um produto pode ser marcado, normalmente usada para filtragem e pesquisa.
.vendorStringRetorna o fornecedor do produto.

Kernel

Kernel é um módulo Ruby que está incluído em todas as classes. Como resultado, seus métodos estão disponíveis para cada um dos objetos. Esses métodos agem da mesma maneira que as funções globais em outros idiomas.

Métodos de script usando o objeto Kernel
MétodoTipo de devoluçãoDescrição
.exitnenhumEncerra a execução do script atual sem erros. Se isso for executado antes que qualquer coisa seja atribuída a Output.cart, o script não terá efeito. Essa é uma maneira útil de sair de scripts, por exemplo, se o cliente não estiver qualificado para executar o script.

Exemplo de kernel

customer = Input.cart.customer
if customer && customer.email.end_with?("@mycompany.com")
  # Employees are not eligible for this promotion.
  exit
end

Métodos de item de linha

Os métodos a seguir podem ser usados apenas em scripts de item de linha:

Carrinho

Métodos de script usando o objeto Cart nos scripts de itens de linha
MétodoTipo de devoluçãoDescrição
.subtotal_price_wasDinheiroRetorna o preço subtotal do carrinho antes da aplicação de qualquer desconto.
.subtotal_price_changed?BooleanoRetorna se o preço subtotal foi alterado.

LineItem

Métodos de script usando o objeto LineItem em scripts de itens de linha
MétodoTipo de devoluçãoDescrição
.change_line_price(Money new_price, { message: String }) DinheiroAltere o preço do item de linha para o valor especificado. É preciso haver uma mensagem. new_price precisa ser menor que o preço atual.
.original_line_priceDinheiroRetorna o preço original do item de linha antes da aplicação de scripts e descontos.
.line_price_wasDinheiroRetorna o preço do item de linha antes de o script atual aplicar as alterações.
.line_price_changed?BooleanoRetorna se o preço do item de linha foi alterado.
.change_properties(hash new_properties, { message: String }) hashDefine novas propriedades para os itens de linha. O hash de propriedades original é armazenado em properties_was, e o hash de propriedades passado ao método passa a ser as novas propriedades do item de linha.
.properties_washashRetorna o hash de propriedades original do item de linha antes da aplicação de qualquer alteração.
.properties_changed?BooleanoRetorna se as propriedades do item de linha foram alteradas.
.split({ take: Integer })LineItemDivide um item de linha em dois itens de linha. take especifica qual quantidade remover do item de linha original para criar o novo item de linha.

Exemplo de .split

Este exemplo de script divide um item de linha chamado original_line_item em dois itens de linha. O novo item de ilha tem uma quantidade de 1 (especificado por take: 1). Em seguida, o script aplica um preço com desconto ao novo item de linha com a mensagem "Terceiro chapéu por 5 dólares".

if original_line_item.quantity >= 3
  new_line_item = original_line_item.split(take: 1)
  new_line_item.change_line_price(Money.new(cents: 500), message: "Third hat for 5 dollars")
  cart.line_items << new_line_item
end

Variante

Métodos de script usando o objeto Variant em scripts de itens de linha
MétodoTipo de devoluçãoDescrição
.compare_at_priceDinheiroRetorna a Comparação de preços da variante. Retorna nil se não houver uma Comparação de preços para a variante.

Formas de frete

Os métodos a seguir podem ser usados nos scripts de frete:

Entrada

Métodos de script usando o objeto Input nos scripts de frete
MétodoTipo de devoluçãoDescrição
.shipping_ratesShippingRateListRetorna uma lista de todas as taxas de frete.

ShippingRateList

Métodos de script usando o objeto ShippingRateList em scripts de frete
MétodoTipo de devoluçãoDescrição
.delete_ifShippingRateListExclua taxas de frete usando um bloco de código opcional. Confira a documentação do método delete_if do Ruby.
.sort!ShippingRateListOrganize as taxas de frete usando o operador de comparação ou um bloco de código opcional. Confira a documentação do método sort! do Ruby.
.sort_by!ShippingRateListOrganize as taxas de frete usando um bloco de código opcional. Confira a documentação do método sort_by! do Ruby.

ShippingRate

Métodos de script usando o objeto ShippingRate em scripts de frete
MétodoTipo de devoluçãoDescrição
.codeStringRetorna o código da taxa de frete.
.markupDinheiroRetorna a marcação para uma taxa de frete, se aplicável.
.nameStringRetorna o nome da taxa de frete. Ele pode ser modificado usando o método change_name.
.priceDinheiroRetorna o preço da taxa de frete.
.sourceStringRetorna a origem (a transportadora) associada à taxa de frete, se relevante. Não pode ser modificado.
.change_name(String new_name)String Altera o nome (máximo de 255 caracteres) da taxa de frete. Não é possível alterar, excluir nem ocultar a origem.
.apply_discount(Money discount, { message: String })DinheiroAplica um desconto do valor fixo especificado. O preço não pode ser reduzido para menos de 0. Uma mensagem é necessária.
.phone_required?BooleanoRetorna true (verdadeiro) se for necessário um número de celular para obter a taxa de frete ou false (falso) se não for necessário o número de celular.

Formas de pagamento

Os métodos a seguir podem ser usados nos scripts de pagamento:

Entrada

Métodos de script usando o objeto Input nos scripts de pagamento
MétodoTipo de devoluçãoDescrição
.payment_gatewaysPaymentGatewaysListRetorna uma lista de todos os gateways de pagamento da loja.

PaymentGatewayList

Métodos de script usando o objeto PaymentGatewayList em scripts de pagamento
MétodoTipo de devoluçãoDescrição
.delete_ifPaymentGatewayListExclua gateways de pagamento usando um bloco de código opcional. Confira a documentação do método delete_if do Ruby.
.sort!PaymentGatewayListOrganize os gateways de pagamento usando o operador de comparação ou um bloco de código opcional. Confira a documentação do método Ruby's sort!.
.sort_by!PaymentGatewayListOrganize os gateways de pagamento usando um bloco de código opcional. Confira a documentação do método sort_by! do Ruby.

PaymentGateway

MétodoTipo de devoluçãoDescrição
.nameStringRetorna o nome do gateway de pagamento.
.enabled_card_brands Listar<String>

Se o gateway de pagamento for compatível com cartões de crédito, retorna uma lista dos tipos de cartões de crédito aceitos pela loja. Se o gateway não for compatível com cartões de crédito, retorna uma lista vazia.

.change_name(String new_name)StringAltera o nome do gateway de pagamento. Vale lembrar que não é possível renomear esses serviços com logos.

Exemplos

No exemplo de script de item de linha a seguir, quando um cliente solicita um produto que não é um cartão-presente, o preço do produto é reduzido em US$ 9. Da mesma forma, o valor total que o cliente gastou em todas as visitas à sua loja é mostrado:

customer = Input.cart.customer Input.cart.line_items.each do |line_item| product = line_item.variant.product next if product.gift_card? line_item.change_line_price(line_item.line_price - Money.new(cents: 900), message: customer.total_spent) end Output.cart = Input.cart

Saiba mais

Saiba mais sobre:

Não encontrou as respostas que está procurando? Estamos sempre à disposição para ajudar você.