npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

rn-stone-pos

v1.0.0

Published

test

Downloads

5

Readme

React Native Stone Lib é uma biblioteca destinada a integrar aplicações React Native com a SDK nativa da Stone, permitindo a comunicação com terminais POS da Stone, como Sunmi, Ingenico ou PAX. A biblioteca possibilita realizar transações financeiras, gerenciar pinpads, imprimir recibos e muito mais.

💻 Pré-requisitos

  • NodeJS >= 18.0.0

  • React Native >= 0.72

  • Expo >= 47 (opcional)

  • Token de acesso ao repositório privado da Stone (packageCloud)

🚀 Instalação

A Stone possui um repositório privado no packageCloud, portanto, é necessário ter seu token de acesso para baixar as dependências.

Configuração do Token

Você pode adicionar a variável StonePos_packageCloudToken ao seu arquivo gradle.properties na pasta android do seu projeto ou defini-la como uma variável de ambiente global (útil para builds em CI).

Outras variáveis opcionais:

Passos para instalação

Instale a biblioteca usando npm:

npm install rn-stone-lib

Configuração no Android

Passos Obrigatórios

Edite o arquivo android/app/build.gradle (NÃO android/build.gradle) e adicione:

apply from: "../../node_modules/rn-stone-lib/android/stone-repo.gradle"

Se estiver desenvolvendo para POS, adicione também:

apply from: "../../node_modules/rn-stone-lib/android/dynamic-hal.gradle"

Isso habilitará os módulos HAL conforme suas necessidades, desde que StonePos_include* esteja definido como true.

Resolução de Problemas

  • MinSDK: Defina minSdkVersion para 22 no seu arquivo build.gradle, conforme exigência da Stone.

  • Erro de mesclagem de manifesto: Se ocorrer um erro relacionado ao atributo application@allowBackup, adicione tools:replace="android:allowBackup" ao elemento <application> em android/app/src/main/AndroidManifest.xml:

<application

android:name=".MainApplication"

android:label="@string/app_name"

android:icon="@mipmap/ic_launcher"

android:allowBackup="true"

tools:replace="android:allowBackup"

android:theme="@style/AppTheme">

<!-- ... -->

</application>
  • Erro 'More than one file was found with OS independent path': Adicione ao android/app/build.gradle:
android {

packagingOptions {

exclude 'META-INF/api_release.kotlin_module'

exclude 'META-INF/client_release.kotlin_module'

  }
}

📖 Uso

A biblioteca fornece diversas funções para facilitar a integração com os terminais POS da Stone.

Funções Principais

  • initSDK: Inicializa o SDK da Stone.

  • activateCode: Ativa um Stone Code no dispositivo.

  • deactivateCode: Desativa um Stone Code do dispositivo.

  • getActivatedCodes: Retorna uma lista de Stone Codes ativados.

  • getAllTransactionsOrderByIdDesc: Obtém todas as transações ordenadas por ID de forma decrescente.

  • getLastTransaction: Retorna a última transação realizada.

  • findTransactionWithAuthorizationCode: Busca uma transação pelo código de autorização.

  • findTransactionWithInitiatorTransactionKey: Busca uma transação pela chave de transação iniciadora (ATK).

  • findTransactionWithId: Busca uma transação pelo ID.

  • reversePendingTransactions: Reverte transações pendentes.

  • voidTransaction: Cancela uma transação pelo ATK.

  • captureTransaction: Captura uma transação realizada com capture = false.

  • makeTransaction: Realiza uma transação financeira.

  • cancelRunningTaskMakeTransaction: Cancela uma transação em andamento.

  • sendTransactionReceiptMail: Envia o comprovante de transação por e-mail.

  • fetchTransactionsForCard: Retorna transações registradas para um cartão escaneado.

  • displayMessageInPinPad: Exibe uma mensagem no PinPad.

  • connectToPinPad: Conecta-se a um PinPad Bluetooth.

  • printReceiptInPOSPrinter: Imprime recibo na impressora POS.

  • printHTMLInPOSPrinter: Imprime conteúdo HTML na impressora POS.

  • mifareDetectCard: Detecta um cartão Mifare.

  • mifareAuthenticateSector: Autentica um setor Mifare.

  • mifareReadBlock: Lê um bloco de um setor Mifare.

  • mifareWriteBlock: Escreve em um bloco de um setor Mifare.

