@justifi/webcomponents 4.2.2 → 4.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/dist/cjs/{Api-11362403.js → Api-7303478d.js} +3 -2
- package/dist/cjs/Api-7303478d.js.map +1 -0
- package/dist/cjs/business-form-schema-63b311b2.js +132 -0
- package/dist/cjs/business-form-schema-63b311b2.js.map +1 -0
- package/dist/cjs/form-control-select_2.cjs.entry.js +61 -0
- package/dist/cjs/form-control-select_2.cjs.entry.js.map +1 -0
- package/dist/cjs/{index-34312a38.js → index-83b2ec02.js} +136 -20
- package/dist/cjs/index-83b2ec02.js.map +1 -0
- package/dist/cjs/{index.esm-bcf90c56.js → index.esm-7e12ce07.js} +301 -14
- package/dist/cjs/index.esm-7e12ce07.js.map +1 -0
- package/dist/cjs/justifi-bank-account-form.cjs.entry.js +8 -3
- package/dist/cjs/justifi-bank-account-form.cjs.entry.js.map +1 -1
- package/dist/cjs/justifi-billing-form_2.cjs.entry.js +5 -5
- package/dist/cjs/justifi-billing-form_2.cjs.entry.js.map +1 -1
- package/dist/cjs/justifi-business-address-form.cjs.entry.js +37 -0
- package/dist/cjs/justifi-business-address-form.cjs.entry.js.map +1 -0
- package/dist/cjs/justifi-business-form.cjs.entry.js +751 -0
- package/dist/cjs/justifi-business-form.cjs.entry.js.map +1 -0
- package/dist/cjs/justifi-business-generic-info_3.cjs.entry.js +148 -0
- package/dist/cjs/justifi-business-generic-info_3.cjs.entry.js.map +1 -0
- package/dist/cjs/justifi-card-form.cjs.entry.js +8 -3
- package/dist/cjs/justifi-card-form.cjs.entry.js.map +1 -1
- package/dist/cjs/justifi-payment-form.cjs.entry.js +24 -7
- package/dist/cjs/justifi-payment-form.cjs.entry.js.map +1 -1
- package/dist/cjs/justifi-payment-method-form.cjs.entry.js +22 -17
- package/dist/cjs/justifi-payment-method-form.cjs.entry.js.map +1 -1
- package/dist/cjs/justifi-payments-list.cjs.entry.js +75 -4038
- package/dist/cjs/justifi-payments-list.cjs.entry.js.map +1 -1
- package/dist/cjs/justifi-payouts-list.cjs.entry.js +113 -0
- package/dist/cjs/justifi-payouts-list.cjs.entry.js.map +1 -0
- package/dist/cjs/loader.cjs.js +3 -12
- package/dist/cjs/loader.cjs.js.map +1 -1
- package/dist/cjs/select-input_2.cjs.entry.js +6 -6
- package/dist/cjs/select-input_2.cjs.entry.js.map +1 -1
- package/dist/cjs/{state-options-efeaa587.js → state-options-83b52cd1.js} +1 -1
- package/dist/{esm/state-options-188acc34.js.map → cjs/state-options-83b52cd1.js.map} +1 -1
- package/dist/cjs/utils-4ee7e080.js +3979 -0
- package/dist/cjs/utils-4ee7e080.js.map +1 -0
- package/dist/cjs/webcomponents.cjs.js +3 -6
- package/dist/cjs/webcomponents.cjs.js.map +1 -1
- package/dist/collection/api/Api.js +3 -2
- package/dist/collection/api/Api.js.map +1 -1
- package/dist/collection/api/Payout.js +33 -0
- package/dist/collection/api/Payout.js.map +1 -0
- package/dist/collection/api/index.js +1 -0
- package/dist/collection/api/index.js.map +1 -1
- package/dist/collection/api/mockData/MockPayments.js +1 -1
- package/dist/collection/collection-manifest.json +18 -12
- package/dist/collection/components/bank-account-form/bank-account-form.js +38 -10
- package/dist/collection/components/bank-account-form/bank-account-form.js.map +1 -1
- package/dist/collection/components/bank-account-form/bank-account-form.stories.js +2 -0
- package/dist/collection/components/bank-account-form/bank-account-form.stories.js.map +1 -1
- package/dist/collection/components/bank-account-form/test/bank-account-form.e2e.js +1 -1
- package/dist/collection/components/bank-account-form/test/bank-account-form.spec.js +3 -3
- package/dist/collection/components/billing-form/billing-form-schema.js +1 -1
- package/dist/collection/components/billing-form/billing-form.css +212 -39
- package/dist/collection/components/billing-form/billing-form.js +16 -10
- package/dist/collection/components/billing-form/billing-form.js.map +1 -1
- package/dist/collection/components/billing-form/test/billing-form.spec.js +51 -24
- package/dist/collection/components/billing-form/test/billing-form.spec.js.map +1 -1
- package/dist/collection/components/{business-address/business-address-schema.js → business-form/business-address/business-address-form-schema.js} +2 -2
- package/dist/collection/components/business-form/business-address/business-address-form-schema.js.map +1 -0
- package/dist/collection/components/business-form/business-address/business-address-form.css +2532 -0
- package/dist/collection/components/business-form/business-address/business-address-form.js +98 -0
- package/dist/collection/components/business-form/business-address/business-address-form.js.map +1 -0
- package/dist/collection/components/business-form/business-address/test/business-address.e2e.js +10 -0
- package/dist/collection/components/business-form/business-address/test/business-address.e2e.js.map +1 -0
- package/dist/collection/components/business-form/business-address/test/business-address.spec.js +72 -0
- package/dist/collection/components/business-form/business-address/test/business-address.spec.js.map +1 -0
- package/dist/collection/components/business-form/business-form-schema.js +149 -0
- package/dist/collection/components/business-form/business-form-schema.js.map +1 -0
- package/dist/collection/components/business-form/business-form.css +2532 -0
- package/dist/collection/components/business-form/business-form.js +76 -0
- package/dist/collection/components/business-form/business-form.js.map +1 -0
- package/dist/collection/components/{business-info/business-info.css → business-form/business-generic-info/business-generic-info.css} +745 -530
- package/dist/collection/components/business-form/business-generic-info/business-generic-info.js +79 -0
- package/dist/collection/components/business-form/business-generic-info/business-generic-info.js.map +1 -0
- package/dist/collection/components/business-form/business-owners/business-owners.css +2489 -0
- package/dist/collection/components/business-form/business-owners/business-owners.js +120 -0
- package/dist/collection/components/business-form/business-owners/business-owners.js.map +1 -0
- package/dist/collection/components/business-form/business-representative/business-representative-schema.js +2 -0
- package/dist/collection/components/business-form/business-representative/business-representative-schema.js.map +1 -0
- package/dist/collection/components/business-form/business-representative/business-representative.css +2489 -0
- package/dist/collection/components/business-form/business-representative/business-representative.js +76 -0
- package/dist/collection/components/business-form/business-representative/business-representative.js.map +1 -0
- package/dist/collection/components/business-form/businessForm.stories.js +115 -0
- package/dist/collection/components/business-form/businessForm.stories.js.map +1 -0
- package/dist/collection/components/card-form/card-form.js +38 -10
- package/dist/collection/components/card-form/card-form.js.map +1 -1
- package/dist/collection/components/card-form/card-form.stories.js +5 -2
- package/dist/collection/components/card-form/card-form.stories.js.map +1 -1
- package/dist/collection/components/card-form/test/card-form.e2e.js +1 -1
- package/dist/collection/components/card-form/test/card-form.spec.js +3 -3
- package/dist/collection/components/{business-address/business-address.css → form/form-control-select.css} +344 -1212
- package/dist/collection/components/form/form-control-select.js +168 -0
- package/dist/collection/components/form/form-control-select.js.map +1 -0
- package/dist/collection/components/form/form-control-text.css +1794 -0
- package/dist/collection/components/form/form-control-text.js +152 -0
- package/dist/collection/components/form/form-control-text.js.map +1 -0
- package/dist/collection/components/form/form.js +85 -0
- package/dist/collection/components/form/form.js.map +1 -0
- package/dist/collection/components/payment-form/payment-form.css +220 -45
- package/dist/collection/components/payment-form/payment-form.js +47 -7
- package/dist/collection/components/payment-form/payment-form.js.map +1 -1
- package/dist/collection/components/payment-form/payment-form.stories.js +3 -2
- package/dist/collection/components/payment-form/payment-form.stories.js.map +1 -1
- package/dist/collection/components/payment-form/payment-method-selector.css +348 -145
- package/dist/collection/components/payment-form/payment-method-selector.js +5 -3
- package/dist/collection/components/payment-form/payment-method-selector.js.map +1 -1
- package/dist/collection/components/payment-form/test/payment-form.e2e.js +1 -1
- package/dist/collection/components/payment-form/test/payment-form.spec.js +4 -3
- package/dist/collection/components/payment-form/test/payment-form.spec.js.map +1 -1
- package/dist/collection/components/payment-method-form/get-computed-theme.js +2 -0
- package/dist/collection/components/payment-method-form/get-computed-theme.js.map +1 -1
- package/dist/collection/components/payment-method-form/payment-method-form.js +19 -11
- package/dist/collection/components/payment-method-form/payment-method-form.js.map +1 -1
- package/dist/collection/components/payment-method-form/test/payment-method-form.e2e.js +1 -1
- package/dist/collection/components/payment-method-form/test/payment-method-form.spec.js +3 -3
- package/dist/collection/components/payment-method-form/theme.js.map +1 -1
- package/dist/collection/components/payments-list/example.js +12 -0
- package/dist/collection/components/payments-list/payments-list.css +7954 -1
- package/dist/collection/components/payments-list/payments-list.js +104 -27
- package/dist/collection/components/payments-list/payments-list.js.map +1 -1
- package/dist/collection/components/payments-list/payments-list.stories.js +78 -0
- package/dist/collection/components/payments-list/payments-list.stories.js.map +1 -0
- package/dist/collection/components/payments-list/test/payments-list.spec.js +82 -18
- package/dist/collection/components/payments-list/test/payments-list.spec.js.map +1 -1
- package/dist/collection/components/payouts-list/payouts-list.css +7983 -0
- package/dist/collection/components/payouts-list/payouts-list.js +181 -0
- package/dist/collection/components/payouts-list/payouts-list.js.map +1 -0
- package/dist/collection/components/payouts-list/payouts-list.stories.js +69 -0
- package/dist/collection/components/payouts-list/payouts-list.stories.js.map +1 -0
- package/dist/collection/components/select-input/select-input.css +344 -141
- package/dist/collection/components/select-input/select-input.js +5 -4
- package/dist/collection/components/select-input/select-input.js.map +1 -1
- package/dist/collection/components/select-input/test/select-input.spec.js +72 -28
- package/dist/collection/components/select-input/test/select-input.spec.js.map +1 -1
- package/dist/collection/components/text-input/test/text-input.spec.js +47 -5
- package/dist/collection/components/text-input/test/text-input.spec.js.map +1 -1
- package/dist/collection/components/text-input/text-input.css +344 -141
- package/dist/collection/components/text-input/text-input.js +2 -2
- package/dist/collection/components/text-input/text-input.js.map +1 -1
- package/dist/collection/utils/utils.js +7 -2
- package/dist/collection/utils/utils.js.map +1 -1
- package/dist/components/Api.js +2 -1
- package/dist/components/Api.js.map +1 -1
- package/dist/components/billing-form.js +2 -2
- package/dist/components/billing-form.js.map +1 -1
- package/dist/components/business-address-form.js +65 -0
- package/dist/components/business-address-form.js.map +1 -0
- package/dist/components/business-generic-info.js +190 -0
- package/dist/components/business-generic-info.js.map +1 -0
- package/dist/components/business-owners.js +102 -0
- package/dist/components/business-owners.js.map +1 -0
- package/dist/components/business-representative.js +75 -0
- package/dist/components/business-representative.js.map +1 -0
- package/dist/components/{justifi-business-info.d.ts → form-control-select.d.ts} +4 -4
- package/dist/components/form-control-select.js +8 -0
- package/dist/components/form-control-select.js.map +1 -0
- package/dist/components/form-control-select2.js +53 -0
- package/dist/components/form-control-select2.js.map +1 -0
- package/dist/components/form-control-text.d.ts +11 -0
- package/dist/components/form-control-text.js +8 -0
- package/dist/components/form-control-text.js.map +1 -0
- package/dist/components/form-control-text2.js +51 -0
- package/dist/components/form-control-text2.js.map +1 -0
- package/dist/components/index.esm.js +298 -14
- package/dist/components/index.esm.js.map +1 -1
- package/dist/components/justifi-bank-account-form.js +7 -2
- package/dist/components/justifi-bank-account-form.js.map +1 -1
- package/dist/components/justifi-business-address-form.d.ts +11 -0
- package/dist/components/justifi-business-address-form.js +8 -0
- package/dist/components/justifi-business-address-form.js.map +1 -0
- package/dist/components/justifi-business-form.d.ts +11 -0
- package/dist/components/justifi-business-form.js +802 -0
- package/dist/components/justifi-business-form.js.map +1 -0
- package/dist/components/justifi-business-generic-info.d.ts +11 -0
- package/dist/components/justifi-business-generic-info.js +8 -0
- package/dist/components/justifi-business-generic-info.js.map +1 -0
- package/dist/components/justifi-business-owners.d.ts +11 -0
- package/dist/components/justifi-business-owners.js +8 -0
- package/dist/components/justifi-business-owners.js.map +1 -0
- package/dist/components/justifi-business-representative.d.ts +11 -0
- package/dist/components/justifi-business-representative.js +8 -0
- package/dist/components/justifi-business-representative.js.map +1 -0
- package/dist/components/justifi-card-form.js +7 -2
- package/dist/components/justifi-card-form.js.map +1 -1
- package/dist/components/justifi-payment-form.js +23 -4
- package/dist/components/justifi-payment-form.js.map +1 -1
- package/dist/components/justifi-payments-list.js +78 -4038
- package/dist/components/justifi-payments-list.js.map +1 -1
- package/dist/components/justifi-payouts-list.d.ts +11 -0
- package/dist/components/justifi-payouts-list.js +134 -0
- package/dist/components/justifi-payouts-list.js.map +1 -0
- package/dist/components/payment-method-form.js +21 -16
- package/dist/components/payment-method-form.js.map +1 -1
- package/dist/components/payment-method-selector.js +1 -1
- package/dist/components/payment-method-selector.js.map +1 -1
- package/dist/components/select-input2.js +3 -3
- package/dist/components/select-input2.js.map +1 -1
- package/dist/components/state-options.js.map +1 -1
- package/dist/components/text-input2.js +2 -2
- package/dist/components/text-input2.js.map +1 -1
- package/dist/components/utils.js +3972 -0
- package/dist/components/utils.js.map +1 -0
- package/dist/esm/{Api-a07f0057.js → Api-436dfa09.js} +3 -2
- package/dist/esm/Api-436dfa09.js.map +1 -0
- package/dist/esm/business-form-schema-30c48693.js +128 -0
- package/dist/esm/business-form-schema-30c48693.js.map +1 -0
- package/dist/esm/form-control-select_2.entry.js +56 -0
- package/dist/esm/form-control-select_2.entry.js.map +1 -0
- package/dist/esm/{index-044f93fc.js → index-c8f391de.js} +136 -20
- package/dist/esm/index-c8f391de.js.map +1 -0
- package/dist/esm/{index.esm-5624a5ed.js → index.esm-be2cd327.js} +299 -15
- package/dist/esm/index.esm-be2cd327.js.map +1 -0
- package/dist/esm/justifi-bank-account-form.entry.js +8 -3
- package/dist/esm/justifi-bank-account-form.entry.js.map +1 -1
- package/dist/esm/justifi-billing-form_2.entry.js +5 -5
- package/dist/esm/justifi-billing-form_2.entry.js.map +1 -1
- package/dist/esm/justifi-business-address-form.entry.js +33 -0
- package/dist/esm/justifi-business-address-form.entry.js.map +1 -0
- package/dist/esm/justifi-business-form.entry.js +747 -0
- package/dist/esm/justifi-business-form.entry.js.map +1 -0
- package/dist/esm/justifi-business-generic-info_3.entry.js +142 -0
- package/dist/esm/justifi-business-generic-info_3.entry.js.map +1 -0
- package/dist/esm/justifi-card-form.entry.js +8 -3
- package/dist/esm/justifi-card-form.entry.js.map +1 -1
- package/dist/esm/justifi-payment-form.entry.js +21 -4
- package/dist/esm/justifi-payment-form.entry.js.map +1 -1
- package/dist/esm/justifi-payment-method-form.entry.js +22 -17
- package/dist/esm/justifi-payment-method-form.entry.js.map +1 -1
- package/dist/esm/justifi-payments-list.entry.js +75 -4038
- package/dist/esm/justifi-payments-list.entry.js.map +1 -1
- package/dist/esm/justifi-payouts-list.entry.js +109 -0
- package/dist/esm/justifi-payouts-list.entry.js.map +1 -0
- package/dist/esm/loader.js +4 -13
- package/dist/esm/loader.js.map +1 -1
- package/dist/esm/select-input_2.entry.js +6 -6
- package/dist/esm/select-input_2.entry.js.map +1 -1
- package/dist/esm/{state-options-188acc34.js → state-options-ece00aa2.js} +1 -1
- package/dist/esm/state-options-ece00aa2.js.map +1 -0
- package/dist/esm/utils-e7782126.js +3972 -0
- package/dist/esm/utils-e7782126.js.map +1 -0
- package/dist/esm/webcomponents.js +4 -7
- package/dist/esm/webcomponents.js.map +1 -1
- package/dist/types/api/Payout.d.ts +62 -0
- package/dist/types/api/index.d.ts +1 -0
- package/dist/types/components/business-form/business-address/business-address-form.d.ts +9 -0
- package/dist/types/components/{business-info/business-info-schema.d.ts → business-form/business-form-schema.d.ts} +55 -4
- package/dist/types/components/business-form/business-form.d.ts +14 -0
- package/dist/types/components/business-form/business-generic-info/business-generic-info.d.ts +16 -0
- package/dist/types/components/business-form/business-owners/business-owners.d.ts +32 -0
- package/dist/types/components/business-form/business-representative/business-representative-schema.d.ts +15 -0
- package/dist/types/components/business-form/business-representative/business-representative.d.ts +12 -0
- package/dist/types/components/business-form/businessForm.stories.d.ts +21 -0
- package/dist/types/components/form/form-control-select.d.ts +16 -0
- package/dist/types/components/form/form-control-text.d.ts +12 -0
- package/dist/types/components/form/form.d.ts +21 -0
- package/dist/types/components/payment-form/payment-form.d.ts +2 -0
- package/dist/types/components/payment-method-form/theme.d.ts +2 -0
- package/dist/types/components/payments-list/payments-list.d.ts +38 -5
- package/dist/types/components/payments-list/payments-list.stories.d.ts +17 -0
- package/dist/types/components/payouts-list/payouts-list.d.ts +45 -0
- package/dist/types/components/payouts-list/payouts-list.stories.d.ts +16 -0
- package/dist/types/components.d.ts +339 -26
- package/dist/types/stencil-public-runtime.d.ts +14 -2
- package/dist/types/utils/utils.d.ts +1 -0
- package/dist/webcomponents/p-0fd4aae2.js +2 -0
- package/dist/webcomponents/p-0fd4aae2.js.map +1 -0
- package/dist/webcomponents/p-1953797f.entry.js +2 -0
- package/dist/webcomponents/p-1953797f.entry.js.map +1 -0
- package/dist/webcomponents/p-1a1f2196.js +2 -0
- package/dist/webcomponents/p-1a1f2196.js.map +1 -0
- package/dist/webcomponents/p-23e9c7d4.entry.js +2 -0
- package/dist/webcomponents/p-23e9c7d4.entry.js.map +1 -0
- package/dist/webcomponents/p-309a886f.entry.js +2 -0
- package/dist/webcomponents/p-309a886f.entry.js.map +1 -0
- package/dist/webcomponents/p-33d69eb5.entry.js +2 -0
- package/dist/webcomponents/p-33d69eb5.entry.js.map +1 -0
- package/dist/webcomponents/p-3a80a2ec.entry.js +2 -0
- package/dist/webcomponents/p-3a80a2ec.entry.js.map +1 -0
- package/dist/webcomponents/p-45fea6a8.entry.js +2 -0
- package/dist/webcomponents/p-45fea6a8.entry.js.map +1 -0
- package/dist/webcomponents/{p-0ea23153.js → p-47bc59b5.js} +1 -1
- package/dist/webcomponents/p-47bc59b5.js.map +1 -0
- package/dist/webcomponents/p-7041a637.entry.js +2 -0
- package/dist/webcomponents/p-7041a637.entry.js.map +1 -0
- package/dist/webcomponents/p-79456add.js +2 -0
- package/dist/webcomponents/p-79456add.js.map +1 -0
- package/dist/webcomponents/{p-1f151d49.js → p-af080b21.js} +2 -2
- package/dist/webcomponents/p-af080b21.js.map +1 -0
- package/dist/webcomponents/p-bc969904.js +3 -0
- package/dist/webcomponents/p-bc969904.js.map +1 -0
- package/dist/webcomponents/p-cd097ce9.entry.js +2 -0
- package/dist/webcomponents/p-cd097ce9.entry.js.map +1 -0
- package/dist/webcomponents/p-d5bc9f22.entry.js +2 -0
- package/dist/webcomponents/p-d5bc9f22.entry.js.map +1 -0
- package/dist/webcomponents/p-d5cadc78.entry.js +2 -0
- package/dist/webcomponents/p-d5cadc78.entry.js.map +1 -0
- package/dist/webcomponents/p-dd1ebc0b.entry.js +2 -0
- package/dist/webcomponents/p-dd1ebc0b.entry.js.map +1 -0
- package/dist/webcomponents/p-e05e0c6b.entry.js +2 -0
- package/dist/webcomponents/p-e05e0c6b.entry.js.map +1 -0
- package/dist/webcomponents/webcomponents.css +1 -1
- package/dist/webcomponents/webcomponents.esm.js +1 -1
- package/dist/webcomponents/webcomponents.esm.js.map +1 -1
- package/loader/index.d.ts +1 -1
- package/package.json +12 -14
- package/CHANGELOG.md +0 -208
- package/changelog-template.hbs +0 -10
- package/dist/cjs/Api-11362403.js.map +0 -1
- package/dist/cjs/Payment-ac4dea02.js +0 -73
- package/dist/cjs/Payment-ac4dea02.js.map +0 -1
- package/dist/cjs/index-34312a38.js.map +0 -1
- package/dist/cjs/index.esm-bcf90c56.js.map +0 -1
- package/dist/cjs/justifi-business-address.cjs.entry.js +0 -69
- package/dist/cjs/justifi-business-address.cjs.entry.js.map +0 -1
- package/dist/cjs/justifi-business-info.cjs.entry.js +0 -174
- package/dist/cjs/justifi-business-info.cjs.entry.js.map +0 -1
- package/dist/cjs/state-options-efeaa587.js.map +0 -1
- package/dist/collection/components/business-address/business-address-schema.js.map +0 -1
- package/dist/collection/components/business-address/business-address.js +0 -100
- package/dist/collection/components/business-address/business-address.js.map +0 -1
- package/dist/collection/components/business-address/test/business-address.e2e.js +0 -10
- package/dist/collection/components/business-address/test/business-address.e2e.js.map +0 -1
- package/dist/collection/components/business-address/test/business-address.spec.js +0 -18
- package/dist/collection/components/business-address/test/business-address.spec.js.map +0 -1
- package/dist/collection/components/business-info/business-info-schema.js +0 -94
- package/dist/collection/components/business-info/business-info-schema.js.map +0 -1
- package/dist/collection/components/business-info/business-info.js +0 -168
- package/dist/collection/components/business-info/business-info.js.map +0 -1
- package/dist/components/Payment.js +0 -71
- package/dist/components/Payment.js.map +0 -1
- package/dist/components/justifi-business-address.d.ts +0 -11
- package/dist/components/justifi-business-address.js +0 -99
- package/dist/components/justifi-business-address.js.map +0 -1
- package/dist/components/justifi-business-info.js +0 -207
- package/dist/components/justifi-business-info.js.map +0 -1
- package/dist/esm/Api-a07f0057.js.map +0 -1
- package/dist/esm/Payment-c86e1e84.js +0 -71
- package/dist/esm/Payment-c86e1e84.js.map +0 -1
- package/dist/esm/index-044f93fc.js.map +0 -1
- package/dist/esm/index.esm-5624a5ed.js.map +0 -1
- package/dist/esm/justifi-business-address.entry.js +0 -65
- package/dist/esm/justifi-business-address.entry.js.map +0 -1
- package/dist/esm/justifi-business-info.entry.js +0 -170
- package/dist/esm/justifi-business-info.entry.js.map +0 -1
- package/dist/esm/polyfills/css-shim.js +0 -1
- package/dist/types/components/bank-account-form/bank-account-form.d.ts +0 -56
- package/dist/types/components/business-address/business-address.d.ts +0 -11
- package/dist/types/components/business-info/business-info.d.ts +0 -20
- package/dist/types/components/card-form/card-form.d.ts +0 -62
- package/dist/webcomponents/p-0969db8f.entry.js +0 -2
- package/dist/webcomponents/p-0969db8f.entry.js.map +0 -1
- package/dist/webcomponents/p-0ea23153.js.map +0 -1
- package/dist/webcomponents/p-1ca0646b.js +0 -2
- package/dist/webcomponents/p-1ca0646b.js.map +0 -1
- package/dist/webcomponents/p-1f151d49.js.map +0 -1
- package/dist/webcomponents/p-255b1284.entry.js +0 -2
- package/dist/webcomponents/p-255b1284.entry.js.map +0 -1
- package/dist/webcomponents/p-3aa91155.js +0 -3
- package/dist/webcomponents/p-3aa91155.js.map +0 -1
- package/dist/webcomponents/p-4ecc9860.entry.js +0 -2
- package/dist/webcomponents/p-4ecc9860.entry.js.map +0 -1
- package/dist/webcomponents/p-90c0d9e1.entry.js +0 -2
- package/dist/webcomponents/p-90c0d9e1.entry.js.map +0 -1
- package/dist/webcomponents/p-bd5352d6.entry.js +0 -2
- package/dist/webcomponents/p-bd5352d6.entry.js.map +0 -1
- package/dist/webcomponents/p-c903cc5a.entry.js +0 -2
- package/dist/webcomponents/p-c903cc5a.entry.js.map +0 -1
- package/dist/webcomponents/p-d87b0711.entry.js +0 -2
- package/dist/webcomponents/p-d87b0711.entry.js.map +0 -1
- package/dist/webcomponents/p-dbf7100f.entry.js +0 -2
- package/dist/webcomponents/p-dbf7100f.entry.js.map +0 -1
- package/dist/webcomponents/p-e0054bc3.js +0 -2
- package/dist/webcomponents/p-e0054bc3.js.map +0 -1
- package/dist/webcomponents/p-f30d1567.entry.js +0 -2
- package/dist/webcomponents/p-f30d1567.entry.js.map +0 -1
- /package/dist/types/components/{business-address/business-address-schema.d.ts → business-form/business-address/business-address-form-schema.d.ts} +0 -0
|
@@ -1,36 +1,109 @@
|
|
|
1
|
-
import { Host, h } from
|
|
2
|
-
import { Api, Payment } from
|
|
3
|
-
import { formatCurrency, formatDate, formatTime } from
|
|
1
|
+
import { Host, h } from "@stencil/core";
|
|
2
|
+
import { Api, Payment } from "../../api";
|
|
3
|
+
import { formatCurrency, formatDate, formatTime } from "../../utils/utils";
|
|
4
|
+
const pagingDefaults = {
|
|
5
|
+
amount: 25,
|
|
6
|
+
start_cursor: '',
|
|
7
|
+
end_cursor: '',
|
|
8
|
+
has_previous: false,
|
|
9
|
+
has_next: false,
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* @exportedPart table-head: Table head
|
|
13
|
+
* @exportedPart table-head-row: Head row
|
|
14
|
+
* @exportedPart table-head-cell: Individual head cell
|
|
15
|
+
* @exportedPart table-body: Body of the table
|
|
16
|
+
* @exportedPart table-row: Row of the table
|
|
17
|
+
* @exportedPart table-cell: Individual cell of the table
|
|
18
|
+
* @exportedPart loading-state-cell: Row for loading state
|
|
19
|
+
* @exportedPart loading-state-spinner: Spinner element for loading state
|
|
20
|
+
* @exportedPart error-state: Row for Error state
|
|
21
|
+
* @exportedPart empty-state: Row for Emtpy state
|
|
22
|
+
* @exportedPart pagination-bar: Pagination bar
|
|
23
|
+
* @exportedPart arrow: Both paging buttons
|
|
24
|
+
* @exportedPart arrow-left: Previous page button
|
|
25
|
+
* @exportedPart arrow-right: Next page button
|
|
26
|
+
* @exportedPart arrow-disabled: Disabled state for paging buttons
|
|
27
|
+
*/
|
|
4
28
|
export class PaymentsList {
|
|
5
29
|
constructor() {
|
|
30
|
+
// onChangeAmount = (e) => {
|
|
31
|
+
// const newVal = e?.target?.value;
|
|
32
|
+
// if (newVal) {
|
|
33
|
+
// this.paging = pagingDefaults;
|
|
34
|
+
// this.paging.amount = newVal;
|
|
35
|
+
// this.fetchData();
|
|
36
|
+
// }
|
|
37
|
+
// }
|
|
38
|
+
this.onPageChange = (direction) => {
|
|
39
|
+
return () => {
|
|
40
|
+
this.fetchData(direction);
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
this.emptyState = (h("tr", null, h("td", { class: "empty-state", part: "empty-state", colSpan: 7, style: { textAlign: 'center' } }, "No payments to show")));
|
|
44
|
+
this.errorState = () => (h("tr", null, h("td", { class: "error-state", part: "error-state", colSpan: 7, style: { textAlign: 'center' } }, "An unexpected error occurred: ", this.errorMessage)));
|
|
45
|
+
this.loadingState = (h("tr", null, h("td", { class: "loading-state", part: "loading-state-cell", colSpan: 7, style: { textAlign: 'center' } }, h("div", { part: "loading-state-spinner", class: "spinner-border", role: "status" }, h("span", { class: "visually-hidden" }, "Loading...")))));
|
|
46
|
+
this.paginationBar = () => {
|
|
47
|
+
return (h("div", { class: "pagination-bar d-flex justify-content-center gap-3" }, h("button", { onClick: this.onPageChange('prev'), part: `arrow arrow-left${this.paging.has_previous ? '' : ' arrow-disabled'}`, disabled: !this.paging.has_previous, class: `btn btn-primary pagination-btn pagination-prev-btn${this.paging.has_previous ? '' : ' disabled'}` }, "\u2190"), h("button", { onClick: this.onPageChange('next'), part: `arrow arrow-right${this.paging.has_next ? '' : ' arrow-disabled'}`, disabled: !this.paging.has_next, class: `btn btn-primary pagination-btn pagination-next-btn${this.paging.has_next ? '' : ' disabled'}` }, "\u2192")));
|
|
48
|
+
};
|
|
6
49
|
this.accountId = undefined;
|
|
7
|
-
this.
|
|
50
|
+
this.authToken = undefined;
|
|
8
51
|
this.payments = [];
|
|
52
|
+
this.loading = true;
|
|
53
|
+
this.errorMessage = undefined;
|
|
54
|
+
this.paging = pagingDefaults;
|
|
9
55
|
}
|
|
10
|
-
|
|
56
|
+
updateOnPropChange() {
|
|
11
57
|
this.fetchData();
|
|
12
58
|
}
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
59
|
+
connectedCallback() {
|
|
60
|
+
this.fetchData();
|
|
61
|
+
}
|
|
62
|
+
async fetchData(direction) {
|
|
63
|
+
var _a;
|
|
64
|
+
if (!this.accountId || !this.authToken) {
|
|
65
|
+
this.errorMessage = "Can not fetch any data without an AccountID and an AuthToken";
|
|
66
|
+
this.loading = false;
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
this.loading = true;
|
|
70
|
+
const limit = this.paging.amount;
|
|
71
|
+
const cursor = `${direction === 'prev'
|
|
72
|
+
? '&before_cursor=' + this.paging.start_cursor
|
|
73
|
+
: direction === 'next'
|
|
74
|
+
? '&after_cursor=' + this.paging.end_cursor
|
|
75
|
+
: ''}`;
|
|
76
|
+
const endpoint = `account/${this.accountId}/payments?limit=${limit}${cursor ? cursor : ''}`;
|
|
77
|
+
const response = await Api(this.authToken).get(endpoint);
|
|
78
|
+
if (!response.error) {
|
|
79
|
+
this.paging = Object.assign(Object.assign({}, this.paging), response.page_info);
|
|
80
|
+
const data = (_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.map(dataItem => new Payment(dataItem));
|
|
20
81
|
this.payments = data;
|
|
21
|
-
}
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
this.errorMessage = typeof response.error === 'string' ? response.error : response.error.message;
|
|
85
|
+
}
|
|
86
|
+
this.loading = false;
|
|
87
|
+
}
|
|
88
|
+
showEmptyState() {
|
|
89
|
+
return this.payments ? this.payments.length < 1 : true;
|
|
22
90
|
}
|
|
23
91
|
render() {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
92
|
+
var _a;
|
|
93
|
+
return (h(Host, { exportparts: "\n table-head,table-head-row,table-head-cell,table-body,table-row,table-cell,\n loading-state-cell,loading-state-spinner,error-state,empty-state,\n pagination-bar,arrow,arrow-left,arrow-right,arrow-disabled\n " }, h("table", { class: "table table-hover" }, h("thead", { class: "table-head sticky-top", part: "table-head" }, h("tr", { class: "table-light", part: 'table-head-row' }, h("th", { part: "table-head-cell", scope: "col", title: "The date and time each payment was made" }, "Made on"), h("th", { part: "table-head-cell", scope: "col", title: "The dollar amount of each payment" }, "Amount"), h("th", { part: "table-head-cell", scope: "col" }, "Description"), h("th", { part: "table-head-cell", scope: "col" }, "Cardholder"), h("th", { part: "table-head-cell", scope: "col" }, "Payment Method"), h("th", { part: "table-head-cell", scope: "col" }, "Status"), h("th", { part: "table-head-cell", scope: "col" }, "Payment ID"))), h("tbody", { class: "table-body", part: 'table-body' }, this.loading ? this.loadingState :
|
|
94
|
+
this.errorMessage ? this.errorState() :
|
|
95
|
+
this.showEmptyState() ? this.emptyState :
|
|
96
|
+
(_a = this.payments) === null || _a === void 0 ? void 0 : _a.map((payment, index) => {
|
|
97
|
+
var _a, _b, _c, _d;
|
|
98
|
+
return h("tr", { part: `table-row${index % 2 ? ' table-row-even' : ' table-row-odd'}` }, h("th", { scope: "row", part: "table-cell" }, h("div", null, formatDate(payment.created_at)), h("div", null, formatTime(payment.created_at))), h("td", { part: "table-cell" }, formatCurrency(payment.amount)), h("td", { part: "table-cell" }, payment.description), h("td", { part: "table-cell" }, (_b = (_a = payment.payment_method) === null || _a === void 0 ? void 0 : _a.card) === null || _b === void 0 ? void 0 : _b.name), h("td", { part: "table-cell" }, (_d = (_c = payment.payment_method) === null || _c === void 0 ? void 0 : _c.card) === null || _d === void 0 ? void 0 : _d.acct_last_four), h("td", { part: "table-cell" }, payment.status), h("td", { part: "table-cell" }, payment.id));
|
|
99
|
+
})), this.paging &&
|
|
100
|
+
h("tfoot", { class: "sticky-bottom" }, h("tr", { class: "table-light align-middle" }, h("td", { part: "pagination-bar", colSpan: 7 }, this.paginationBar()))))));
|
|
28
101
|
}
|
|
29
102
|
static get is() { return "justifi-payments-list"; }
|
|
30
103
|
static get encapsulation() { return "shadow"; }
|
|
31
104
|
static get originalStyleUrls() {
|
|
32
105
|
return {
|
|
33
|
-
"$": ["payments-list.
|
|
106
|
+
"$": ["payments-list.scss"]
|
|
34
107
|
};
|
|
35
108
|
}
|
|
36
109
|
static get styleUrls() {
|
|
@@ -57,12 +130,12 @@ export class PaymentsList {
|
|
|
57
130
|
"attribute": "account-id",
|
|
58
131
|
"reflect": false
|
|
59
132
|
},
|
|
60
|
-
"
|
|
61
|
-
"type": "
|
|
133
|
+
"authToken": {
|
|
134
|
+
"type": "string",
|
|
62
135
|
"mutable": false,
|
|
63
136
|
"complexType": {
|
|
64
|
-
"original": "
|
|
65
|
-
"resolved": "
|
|
137
|
+
"original": "string",
|
|
138
|
+
"resolved": "string",
|
|
66
139
|
"references": {}
|
|
67
140
|
},
|
|
68
141
|
"required": false,
|
|
@@ -71,22 +144,26 @@ export class PaymentsList {
|
|
|
71
144
|
"tags": [],
|
|
72
145
|
"text": ""
|
|
73
146
|
},
|
|
74
|
-
"
|
|
147
|
+
"attribute": "auth-token",
|
|
148
|
+
"reflect": false
|
|
75
149
|
}
|
|
76
150
|
};
|
|
77
151
|
}
|
|
78
152
|
static get states() {
|
|
79
153
|
return {
|
|
80
|
-
"payments": {}
|
|
154
|
+
"payments": {},
|
|
155
|
+
"loading": {},
|
|
156
|
+
"errorMessage": {},
|
|
157
|
+
"paging": {}
|
|
81
158
|
};
|
|
82
159
|
}
|
|
83
160
|
static get watchers() {
|
|
84
161
|
return [{
|
|
85
162
|
"propName": "accountId",
|
|
86
|
-
"methodName": "
|
|
163
|
+
"methodName": "updateOnPropChange"
|
|
87
164
|
}, {
|
|
88
|
-
"propName": "
|
|
89
|
-
"methodName": "
|
|
165
|
+
"propName": "authToken",
|
|
166
|
+
"methodName": "updateOnPropChange"
|
|
90
167
|
}];
|
|
91
168
|
}
|
|
92
169
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"payments-list.js","sourceRoot":"","sources":["../../../../src/components/payments-list/payments-list.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,GAAG,EAA0B,OAAO,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAO3E,MAAM,OAAO,YAAY;;;gBAEY,EAAE;oBACN,EAAE;;EAIjC,mBAAmB;IACjB,IAAI,CAAC,SAAS,EAAE,CAAC;EACnB,CAAC;EAED,SAAS;IACP,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;IACjC,MAAM,QAAQ,GAAG,WAAW,SAAS,WAAW,CAAC;IACjD,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;OACjB,GAAG,CAAC,QAAQ,CAAC;OACb,IAAI,CAAC,CAAC,QAA2C,EAAE,EAAE;MACpD,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;MAClE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACvB,CAAC,CAAC,CAAC;EACP,CAAC;EAED,MAAM;IACJ,OAAO,CACL,EAAC,IAAI;MACH,aAAO,KAAK,EAAC,eAAe;QAC1B;UACE;YACE,UAAI,KAAK,EAAC,KAAK,EAAC,KAAK,EAAC,yCAAyC,cAE1D;YACL,UAAI,KAAK,EAAC,KAAK,EAAC,KAAK,EAAC,mCAAmC,aAEpD;YACL,UAAI,KAAK,EAAC,KAAK,cAAa;YAC5B,UAAI,KAAK,EAAC,KAAK,kBAAiB;YAChC,UAAI,KAAK,EAAC,KAAK,iBAAgB;YAC/B,UAAI,KAAK,EAAC,KAAK,iBAAgB;YAC/B,UAAI,KAAK,EAAC,KAAK,qBAAoB;YACnC,UAAI,KAAK,EAAC,KAAK,aAAY,CACxB,CACC;QACR,iBACG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;;UAC3B;YACE;cACE,eAAM,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,CAAO;cAC3C,eAAM,UAAU,CAAC,OAAO,CAAC,UAAU,CAAC,CAAO,CACxC;YACL,cAAK,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,CAAM;YACzC,cAAK,OAAO,CAAC,UAAU,CAAM;YAC7B,cAAK,OAAO,CAAC,WAAW,CAAM;YAC9B,cAAK,OAAO,CAAC,EAAE,CAAM;YACrB,cAAK,MAAA,MAAA,OAAO,CAAC,cAAc,0CAAE,IAAI,0CAAE,IAAI,CAAM;YAC7C,cAAK,MAAA,MAAA,OAAO,CAAC,cAAc,0CAAE,IAAI,0CAAE,cAAc,CAAM;YACvD,cAAK,OAAO,CAAC,MAAM,CAAM,CACtB,CAAC;QACR,CAAC,CAAC,CACI,CACF,CACH,CACR,CAAC;EACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Host, h, Prop, State, Watch } from '@stencil/core';\nimport { Api, IApiResponseCollection, Payment } from '../../api';\nimport { formatCurrency, formatDate, formatTime } from '../../utils/utils';\n\n@Component({\n tag: 'justifi-payments-list',\n styleUrl: 'payments-list.css',\n shadow: true,\n})\nexport class PaymentsList {\n @Prop() accountId: string;\n @Prop() auth: { token?: string } = {};\n @State() payments: Payment[] = [];\n\n @Watch('accountId')\n @Watch('auth')\n requestPropsChanged() {\n this.fetchData();\n }\n\n fetchData(): void {\n const accountId = this.accountId;\n const endpoint = `account/${accountId}/payments`;\n Api(this.auth.token)\n .get(endpoint)\n .then((response: IApiResponseCollection<Payment[]>) => {\n const data = response.data.map(dataItem => new Payment(dataItem));\n this.payments = data;\n });\n }\n\n render() {\n return (\n <Host>\n <table class=\"justifi-table\">\n <thead>\n <tr>\n <th scope=\"col\" title=\"The date and time each payment was made\">\n Made on\n </th>\n <th scope=\"col\" title=\"The dollar amount of each payment\">\n Amount\n </th>\n <th scope=\"col\">Account</th>\n <th scope=\"col\">Description</th>\n <th scope=\"col\">Payment ID</th>\n <th scope=\"col\">Cardholder</th>\n <th scope=\"col\">Payment Method</th>\n <th scope=\"col\">Status</th>\n </tr>\n </thead>\n <tbody>\n {this.payments.map(payment => {\n <tr>\n <td>\n <div>{formatDate(payment.created_at)}</div>\n <div>{formatTime(payment.created_at)}</div>\n </td>\n <td>{formatCurrency(payment.amount)}</td>\n <td>{payment.account_id}</td>\n <td>{payment.description}</td>\n <td>{payment.id}</td>\n <td>{payment.payment_method?.card?.name}</td>\n <td>{payment.payment_method?.card?.acct_last_four}</td>\n <td>{payment.status}</td>\n </tr>;\n })}\n </tbody>\n </table>\n </Host>\n );\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"payments-list.js","sourceRoot":"","sources":["../../../../src/components/payments-list/payments-list.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, h, Prop, State, Watch } from '@stencil/core';\nimport { Api, IApiResponseCollection, Payment } from '../../api';\nimport { formatCurrency, formatDate, formatTime } from '../../utils/utils';\n\ninterface PagingInfo {\n amount: number,\n start_cursor: string,\n end_cursor: string,\n has_previous: boolean,\n has_next: boolean,\n}\n\nconst pagingDefaults = {\n amount: 25,\n start_cursor: '',\n end_cursor: '',\n has_previous: false,\n has_next: false,\n}\n\n/**\n * @exportedPart table-head: Table head\n * @exportedPart table-head-row: Head row\n * @exportedPart table-head-cell: Individual head cell\n * @exportedPart table-body: Body of the table\n * @exportedPart table-row: Row of the table\n * @exportedPart table-cell: Individual cell of the table\n * @exportedPart loading-state-cell: Row for loading state\n * @exportedPart loading-state-spinner: Spinner element for loading state\n * @exportedPart error-state: Row for Error state\n * @exportedPart empty-state: Row for Emtpy state\n * @exportedPart pagination-bar: Pagination bar\n * @exportedPart arrow: Both paging buttons\n * @exportedPart arrow-left: Previous page button\n * @exportedPart arrow-right: Next page button\n * @exportedPart arrow-disabled: Disabled state for paging buttons\n*/\n@Component({\n tag: 'justifi-payments-list',\n styleUrl: 'payments-list.scss',\n shadow: true,\n})\n\nexport class PaymentsList {\n @Prop() accountId: string;\n @Prop() authToken: string;\n @State() payments: Payment[] = [];\n @State() loading: boolean = true;\n @State() errorMessage: string;\n @State() paging: PagingInfo = pagingDefaults;\n\n @Watch('accountId')\n @Watch('authToken')\n updateOnPropChange() {\n this.fetchData();\n }\n\n connectedCallback() {\n this.fetchData();\n }\n\n // onChangeAmount = (e) => {\n // const newVal = e?.target?.value;\n // if (newVal) {\n // this.paging = pagingDefaults;\n // this.paging.amount = newVal;\n // this.fetchData();\n // }\n // }\n\n onPageChange = (direction: string) => {\n return () => {\n this.fetchData(direction);\n }\n }\n\n async fetchData(direction?: string): Promise<void> {\n if (!this.accountId || !this.authToken) {\n this.errorMessage = \"Can not fetch any data without an AccountID and an AuthToken\";\n this.loading = false;\n return;\n }\n this.loading = true;\n const limit = this.paging.amount;\n const cursor = `${\n direction === 'prev'\n ? '&before_cursor='+this.paging.start_cursor\n : direction === 'next'\n ? '&after_cursor='+this.paging.end_cursor\n : ''\n }`;\n const endpoint = `account/${this.accountId}/payments?limit=${limit}${cursor ? cursor : ''}`;\n\n const response: IApiResponseCollection<Payment[]> = await Api(this.authToken).get(endpoint);\n if (!response.error) {\n this.paging = {\n ...this.paging,\n ...response.page_info\n }\n\n const data = response?.data?.map(dataItem => new Payment(dataItem));\n this.payments = data;\n } else {\n this.errorMessage = typeof response.error === 'string' ? response.error : response.error.message;\n }\n\n this.loading = false;\n }\n\n showEmptyState() {\n return this.payments ? this.payments.length < 1 : true;\n }\n\n emptyState = (\n <tr>\n <td class=\"empty-state\" part=\"empty-state\" colSpan={7} style={{ textAlign: 'center' }}>No payments to show</td>\n </tr>\n );\n\n errorState = () => (\n <tr>\n <td class=\"error-state\" part=\"error-state\" colSpan={7} style={{ textAlign: 'center' }}>\n An unexpected error occurred: {this.errorMessage}\n </td>\n </tr>\n );\n\n loadingState = (\n <tr>\n <td class=\"loading-state\" part=\"loading-state-cell\" colSpan={7} style={{ textAlign: 'center' }}>\n <div part=\"loading-state-spinner\" class=\"spinner-border\" role=\"status\">\n <span class=\"visually-hidden\">Loading...</span>\n </div>\n </td>\n </tr>\n );\n\n paginationBar = () => {\n return (\n <div class=\"pagination-bar d-flex justify-content-center gap-3\">\n <button\n onClick={this.onPageChange('prev')}\n part={`arrow arrow-left${this.paging.has_previous ? '' : ' arrow-disabled'}`}\n disabled={!this.paging.has_previous}\n class={`btn btn-primary pagination-btn pagination-prev-btn${this.paging.has_previous ? '' : ' disabled'}`}\n >←</button>\n {/* <select class=\"amount-select\" part=\"amount-select\" onChange={this.onChangeAmount}>\n <option selected={this.paging.amount === 10} value={10}>10</option>\n <option selected={this.paging.amount === 25} value={25}>25</option>\n <option selected={this.paging.amount === 50} value={50}>50</option>\n </select> */}\n <button\n onClick={this.onPageChange('next')}\n part={`arrow arrow-right${this.paging.has_next ? '' : ' arrow-disabled'}`}\n disabled={!this.paging.has_next}\n class={`btn btn-primary pagination-btn pagination-next-btn${this.paging.has_next ? '' : ' disabled'}`}\n >→</button>\n </div>\n )\n };\n\n render() {\n return (\n <Host exportparts=\"\n table-head,table-head-row,table-head-cell,table-body,table-row,table-cell,\n loading-state-cell,loading-state-spinner,error-state,empty-state,\n pagination-bar,arrow,arrow-left,arrow-right,arrow-disabled\n \">\n <table class=\"table table-hover\">\n <thead class=\"table-head sticky-top\" part=\"table-head\">\n <tr class=\"table-light\" part='table-head-row'>\n <th part=\"table-head-cell\" scope=\"col\" title=\"The date and time each payment was made\">\n Made on\n </th>\n <th part=\"table-head-cell\" scope=\"col\" title=\"The dollar amount of each payment\">\n Amount\n </th>\n <th part=\"table-head-cell\" scope=\"col\">Description</th>\n <th part=\"table-head-cell\" scope=\"col\">Cardholder</th>\n <th part=\"table-head-cell\" scope=\"col\">Payment Method</th>\n <th part=\"table-head-cell\" scope=\"col\">Status</th>\n <th part=\"table-head-cell\" scope=\"col\">Payment ID</th>\n </tr>\n </thead>\n <tbody class=\"table-body\" part='table-body'>\n {\n this.loading ? this.loadingState :\n this.errorMessage ? this.errorState() :\n this.showEmptyState() ? this.emptyState :\n this.payments?.map((payment, index) =>\n <tr part={`table-row${index%2 ? ' table-row-even' : ' table-row-odd'}`}>\n <th scope=\"row\" part=\"table-cell\">\n <div>{formatDate(payment.created_at)}</div>\n <div>{formatTime(payment.created_at)}</div>\n </th>\n <td part=\"table-cell\">{formatCurrency(payment.amount)}</td>\n <td part=\"table-cell\">{payment.description}</td>\n <td part=\"table-cell\">{payment.payment_method?.card?.name}</td>\n <td part=\"table-cell\">{payment.payment_method?.card?.acct_last_four}</td>\n <td part=\"table-cell\">{payment.status}</td>\n <td part=\"table-cell\">{payment.id}</td>\n </tr>\n )\n }\n </tbody>\n {this.paging &&\n <tfoot class=\"sticky-bottom\">\n <tr class=\"table-light align-middle\">\n <td part=\"pagination-bar\" colSpan={7}>\n {this.paginationBar()}\n </td>\n </tr>\n </tfoot>\n }\n </table>\n </Host>\n );\n }\n}\n"]}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
export default {
|
|
2
|
+
title: 'dev/Components/PaymentsList',
|
|
3
|
+
component: 'justifi-payments-list',
|
|
4
|
+
parameters: {},
|
|
5
|
+
argTypes: {
|
|
6
|
+
'client-id': {
|
|
7
|
+
control: 'text',
|
|
8
|
+
table: {
|
|
9
|
+
category: 'props',
|
|
10
|
+
}
|
|
11
|
+
},
|
|
12
|
+
},
|
|
13
|
+
};
|
|
14
|
+
class PaymentsListArgs {
|
|
15
|
+
constructor(args) {
|
|
16
|
+
this['auth-token'] = args['auth-token'] || '';
|
|
17
|
+
this['account-id'] = args['account-id'] || '';
|
|
18
|
+
this['client-id'] = args['client-id'] || '';
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
const Template = (args) => {
|
|
22
|
+
return (`
|
|
23
|
+
<justifi-payments-list
|
|
24
|
+
data-testid="justifi-payments-list"
|
|
25
|
+
auth-token="${args['auth-token']}"
|
|
26
|
+
account-id="${args['account-id']}"
|
|
27
|
+
client-id="${args['client-id']}"
|
|
28
|
+
/>
|
|
29
|
+
`);
|
|
30
|
+
};
|
|
31
|
+
export const Basic = Template.bind({});
|
|
32
|
+
Basic.args = new PaymentsListArgs({});
|
|
33
|
+
export const Styled = Template.bind({});
|
|
34
|
+
Styled.args = new PaymentsListArgs({});
|
|
35
|
+
Styled.decorators = [
|
|
36
|
+
(Story) => `
|
|
37
|
+
${Story()}
|
|
38
|
+
<style>
|
|
39
|
+
justifi-payments-list::part(table-head-cell) {
|
|
40
|
+
background-color: #F4F4F6;
|
|
41
|
+
}
|
|
42
|
+
justifi-payments-list::part(pagination-bar) {
|
|
43
|
+
background-color: #F4F4F6;
|
|
44
|
+
}
|
|
45
|
+
justifi-payments-list::part(arrow) {
|
|
46
|
+
--bs-btn-disabled-bg: #212529;
|
|
47
|
+
--bs-btn-disabled-border-color: #212529;
|
|
48
|
+
--bs-btn-bg: #212529;
|
|
49
|
+
--bs-btn-border-color: #212529;
|
|
50
|
+
--bs-btn-hover-bg: #fccc32;
|
|
51
|
+
--bs-btn-hover-border-color: #fccc32;
|
|
52
|
+
}
|
|
53
|
+
justifi-payments-list::part(error-state) {
|
|
54
|
+
color: red;
|
|
55
|
+
background-color: #EEEEF5;
|
|
56
|
+
}
|
|
57
|
+
justifi-payments-list::part(loading-state-cell) {
|
|
58
|
+
background-color: #EEEEF5;
|
|
59
|
+
}
|
|
60
|
+
justifi-payments-list::part(table-row) {
|
|
61
|
+
background-color: #EEEEF5;
|
|
62
|
+
}
|
|
63
|
+
justifi-payments-list::part(table-row-even) {
|
|
64
|
+
background-color: #F4F4F6;
|
|
65
|
+
}
|
|
66
|
+
</style>
|
|
67
|
+
`
|
|
68
|
+
];
|
|
69
|
+
export const Contained = Template.bind({});
|
|
70
|
+
Contained.decorators = [
|
|
71
|
+
(Story) => `
|
|
72
|
+
<div style="position: relative; width: 900px; height: 300px; overflow-x: hidden;">
|
|
73
|
+
${Story()}
|
|
74
|
+
</div>
|
|
75
|
+
`
|
|
76
|
+
];
|
|
77
|
+
Contained.args = new PaymentsListArgs({});
|
|
78
|
+
//# sourceMappingURL=payments-list.stories.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"payments-list.stories.js","sourceRoot":"","sources":["../../../../src/components/payments-list/payments-list.stories.ts"],"names":[],"mappings":"AAAA,eAAe;EACb,KAAK,EAAE,6BAA6B;EACpC,SAAS,EAAE,uBAAuB;EAClC,UAAU,EAAE,EAAE;EACd,QAAQ,EAAE;IACR,WAAW,EAAE;MACX,OAAO,EAAE,MAAM;MACf,KAAK,EAAE;QACL,QAAQ,EAAE,OAAO;OAClB;KACF;GACF;CACF,CAAC;AAEF,MAAM,gBAAgB;EAKpB,YAAY,IAAI;IACd,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC9C,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC9C,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;EAC9C,CAAC;CACF;AAED,MAAM,QAAQ,GAAG,CAAC,IAAsB,EAAE,EAAE;EAC1C,OAAO,CAAC;;;oBAGU,IAAI,CAAC,YAAY,CAAC;oBAClB,IAAI,CAAC,YAAY,CAAC;mBACnB,IAAI,CAAC,WAAW,CAAC;;GAEjC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACvC,KAAK,CAAC,IAAI,GAAG,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAC;AAEtC,MAAM,CAAC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACxC,MAAM,CAAC,IAAI,GAAG,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAC;AACvC,MAAM,CAAC,UAAU,GAAG;EAClB,CAAC,KAAK,EAAE,EAAE,CAAC;MACP,KAAK,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BV;CACF,CAAA;AAED,MAAM,CAAC,MAAM,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC3C,SAAS,CAAC,UAAU,GAAG;EACrB,CAAC,KAAK,EAAE,EAAE,CAAC;;QAEL,KAAK,EAAE;;GAEZ;CACF,CAAA;AACD,SAAS,CAAC,IAAI,GAAG,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAC","sourcesContent":["export default {\n title: 'dev/Components/PaymentsList',\n component: 'justifi-payments-list',\n parameters: {},\n argTypes: {\n 'client-id': {\n control: 'text',\n table: {\n category: 'props',\n }\n },\n },\n};\n\nclass PaymentsListArgs {\n 'auth-token': string;\n 'account-id': string;\n 'client-id': string;\n\n constructor(args) {\n this['auth-token'] = args['auth-token'] || '';\n this['account-id'] = args['account-id'] || '';\n this['client-id'] = args['client-id'] || '';\n }\n}\n\nconst Template = (args: PaymentsListArgs) => {\n return (`\n <justifi-payments-list\n data-testid=\"justifi-payments-list\"\n auth-token=\"${args['auth-token']}\"\n account-id=\"${args['account-id']}\"\n client-id=\"${args['client-id']}\"\n />\n `);\n};\n\nexport const Basic = Template.bind({});\nBasic.args = new PaymentsListArgs({});\n\nexport const Styled = Template.bind({});\nStyled.args = new PaymentsListArgs({});\nStyled.decorators = [\n (Story) => `\n ${Story()}\n <style>\n justifi-payments-list::part(table-head-cell) {\n background-color: #F4F4F6;\n }\n justifi-payments-list::part(pagination-bar) {\n background-color: #F4F4F6;\n }\n justifi-payments-list::part(arrow) {\n --bs-btn-disabled-bg: #212529;\n --bs-btn-disabled-border-color: #212529;\n --bs-btn-bg: #212529;\n --bs-btn-border-color: #212529;\n --bs-btn-hover-bg: #fccc32;\n --bs-btn-hover-border-color: #fccc32;\n }\n justifi-payments-list::part(error-state) {\n color: red;\n background-color: #EEEEF5;\n }\n justifi-payments-list::part(loading-state-cell) {\n background-color: #EEEEF5;\n }\n justifi-payments-list::part(table-row) {\n background-color: #EEEEF5;\n }\n justifi-payments-list::part(table-row-even) {\n background-color: #F4F4F6;\n }\n </style>\n `\n]\n\nexport const Contained = Template.bind({});\nContained.decorators = [\n (Story) => `\n <div style=\"position: relative; width: 900px; height: 300px; overflow-x: hidden;\">\n ${Story()}\n </div>\n `\n]\nContained.args = new PaymentsListArgs({});\n"]}
|
|
@@ -1,21 +1,85 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
describe('payments-list', () => {
|
|
4
|
-
it('
|
|
5
|
-
|
|
1
|
+
import { newSpecPage } from "@stencil/core/testing";
|
|
2
|
+
import { PaymentsList } from "../payments-list";
|
|
3
|
+
describe('justifi-payments-list', () => {
|
|
4
|
+
it('renders properly', async () => {
|
|
5
|
+
const page = await newSpecPage({
|
|
6
|
+
components: [PaymentsList],
|
|
7
|
+
html: `<justifi-payments-list></justifi-payments-list>`,
|
|
8
|
+
});
|
|
9
|
+
expect(page.root).toEqualHtml(`
|
|
10
|
+
<justifi-payments-list exportparts="
|
|
11
|
+
table-head,table-head-row,table-head-cell,table-body,table-row,table-cell,
|
|
12
|
+
loading-state-cell,loading-state-spinner,error-state,empty-state,
|
|
13
|
+
pagination-bar,arrow,arrow-left,arrow-right,arrow-disabled
|
|
14
|
+
">
|
|
15
|
+
<mock:shadow-root>
|
|
16
|
+
<table class="table table-hover">
|
|
17
|
+
<thead class="sticky-top table-head" part="table-head">
|
|
18
|
+
<tr class="table-light" part="table-head-row">
|
|
19
|
+
<th part="table-head-cell" scope="col" title="The date and time each payment was made">
|
|
20
|
+
Made on
|
|
21
|
+
</th>
|
|
22
|
+
<th part="table-head-cell" scope="col" title="The dollar amount of each payment">
|
|
23
|
+
Amount
|
|
24
|
+
</th>
|
|
25
|
+
<th part="table-head-cell" scope="col">
|
|
26
|
+
Description
|
|
27
|
+
</th>
|
|
28
|
+
<th part="table-head-cell" scope="col">
|
|
29
|
+
Cardholder
|
|
30
|
+
</th>
|
|
31
|
+
<th part="table-head-cell" scope="col">
|
|
32
|
+
Payment Method
|
|
33
|
+
</th>
|
|
34
|
+
<th part="table-head-cell" scope="col">
|
|
35
|
+
Status
|
|
36
|
+
</th>
|
|
37
|
+
<th part="table-head-cell" scope="col">
|
|
38
|
+
Payment ID
|
|
39
|
+
</th>
|
|
40
|
+
</tr>
|
|
41
|
+
</thead>
|
|
42
|
+
<tbody class="table-body" part="table-body">
|
|
43
|
+
<tr>
|
|
44
|
+
<td class="error-state" colspan="7" part="error-state" style="text-align: center;">
|
|
45
|
+
An unexpected error occurred: Can not fetch any data without an AccountID and an AuthToken
|
|
46
|
+
</td>
|
|
47
|
+
</tr>
|
|
48
|
+
</tbody>
|
|
49
|
+
<tfoot class="sticky-bottom">
|
|
50
|
+
<tr class="align-middle table-light">
|
|
51
|
+
<td colspan="7" part="pagination-bar">
|
|
52
|
+
<div class="d-flex gap-3 justify-content-center pagination-bar">
|
|
53
|
+
<button class="btn btn-primary disabled pagination-btn pagination-prev-btn" disabled="" part="arrow arrow-left arrow-disabled">
|
|
54
|
+
←
|
|
55
|
+
</button>
|
|
56
|
+
<button class="btn btn-primary disabled pagination-btn pagination-next-btn" disabled="" part="arrow arrow-right arrow-disabled">
|
|
57
|
+
→
|
|
58
|
+
</button>
|
|
59
|
+
</div>
|
|
60
|
+
</td>
|
|
61
|
+
</tr>
|
|
62
|
+
</tfoot>
|
|
63
|
+
</table>
|
|
64
|
+
</mock:shadow-root>
|
|
65
|
+
</justifi-payments-list>
|
|
66
|
+
`);
|
|
67
|
+
});
|
|
68
|
+
it('stops loading', async () => {
|
|
69
|
+
const page = await newSpecPage({
|
|
70
|
+
components: [PaymentsList],
|
|
71
|
+
html: `<justifi-payments-list></justifi-payments-list>`,
|
|
72
|
+
});
|
|
73
|
+
const loading = page.root.__shadowRoot.querySelector('.loading-state');
|
|
74
|
+
expect(loading).toEqual(null);
|
|
75
|
+
});
|
|
76
|
+
it('renders an error when not given proper auth data', async () => {
|
|
77
|
+
const page = await newSpecPage({
|
|
78
|
+
components: [PaymentsList],
|
|
79
|
+
html: `<justifi-payments-list></justifi-payments-list>`,
|
|
80
|
+
});
|
|
81
|
+
const error = page.root.__shadowRoot.querySelector('.error-state');
|
|
82
|
+
expect(error).toBeDefined();
|
|
6
83
|
});
|
|
7
|
-
// it('renders', async () => {
|
|
8
|
-
// const page = await newSpecPage({
|
|
9
|
-
// components: [PaymentsList],
|
|
10
|
-
// html: `<payments-list></payments-list>`,
|
|
11
|
-
// });
|
|
12
|
-
// expect(page.root).toEqualHtml(`
|
|
13
|
-
// <payments-list>
|
|
14
|
-
// <mock:shadow-root>
|
|
15
|
-
// <slot></slot>
|
|
16
|
-
// </mock:shadow-root>
|
|
17
|
-
// </payments-list>
|
|
18
|
-
// `);
|
|
19
|
-
// });
|
|
20
84
|
});
|
|
21
85
|
//# sourceMappingURL=payments-list.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"payments-list.spec.js","sourceRoot":"","sources":["../../../../../src/components/payments-list/test/payments-list.spec.tsx"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"payments-list.spec.js","sourceRoot":"","sources":["../../../../../src/components/payments-list/test/payments-list.spec.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEhD,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;EACrC,EAAE,CAAC,kBAAkB,EAAE,KAAK,IAAI,EAAE;IAChC,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;MAC1B,IAAI,EAAE,iDAAiD;KACxD,CAAC,CAAC;IAEH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAyD7B,CAAC,CAAC;EACL,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE;IAC7B,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;MAC1B,IAAI,EAAE,iDAAiD;KACxD,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;IAEvE,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;EAChC,CAAC,CAAC,CAAC;EAEH,EAAE,CAAC,kDAAkD,EAAE,KAAK,IAAI,EAAE;IAChE,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC;MAC7B,UAAU,EAAE,CAAC,YAAY,CAAC;MAC1B,IAAI,EAAE,iDAAiD;KACxD,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;IAEnE,MAAM,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;EAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { newSpecPage } from '@stencil/core/testing';\nimport { PaymentsList } from '../payments-list';\n\ndescribe('justifi-payments-list', () => {\n it('renders properly', async () => {\n const page = await newSpecPage({\n components: [PaymentsList],\n html: `<justifi-payments-list></justifi-payments-list>`,\n });\n\n expect(page.root).toEqualHtml(`\n <justifi-payments-list exportparts=\"\n table-head,table-head-row,table-head-cell,table-body,table-row,table-cell,\n loading-state-cell,loading-state-spinner,error-state,empty-state,\n pagination-bar,arrow,arrow-left,arrow-right,arrow-disabled\n \">\n <mock:shadow-root>\n <table class=\"table table-hover\">\n <thead class=\"sticky-top table-head\" part=\"table-head\">\n <tr class=\"table-light\" part=\"table-head-row\">\n <th part=\"table-head-cell\" scope=\"col\" title=\"The date and time each payment was made\">\n Made on\n </th>\n <th part=\"table-head-cell\" scope=\"col\" title=\"The dollar amount of each payment\">\n Amount\n </th>\n <th part=\"table-head-cell\" scope=\"col\">\n Description\n </th>\n <th part=\"table-head-cell\" scope=\"col\">\n Cardholder\n </th>\n <th part=\"table-head-cell\" scope=\"col\">\n Payment Method\n </th>\n <th part=\"table-head-cell\" scope=\"col\">\n Status\n </th>\n <th part=\"table-head-cell\" scope=\"col\">\n Payment ID\n </th>\n </tr>\n </thead>\n <tbody class=\"table-body\" part=\"table-body\">\n <tr>\n <td class=\"error-state\" colspan=\"7\" part=\"error-state\" style=\"text-align: center;\">\n An unexpected error occurred: Can not fetch any data without an AccountID and an AuthToken\n </td>\n </tr>\n </tbody>\n <tfoot class=\"sticky-bottom\">\n <tr class=\"align-middle table-light\">\n <td colspan=\"7\" part=\"pagination-bar\">\n <div class=\"d-flex gap-3 justify-content-center pagination-bar\">\n <button class=\"btn btn-primary disabled pagination-btn pagination-prev-btn\" disabled=\"\" part=\"arrow arrow-left arrow-disabled\">\n ←\n </button>\n <button class=\"btn btn-primary disabled pagination-btn pagination-next-btn\" disabled=\"\" part=\"arrow arrow-right arrow-disabled\">\n →\n </button>\n </div>\n </td>\n </tr>\n </tfoot>\n </table>\n </mock:shadow-root>\n </justifi-payments-list>\n `);\n });\n\n it('stops loading', async () => {\n const page = await newSpecPage({\n components: [PaymentsList],\n html: `<justifi-payments-list></justifi-payments-list>`,\n });\n\n const loading = page.root.__shadowRoot.querySelector('.loading-state');\n\n expect(loading).toEqual(null);\n });\n\n it('renders an error when not given proper auth data', async () => {\n const page = await newSpecPage({\n components: [PaymentsList],\n html: `<justifi-payments-list></justifi-payments-list>`,\n });\n\n const error = page.root.__shadowRoot.querySelector('.error-state');\n\n expect(error).toBeDefined();\n });\n});\n"]}
|