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

ng-wallet

v1.1.27

Published

Digital Wallet Integrations for Angular. Availability of making payments using Google Pay and Apple Pay.

Downloads

38

Readme

Wallet for Angular

Digital Wallet Integrations for Angular. Availability of making payments using Google Pay and Apple Pay.

Requirements for Google Pay

It is necessary to have Google Pay Button installed. Run npm install @google-pay/button-angular

Requirments for Apple Pay

The requirements for using Apple Pay on your website are:

  • iOS devices running iOS 11 or later.
  • Safari 11 on macOS 10.13 or later.
  • Your website must comply with the Apple Pay guidelines. For more information, see Apple Pay on the Web: Acceptable Use Guidelines.
  • You must have an Apple Developer Account and complete the registration. For more information, see Configuring Your Environment.
  • All pages that include Apple Pay must be served over HTTPS. For more information, see Setting Up Your Server. This is a requirement both in development and in production. One way to get up and running is to use a service like ngrok.

Installation

To install and run this proyect just type and execute.

npm install ng-wallet

Implementation and Use

Once the component has been installed we must add it to our project. To do this in the required module we add the following line

import { NgWalletModule } from 'ng-wallet';

Don't forget to add it to the module imports

imports: [
  ...
  NgWalletModule
]

Once it is included, you have to use it and configure it to your liking. For them in the HTML we use the selector <ng-wallet></ng-wallet>

Example usage

.ts File

paymentRequest: PaymentRequestNGWallet = {
    versionAPIApple: 2,
    typePaymentMethod: 'CARD',
    allowedAuthMethods: [
      'PAN_ONLY', 'CRYPTOGRAM_3DS'
    ],
    allowedCardNetworks: [
      'VISA', 'MASTERCARD'
    ],
    typeTokenization: 'PAYMENT_GATEWAY',
    gateway: 'example',
    gatewayMerchantId: 'exampleGatewayMerchantId',
    merchantId: '12345678901234567890',
    merchantName: 'Demo Merchant',
    appleMerchant: '/authorizeMerchant',
    merchantCapabilities: ['SUPPORTS_3DS'],
    info: {
      totalPriceStatus: 'FINAL',
      totalPriceLabel: 'Total',
      totalPrice: '20.00',
      currencyCode: 'USD',
      countryCode: 'US',
      subTotalPrice: '5.00',
      items: [
        {
          label: 'Beer',
          price: '1.99',
          quantity: 1
        },
        {
          label: 'Cheeseburger',
          price: '3.99',
          quantity: 1
        }
      ],
      taxes: [
        {
          label: 'Taxes',
          amount: '6.00'
        }
      ],
      discount: {
        label: 'Discount',
        amount: '3.44'
      }
    }
}

.html File

<ng-wallet
  [paymentRequest]="paymentRequest"
>
</ng-wallet>

Properties

  • paymentRequest: A request for payment, which includes information about payment processing capabilities, the payment amount, and shipping information. For more information, see ApplePayPaymentRequest and PaymentData.
  • versionAPIApple: An integer specifying the Apple Pay version number. For the best compatibility with operating systems and browsers, use the lowest possible version number that supports the features required. For more information, see supportsVersion.
  • typePaymentMethod: A short identifier for the supported payment method. Only CARD and PAYPAL currently are supported entries.
  • allowedAuthMethods: Fields supported to authenticate a card transaction. Only PAN_ONLY and CRYPTOGRAM_3DS currently are supported entries. For more information, see Card Parameters.
  • allowedCardNetworks: The payment networks supported by the merchant. For more information, see supportedNetworks and Card Parameters.
  • typeTokenization: A payment method tokenization type is supported for the given PaymentMethod. For CARD payment method, use PAYMENT_GATEWAY or DIRECT. For PAYPAL PaymentMethod, use DIRECT with no parameter. For more information, see TokenizationSpecification.
  • gateway and gatewayMerchantId: Define the parameters properties as described by your gateway. Typical properties include the gateway's identifier, which is issued by Google, and your gateway account ID, which is provided by the gateway.
  • appleMerchant: Define your own server to request a new merchant session. For more information, see validationURL.
  • merchantCapabilities: The payment capabilities supported by the merchant on Apple Pay. The supported values for merchantCapabilities are: SUPPORTS_3DS, This value must be required, SUPPORTS_CREDIT, SUPPORTS_DEBIT, SUPPORTS_EMV. For more information, see merchantCapabilities.
  • info: This object describes a transaction that determines a payer's ability to pay. It's used to present a payment authorization dialog. For more information, see TransactionInfo.
  • totalPriceStatus: The status of the total price used. Only NOT_CURRENTLY_KNOWN, ESTIMATED and FINAL currently are supported entries.
  • totalPriceLabel: Custom label for the total price within the display items.
  • totalPrice: Total monetary value of the transaction with an optional decimal precision of two decimal places. Use this field as a string value.
  • currencyCode: The ISO 4217 alphabetic currency code.
  • countryCode: The ISO 3166-1 alpha-2 country code where the transaction is processed. This property is required for merchants who process transactions in European Economic Area (EEA) countries and any other countries that are subject to Strong Customer Authentication (SCA). Merchants must specify the acquirer bank country code.
  • subTotalPrice: Monetary value of the items with an optional decimal precision of two decimal places. Use this field as a string value. This object is optional.
  • items: All of the available charges for the current payment request.
  • taxes: All applicable government-imposed taxes, including but not limited to indirect taxes such as goods and services tax (“GST”), fees, duties or such other similar taxes. This object is optional.
  • discount: Discount made in the consumption of the service. This object is optional.