Exemplos de Uso

Inicializar o SDK da Stone

import { initSDK } from 'rn-stone-lib';

async function initializeSDK() {

  try {
    const result = await initSDK('NomeDoSeuApp', 'PIX_KEY', 'PIX_SECRET');

    if (result) {
    console.log('SDK inicializado com sucesso!');
    } else {
    console.log('Falha ao inicializar o SDK.');
    }
  } catch (error) {
    console.error('Erro:', error);
  }

}

Ativar um Stone Code

import { activateCode } from  'rn-stone-lib';

async  function  activateStoneCode() {

try {
  const  success = await  activateCode('SEU_STONE_CODE');

  if (success) {
    console.log('Stone Code ativado com sucesso!');
  } else {
    console.log('Falha ao ativar o Stone Code.');
  }
  } catch (error) {
    console.error('Erro:', error);
  }

}

Desativar um Stone Code

import { deactivateCode } from 'rn-stone-lib';

async function deactivateStoneCode() {

  try {
    const success = await deactivateCode('SEU_STONE_CODE');

    if (success) {
      console.log('Stone Code desativado com sucesso!');
    } else {
      console.log('Falha ao desativar o Stone Code.');
    }
  } catch (error) {
    console.error('Erro:', error);
  }

}

Obter Stone Codes Ativados

import { getActivatedCodes } from 'rn-stone-lib';

async function fetchActivatedCodes() {

  try {
    const codes = await getActivatedCodes();

    console.log('Stone Codes ativados:', codes);
  } catch (error) {
    console.error('Erro ao obter Stone Codes ativados:', error);
  }

}

Obter Todas as Transações Ordenadas por ID Decrescente

import { getAllTransactionsOrderByIdDesc } from 'rn-stone-lib';

async function fetchAllTransactions() {
  try {
    const transactions = await getAllTransactionsOrderByIdDesc();
    console.log('Transações:', transactions);
  } catch (error) {
    console.error('Erro ao obter transações:', error);
  }
}

Obter a Última Transação Realizada

import { getLastTransaction } from 'rn-stone-lib';

async function fetchLastTransaction() {

  try {
    const transaction = await getLastTransaction();

    if (transaction) {
      console.log('Última transação:', transaction);
    } else {
      console.log('Nenhuma transação encontrada.');
    }
  } catch (error) {
    console.error('Erro ao obter a última transação:', error);
  }

}

Buscar Transação pelo Código de Autorização

import { findTransactionWithAuthorizationCode } from 'rn-stone-lib';

async function findTransactionByAuthorizationCode(authCode) {

  try {
    const transaction = await findTransactionWithAuthorizationCode(authCode);

    if (transaction) {
      console.log('Transação encontrada:', transaction);
    } else {
      console.log('Transação não encontrada.');
    }
  } catch (error) {
    console.error('Erro ao buscar transação:', error);
  }

}

Buscar Transação pela Chave de Transação Iniciadora (ATK)

import { findTransactionWithInitiatorTransactionKey } from 'rn-stone-lib';

async function findTransactionByATK(atk) {

  try {
    const transaction = await findTransactionWithInitiatorTransactionKey(atk);

    if (transaction) {
      console.log('Transação encontrada:', transaction);
    } else {
      console.log('Transação não encontrada.');
    }
  } catch (error) {
    console.error('Erro ao buscar transação:', error);
  }

}

Buscar Transação pelo ID

import { findTransactionWithId } from 'rn-stone-lib';

