angular.module("admin.payments").factory 'AdminStripeElements', ($rootScope, StatusMessage) -> new class AdminStripeElements # These are both set from the AdminStripeElements directive stripe: null card: null # Create Token to be used with the Stripe Charges API requestToken: (secrets, submit) -> return unless @stripe? && @card? cardData = @makeCardData(secrets) @stripe.createToken(@card, cardData).then (response) => if(response.error) StatusMessage.display 'error', response.error.message console.error(JSON.stringify(response.error)) else secrets.token = response.token.id secrets.cc_type = @mapTokenApiCardBrand(response.token.card.brand) secrets.card = response.token.card submit() # Create Payment Method to be used with the Stripe Payment Intents API createPaymentMethod: (secrets, submit) -> return unless @stripe? && @card? cardData = @makeCardData(secrets) @stripe.createPaymentMethod({ type: 'card', card: @card }, @card, cardData).then (response) => if(response.error) StatusMessage.display 'error', response.error.message console.error(JSON.stringify(response.error)) else secrets.token = response.paymentMethod.id secrets.cc_type = @mapPaymentMethodsApiCardBrand(response.paymentMethod.card.brand) secrets.card = response.paymentMethod.card submit() # Maps the brand returned by Stripe's tokenAPI to that required by activemerchant mapTokenApiCardBrand: (cardBrand) -> switch cardBrand when 'MasterCard' then return 'master' when 'Visa' then return 'visa' when 'American Express' then return 'american_express' when 'Discover' then return 'discover' when 'JCB' then return 'jcb' when 'Diners Club' then return 'diners_club' # Maps the brand returned by Stripe's paymentMethodsAPI to that required by activemerchant mapPaymentMethodsApiCardBrand: (cardBrand) -> switch cardBrand when 'mastercard' then return 'master' when 'amex' then return 'american_express' when 'diners' then return 'diners_club' else return cardBrand # a few brands are equal, for example, visa # It doesn't matter if any of these are nil, all are optional. makeCardData: (secrets) -> {'name': secrets.name, 'address1': secrets.address1, 'city': secrets.city, 'zipcode': secrets.zipcode}