Google Pay Button Properties

  • buttonColorGoogle: Specifies the color of the button. It is optional and the values can be "default" | "black" | "white".
  • buttonTypeGoogle: Button type to use. It is optional and the values can be "buy" | "plain" | "donate" | "long" | "short".
  • buttonLocaleGoogle: This ISO 639-1 code represents the desired button language. It is optional and the value is a string.
  • buttonSizeMode: Buttons will be sized according to the translated buttonType. It is optional and the values can be "static" | "fill".
  • environment: The Google Pay environment to target. It is required and the values can be "TEST" | "PRODUCTION".
  • existingPaymentMethodRequired: When set to true (and environment is Production), the Google Pay button will only be displayed if the user already has an existing payment that they can use to make a purchase. It is optional and the type is boolean.

Google Pay Button Callbacks/events

  • cancelCallback: Invoked when a user cancels or closes the Google Pay payment sheet. Also raised as event "cancel". Invoked an error is encountered in the process of presenting and collecting payment options from the Google Pay payment sheet. errorCallback: Also raised as event "error".
  • paymentAuthorizedCallback: Invoked when a user chooses a payment method. This callback should be used to validate whether or not the payment method can be used to complete a payment. This would be typically used to perform pre-authorization to ensure that the card is valid and has sufficient funds. Note that in order to use this callback paymentRequest.callbackIntents must include PAYMENT_AUTHORIZATION.
  • paymentDataChangedCallback: Invoked when payment the user changes payment data options including payment method, shipping details, and contact details. This callback can be used to dynamically update transactionInfo when payment details, shipping address, or shipping options change. Note that in order to use this callback paymentRequest.callbackIntents must include either SHIPPING_ADDRESS or SHIPPING_OPTION.
  • readyToPayChangeCallback: Invoked when the user's isReadyToPay state changes. This callback can be used to change the application's behaviour based on whether or not the user is ready to pay. Also raised as event "readytopaychange".
  • loadPaymentDataCallback: Invoked when a user has successfully nominated payment details. This callback receives the PaymentData response which includes the PaymentMethodData that can be sent to supported payment processors. Also raised as event "loadpaymentdata".

Apple Pay Button Properties

  • buttonColorApple: A type that indicates the available appearances for an Apple Pay Button. For more information, see ApplePayButtonStyle.
  • buttonTypeApple: A type that indicates the button types that you can display to initiate Apple Pay transactions. For more information, see ApplePayButton Type.
  • buttonLocaleApple: A type that indicates the languages and regions that you can specify for the Apple Pay button. For more information, see ApplePayButtonLocale.
  • width and height: The size of the buttons will be adjusted to the dimensions defined in the width and height.
  • borderRadius: A type to apply rounded corners to the buttons.

Global Configuration (Default Values)

Initially the buttons will have an initial value in their configuration.

Google Pay Button:

  • buttonColorGoogle="black"
  • buttonTypeGoogle="buy"
  • buttonSizeMode="static"
  • buttonLocaleGoogle="en"
  • environment="TEST"
  • existingPaymentMethodRequired=true

Apple Pay Button:

  • buttonColorApple="black"
  • buttonTypeApple="buy"
  • width="100px"
  • height="30px"
  • borderRadius="0pt"
  • buttonLocaleApple="en"

These initial values save time configuring the buttons, so there would be fewer lines in the code.

Documentation

Button Preview

Button Preview