async function findTransactionById(id) {

  try {
    const transaction = await findTransactionWithId(id);

    if (transaction) {
      console.log('Transação encontrada:', transaction);
    } else {
      console.log('Transação não encontrada.');
    }
  } catch (error) {
    console.error('Erro ao buscar transação:', error);
  }

}

Reverter Transações Pendentes

import { reversePendingTransactions } from 'rn-stone-lib';

async function reversePending() {
  try {
    const success = await reversePendingTransactions();

    if (success) {
      console.log('Transações pendentes revertidas com sucesso!');
    } else {
      console.log('Nenhuma transação pendente para reverter.');
    }
  } catch (error) {
    console.error('Erro ao reverter transações pendentes:', error);
  }
}

Cancelar uma Transação

import { voidTransaction } from 'rn-stone-lib';

async function cancelTransaction(atk) {

  try {
    const transaction = await voidTransaction(atk);

    console.log('Transação cancelada:', transaction);
  } catch (error) {
    console.error('Erro ao cancelar transação:', error);
  }

}

Capturar uma Transação

import { captureTransaction } from 'rn-stone-lib';

async function captureTransactionByATK(atk) {

  try {
    const transaction = await captureTransaction(atk);

    console.log('Transação capturada:', transaction);
  } catch (error) {
    console.error('Erro ao capturar transação:', error);
  }

}

Realizar uma Transação

import { makeTransaction } from  'rn-stone-lib';

async function processTransaction() {

  try {
    const  transaction = await  makeTransaction({
    amount:  5000, // Valor em centavos (R$50,00)
    installmentCount:  1,
    installmentHasInterest:  false,
    capture:  true,
    });

    console.log('Transação realizada:', transaction);
  } catch (error) {
    console.error('Erro na transação:', error);
  }

}

Cancelar uma Transação em Andamento

import { cancelRunningTaskMakeTransaction } from 'rn-stone-lib';

async function cancelCurrentTransaction() {
  try {
    const success = await cancelRunningTaskMakeTransaction();
    if (success) {
      console.log('Transação em andamento cancelada com sucesso!');
    } else {
      console.log('Nenhuma transação em andamento para cancelar.');
    }
  } catch (error) {
    console.error('Erro ao cancelar transação:', error);
  }

}

Enviar Comprovante de Transação por E-mail

import { sendTransactionReceiptMail } from 'rn-stone-lib';

async function sendReceiptByEmail(atk) {
  try {
    const success = await sendTransactionReceiptMail(
      atk,
      'CLIENT', // ou 'MERCHANT'
      [{ email: '[email protected]', name: 'Cliente' }],
      { email: '[email protected]', name: 'Sua Loja' }
    );
    if (success) {
      console.log('Comprovante enviado por e-mail com sucesso!');
    } else {
      console.log('Falha ao enviar o comprovante.');
    }
  } catch (error) {
    console.error('Erro ao enviar comprovante:', error);
  }

}

Retornar Transações Registradas para um Cartão Escaneado

import { fetchTransactionsForCard } from 'rn-stone-lib';

async function getTransactionsForCard() {

  try {
    const transactions = await fetchTransactionsForCard();

    console.log('Transações do cartão:', transactions);
  } catch (error) {
    console.error('Erro ao obter transações do cartão:', error);
  }

}

Exibir uma Mensagem no PinPad

import { displayMessageInPinPad } from 'rn-stone-lib';

async function showMessageOnPinPad() {

  try {
    const success = await displayMessageInPinPad('Olá, Cliente!');

    if (success) {
      console.log('Mensagem exibida no PinPad com sucesso!');
    } else {
      console.log('Falha ao exibir mensagem no PinPad.');
    }
  } catch (error) {
    console.error('Erro ao exibir mensagem no PinPad:', error);
  }

}

Conectar a um PinPad Bluetooth


import { connectToPinPad } from  'rn-stone-lib';

async  function  connectPinPad() {

  try {
    const  success = await  connectToPinPad('PinPadName', 'MAC_ADDRESS');

    if (success) {
      console.log('Conectado ao PinPad com sucesso!');
    } else {
      console.log('Falha na conexão com o PinPad.');
    }
  } catch (error) {
    console.error('Erro:', error);
  }

}

Imprimir Recibo na Impressora POS

import { printReceiptInPOSPrinter } from 'rn-stone-lib';

async function printReceipt(atk) {
  try {
    const success = await printReceiptInPOSPrinter('CLIENT', atk, false);

    if (success) {
      console.log('Recibo impresso com sucesso!');
    } else {
      console.log('Falha ao imprimir o recibo.');
    }
  } catch (error) {
    console.error('Erro ao imprimir recibo:', error);
  }

}

Imprimir Conteúdo HTML na Impressora POS

import { printHTMLInPOSPrinter } from 'rn-stone-lib';

async function printCustomHTML() {

  try {
    const htmlContent = `
      <html>
        <body>
          <h1>Recibo Personalizado</h1>
          <p>Obrigado por sua compra!</p>
        </body>
      </html>
    `;

    const success = await printHTMLInPOSPrinter(htmlContent);

    if (success) {
      console.log('Conteúdo HTML impresso com sucesso!');
    } else {
      console.log('Falha ao imprimir conteúdo HTML.');
    }
  } catch (error) {
    console.error('Erro ao imprimir conteúdo HTML:', error);
  }

}

Detectar um Cartão Mifare

import { mifareDetectCard } from 'rn-stone-lib';

async function detectMifareCard() {

  try {
    const cardUuid = await mifareDetectCard();

    console.log('Cartão Mifare detectado:', cardUuid);
  } catch (error) {
    console.error('Erro ao detectar cartão Mifare:', error);
  }

}

Autenticar um Setor Mifare

import { mifareAuthenticateSector, MifareKeyType } from 'rn-stone-lib';

async function authenticateMifareSector() {
  try {
    const success = await mifareAuthenticateSector(
      MifareKeyType.TypeA,
      1, // Setor
      'FFFFFFFFFFFF' // Chave padrão
    );

    if (success) {
      console.log('Setor autenticado com sucesso!');
    } else {
      console.log('Falha na autenticação do setor.');
    }
  } catch (error) {
    console.error('Erro ao autenticar setor Mifare:', error);
  }

}

Ler um Bloco de um Setor Mifare

import { mifareReadBlock, MifareKeyType } from 'rn-stone-lib';

async function readMifareBlock() {

  try {
    const data = await mifareReadBlock(
      MifareKeyType.TypeA,
      1, // Setor
      0, // Bloco
      'FFFFFFFFFFFF' // Chave padrão
    );

    console.log('Dados do bloco:', data);
  } catch (error) {
    console.error('Erro ao ler bloco Mifare:', error);
  }

}

Escrever em um Bloco de um Setor Mifare

import { mifareWriteBlock, MifareKeyType } from 'rn-stone-lib';

async function writeMifareBlock() {

  try {
    const dataToWrite = '0123456789ABCDEF'; // Deve ter 16 bytes
    const success = await mifareWriteBlock(
      MifareKeyType.TypeA,
      1, // Setor
      0, // Bloco
      dataToWrite,
      'FFFFFFFFFFFF' // Chave padrão
    );

    if (success) {
      console.log('Dados escritos com sucesso no bloco!');
    } else {
      console.log('Falha ao escrever no bloco.');
    }
  } catch (error) {
    console.error('Erro ao escrever no bloco Mifare:', error);
  }

}

Utilizando Eventos Nativos

Você pode utilizar o hook useNativeEventListener para escutar eventos nativos:

import { useNativeEventListener } from  'rn-stone-lib';

function  App() {

  useNativeEventListener('MAKE_TRANSACTION_PROGRESS', (data) => {

  console.log('Progresso:', data);

  });

  // ...

}

📝 Contribuindo

Consulte o guia de contribuição para saber como contribuir e entender o fluxo de desenvolvimento.

📄 Licença

MIT


Feito com ❤️ por [seu nome ou equipe].