@saasquatch/mint-components 1.11.1-4 → 1.11.1-40
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/dist/cjs/{GenericTableView-a3f48e15.js → GenericTableView-bb2fcd95.js} +1 -1
- package/dist/cjs/{ShadowViewAddon-cfda0bfa.js → ShadowViewAddon-2d56f3b4.js} +28 -20
- package/dist/cjs/{copy-text-view-5f908186.js → copy-text-view-29330e8a.js} +69 -25
- package/dist/cjs/{email-registration-view-4c5d9379.js → email-registration-view-54cedb43.js} +1 -1
- package/dist/cjs/{global-02e50f09.js → global-e067aa06.js} +2 -2
- package/dist/cjs/{index-b0129cd6.js → index-ff72278c.js} +2 -0
- package/dist/cjs/{index.module-df530553.js → index.module-224d7b8d.js} +1 -1
- package/dist/cjs/loader.cjs.js +5 -5
- package/dist/cjs/{luxon-05098e19.js → luxon-45228ff5.js} +1 -1
- package/dist/cjs/mint-components.cjs.js +5 -5
- package/dist/cjs/{mockRewardData-4258e067.js → mockRewardData-d6be2267.js} +1 -1
- package/dist/cjs/raisins-plop-target.cjs.entry.js +1 -1
- package/dist/cjs/{re-render-1976e05e.js → re-render-cd2f8774.js} +2 -2
- package/dist/cjs/{sqm-asset-card-view-a0e33f21.js → sqm-asset-card-view-30ca5188.js} +1 -1
- package/dist/cjs/sqm-asset-card.cjs.entry.js +4 -4
- package/dist/cjs/sqm-banking-info-form_16.cjs.entry.js +10 -10
- package/dist/cjs/sqm-big-stat_38.cjs.entry.js +13 -13
- package/dist/cjs/{sqm-close-button-view-217239b7.js → sqm-close-button-view-6a709e00.js} +1 -1
- package/dist/cjs/sqm-close-button.cjs.entry.js +4 -4
- package/dist/cjs/sqm-context-router.cjs.entry.js +3 -3
- package/dist/cjs/sqm-empty_4.cjs.entry.js +10 -5
- package/dist/cjs/sqm-form-message.cjs.entry.js +2 -2
- package/dist/cjs/sqm-graphql-client-provider.cjs.entry.js +3 -3
- package/dist/cjs/sqm-header-logo.cjs.entry.js +2 -2
- package/dist/cjs/sqm-instant-access-registration.cjs.entry.js +6 -6
- package/dist/cjs/{sqm-invoice-table-view-e3b03a00.js → sqm-invoice-table-view-2f4f426b.js} +2 -2
- package/dist/cjs/{sqm-leaderboard-rank-view-5a3d4a88.js → sqm-leaderboard-rank-view-317eb84f.js} +1 -1
- package/dist/cjs/sqm-leaderboard-rank.cjs.entry.js +5 -5
- package/dist/cjs/{sqm-logout-current-user-view-c9f18d96.js → sqm-logout-current-user-view-1912b773.js} +1 -1
- package/dist/cjs/sqm-logout-current-user.cjs.entry.js +4 -4
- package/dist/cjs/{sqm-navigation-sidebar-item-view-4e90b6f5.js → sqm-navigation-sidebar-item-view-010a81c7.js} +2 -2
- package/dist/cjs/sqm-navigation-sidebar-item.cjs.entry.js +4 -4
- package/dist/cjs/{sqm-navigation-sidebar-view-921704fb.js → sqm-navigation-sidebar-view-215eba1d.js} +1 -1
- package/dist/cjs/sqm-navigation-sidebar.cjs.entry.js +4 -4
- package/dist/cjs/sqm-pagination_3.cjs.entry.js +80 -30
- package/dist/cjs/sqm-password-field.cjs.entry.js +4 -4
- package/dist/cjs/sqm-popup-container.cjs.entry.js +3 -3
- package/dist/cjs/{sqm-portal-container-view-990a85a3.js → sqm-portal-container-view-976bf0f5.js} +1 -1
- package/dist/cjs/{sqm-portal-email-verification-view-bff9783d.js → sqm-portal-email-verification-view-f8980d11.js} +3 -3
- package/dist/cjs/sqm-portal-email-verification.cjs.entry.js +6 -6
- package/dist/cjs/{sqm-portal-forgot-password-view-3cd69fe7.js → sqm-portal-forgot-password-view-24339191.js} +2 -2
- package/dist/cjs/sqm-portal-forgot-password.cjs.entry.js +5 -5
- package/dist/cjs/sqm-portal-logout.cjs.entry.js +3 -3
- package/dist/cjs/{sqm-portal-profile-view-fde54e35.js → sqm-portal-profile-view-7c70d7f9.js} +3 -3
- package/dist/cjs/sqm-portal-profile.cjs.entry.js +7 -7
- package/dist/cjs/sqm-portal-protected-route.cjs.entry.js +3 -3
- package/dist/cjs/sqm-portal-registration-form.cjs.entry.js +5 -5
- package/dist/cjs/{sqm-portal-reset-password-view-34771d2c.js → sqm-portal-reset-password-view-1b85b8cf.js} +2 -2
- package/dist/cjs/sqm-portal-reset-password.cjs.entry.js +5 -5
- package/dist/cjs/{sqm-portal-verify-email-view-c8f91506.js → sqm-portal-verify-email-view-cc3c87c3.js} +2 -2
- package/dist/cjs/sqm-portal-verify-email.cjs.entry.js +5 -5
- package/dist/cjs/sqm-referral-table_11.cjs.entry.js +11 -11
- package/dist/cjs/sqm-referred-registration.cjs.entry.js +6 -6
- package/dist/cjs/sqm-rewards-table-customer-note-cell.cjs.entry.js +3 -3
- package/dist/cjs/sqm-rewards-table-customer-note-column.cjs.entry.js +4 -4
- package/dist/cjs/sqm-rewards-table_9.cjs.entry.js +10 -10
- package/dist/cjs/sqm-route.cjs.entry.js +1 -1
- package/dist/cjs/sqm-stencilbook.cjs.entry.js +55 -28
- package/dist/cjs/sqm-tab.cjs.entry.js +4 -4
- package/dist/cjs/sqm-tabs.cjs.entry.js +5 -5
- package/dist/cjs/{sqm-text-span-view-e1cd9bd3.js → sqm-text-span-view-38222836.js} +1 -1
- package/dist/cjs/sqm-text-span.cjs.entry.js +3 -3
- package/dist/cjs/{stencil-hooks.module-72742a0b.js → stencil-hooks.module-8f69ed33.js} +1 -1
- package/dist/cjs/{useChildElements-e0d44916.js → useChildElements-176ac928.js} +2 -2
- package/dist/cjs/{useInstantAccessRegistration-bbe746d1.js → useInstantAccessRegistration-151a3f4a.js} +3 -3
- package/dist/cjs/{useReferralTable-a76adb0d.js → useReferralTable-c91d9310.js} +5 -5
- package/dist/cjs/{useRegistrationFormState-876ed65d.js → useRegistrationFormState-49dd9295.js} +2 -2
- package/dist/cjs/{utilities-cec9dd36.js → utilities-719c980a.js} +2 -2
- package/dist/collection/components/sqm-coupon-code/sqm-coupon-code.js +1 -1
- package/dist/collection/components/sqm-empty/sqm-empty.js +10 -2
- package/dist/collection/components/sqm-logout-current-user/sqm-logout-current-user.js +1 -1
- package/dist/collection/components/sqm-pagination/sqm-pagination-view.js +6 -8
- package/dist/collection/components/sqm-pagination/sqm-pagination.js +47 -10
- package/dist/collection/components/sqm-referral-code/sqm-referral-code.js +5 -3
- package/dist/collection/components/sqm-referral-code/useReferralCode.js +12 -5
- package/dist/collection/components/sqm-referral-codes/ReferralCodes.stories.js +18 -0
- package/dist/collection/components/sqm-referral-codes/sqm-referral-codes-view.js +13 -3
- package/dist/collection/components/sqm-referral-codes/sqm-referral-codes.js +51 -5
- package/dist/collection/components/sqm-referral-codes/useReferralCodes.js +64 -22
- package/dist/collection/components/sqm-share-button/useShareButton.js +15 -8
- package/dist/collection/components/sqm-share-code/sqm-share-code.js +1 -1
- package/dist/collection/components/sqm-share-link/sqm-share-link.js +1 -1
- package/dist/collection/components/sqm-share-link/useShareLink.js +5 -4
- package/dist/collection/components/views/copy-text-view.js +4 -2
- package/dist/collection/stories/Widget.stories.js +5 -0
- package/dist/esm/{GenericTableView-bf154727.js → GenericTableView-706f5b56.js} +1 -1
- package/dist/esm/{ShadowViewAddon-95520b03.js → ShadowViewAddon-db086943.js} +28 -20
- package/dist/esm/{copy-text-view-73cd7a82.js → copy-text-view-47f83e9b.js} +69 -25
- package/dist/esm/{email-registration-view-12793040.js → email-registration-view-5ecee6f8.js} +1 -1
- package/dist/esm/{global-b89b6edc.js → global-701bd5b0.js} +2 -2
- package/dist/esm/{index-17b4da69.js → index-014ddfa3.js} +2 -1
- package/dist/esm/{index.module-f122af7b.js → index.module-5eb0926c.js} +2 -2
- package/dist/esm/loader.js +5 -5
- package/dist/esm/{luxon-7600be8d.js → luxon-12195d94.js} +1 -1
- package/dist/esm/mint-components.js +5 -5
- package/dist/esm/{mockRewardData-0eb6e778.js → mockRewardData-133c20ca.js} +1 -1
- package/dist/esm/raisins-plop-target.entry.js +1 -1
- package/dist/esm/{re-render-c64289f3.js → re-render-b31d83d7.js} +2 -2
- package/dist/esm/{sqm-asset-card-view-9d93fbdd.js → sqm-asset-card-view-da88351a.js} +1 -1
- package/dist/esm/sqm-asset-card.entry.js +4 -4
- package/dist/esm/sqm-banking-info-form_16.entry.js +10 -10
- package/dist/esm/sqm-big-stat_38.entry.js +13 -13
- package/dist/esm/{sqm-close-button-view-b24c708b.js → sqm-close-button-view-8058642b.js} +1 -1
- package/dist/esm/sqm-close-button.entry.js +4 -4
- package/dist/esm/sqm-context-router.entry.js +3 -3
- package/dist/esm/sqm-empty_4.entry.js +10 -5
- package/dist/esm/sqm-form-message.entry.js +2 -2
- package/dist/esm/sqm-graphql-client-provider.entry.js +3 -3
- package/dist/esm/sqm-header-logo.entry.js +2 -2
- package/dist/esm/sqm-instant-access-registration.entry.js +6 -6
- package/dist/esm/{sqm-invoice-table-view-09cc28d6.js → sqm-invoice-table-view-7d1aa71f.js} +2 -2
- package/dist/esm/{sqm-leaderboard-rank-view-10657658.js → sqm-leaderboard-rank-view-773a586f.js} +1 -1
- package/dist/esm/sqm-leaderboard-rank.entry.js +5 -5
- package/dist/esm/{sqm-logout-current-user-view-2c6122cd.js → sqm-logout-current-user-view-dfcd508a.js} +1 -1
- package/dist/esm/sqm-logout-current-user.entry.js +4 -4
- package/dist/esm/{sqm-navigation-sidebar-item-view-14114804.js → sqm-navigation-sidebar-item-view-9fa7f5ea.js} +2 -2
- package/dist/esm/sqm-navigation-sidebar-item.entry.js +4 -4
- package/dist/esm/{sqm-navigation-sidebar-view-0312e073.js → sqm-navigation-sidebar-view-5f332ea1.js} +1 -1
- package/dist/esm/sqm-navigation-sidebar.entry.js +4 -4
- package/dist/esm/sqm-pagination_3.entry.js +80 -30
- package/dist/esm/sqm-password-field.entry.js +4 -4
- package/dist/esm/sqm-popup-container.entry.js +3 -3
- package/dist/esm/{sqm-portal-container-view-6c582684.js → sqm-portal-container-view-83df005d.js} +1 -1
- package/dist/esm/{sqm-portal-email-verification-view-ced567c9.js → sqm-portal-email-verification-view-332e1339.js} +3 -3
- package/dist/esm/sqm-portal-email-verification.entry.js +6 -6
- package/dist/esm/{sqm-portal-forgot-password-view-95cd454f.js → sqm-portal-forgot-password-view-8629f753.js} +2 -2
- package/dist/esm/sqm-portal-forgot-password.entry.js +5 -5
- package/dist/esm/sqm-portal-logout.entry.js +3 -3
- package/dist/esm/{sqm-portal-profile-view-d72dd5ac.js → sqm-portal-profile-view-847526a2.js} +3 -3
- package/dist/esm/sqm-portal-profile.entry.js +7 -7
- package/dist/esm/sqm-portal-protected-route.entry.js +3 -3
- package/dist/esm/sqm-portal-registration-form.entry.js +5 -5
- package/dist/esm/{sqm-portal-reset-password-view-f1454d43.js → sqm-portal-reset-password-view-865655da.js} +2 -2
- package/dist/esm/sqm-portal-reset-password.entry.js +5 -5
- package/dist/esm/{sqm-portal-verify-email-view-3739f523.js → sqm-portal-verify-email-view-6c60df25.js} +2 -2
- package/dist/esm/sqm-portal-verify-email.entry.js +5 -5
- package/dist/esm/sqm-referral-table_11.entry.js +11 -11
- package/dist/esm/sqm-referred-registration.entry.js +6 -6
- package/dist/esm/sqm-rewards-table-customer-note-cell.entry.js +3 -3
- package/dist/esm/sqm-rewards-table-customer-note-column.entry.js +4 -4
- package/dist/esm/sqm-rewards-table_9.entry.js +10 -10
- package/dist/esm/sqm-route.entry.js +1 -1
- package/dist/esm/sqm-stencilbook.entry.js +55 -28
- package/dist/esm/sqm-tab.entry.js +4 -4
- package/dist/esm/sqm-tabs.entry.js +5 -5
- package/dist/esm/{sqm-text-span-view-8d140661.js → sqm-text-span-view-d6e03f93.js} +1 -1
- package/dist/esm/sqm-text-span.entry.js +3 -3
- package/dist/esm/{stencil-hooks.module-ac12ca1c.js → stencil-hooks.module-576d7f01.js} +1 -1
- package/dist/esm/{useChildElements-37daf533.js → useChildElements-ebcfbc19.js} +2 -2
- package/dist/esm/{useInstantAccessRegistration-9d4cb797.js → useInstantAccessRegistration-7b2ea2bd.js} +3 -3
- package/dist/esm/{useReferralTable-42f99ea2.js → useReferralTable-df227f15.js} +5 -5
- package/dist/esm/{useRegistrationFormState-53c71782.js → useRegistrationFormState-faea9402.js} +2 -2
- package/dist/esm/{utilities-18d10876.js → utilities-292b61b9.js} +2 -2
- package/dist/esm-es5/{GenericTableView-bf154727.js → GenericTableView-706f5b56.js} +1 -1
- package/dist/esm-es5/ShadowViewAddon-db086943.js +1 -0
- package/dist/esm-es5/copy-text-view-47f83e9b.js +1 -0
- package/dist/esm-es5/{email-registration-view-12793040.js → email-registration-view-5ecee6f8.js} +1 -1
- package/dist/esm-es5/{global-b89b6edc.js → global-701bd5b0.js} +1 -1
- package/dist/esm-es5/{index-17b4da69.js → index-014ddfa3.js} +1 -1
- package/dist/esm-es5/{index.module-f122af7b.js → index.module-5eb0926c.js} +1 -1
- package/dist/esm-es5/loader.js +1 -1
- package/dist/esm-es5/{luxon-7600be8d.js → luxon-12195d94.js} +1 -1
- package/dist/esm-es5/mint-components.js +1 -1
- package/dist/esm-es5/{mockRewardData-0eb6e778.js → mockRewardData-133c20ca.js} +1 -1
- package/dist/esm-es5/raisins-plop-target.entry.js +1 -1
- package/dist/esm-es5/{re-render-c64289f3.js → re-render-b31d83d7.js} +1 -1
- package/dist/esm-es5/{sqm-asset-card-view-9d93fbdd.js → sqm-asset-card-view-da88351a.js} +1 -1
- package/dist/esm-es5/sqm-asset-card.entry.js +1 -1
- package/dist/esm-es5/sqm-banking-info-form_16.entry.js +1 -1
- package/dist/esm-es5/sqm-big-stat_38.entry.js +1 -1
- package/dist/esm-es5/{sqm-close-button-view-b24c708b.js → sqm-close-button-view-8058642b.js} +1 -1
- package/dist/esm-es5/sqm-close-button.entry.js +1 -1
- package/dist/esm-es5/sqm-context-router.entry.js +1 -1
- package/dist/esm-es5/sqm-empty_4.entry.js +1 -1
- package/dist/esm-es5/sqm-form-message.entry.js +1 -1
- package/dist/esm-es5/sqm-graphql-client-provider.entry.js +1 -1
- package/dist/esm-es5/sqm-header-logo.entry.js +1 -1
- package/dist/esm-es5/sqm-instant-access-registration.entry.js +1 -1
- package/dist/esm-es5/{sqm-invoice-table-view-09cc28d6.js → sqm-invoice-table-view-7d1aa71f.js} +1 -1
- package/dist/esm-es5/sqm-leaderboard-rank-view-773a586f.js +1 -0
- package/dist/esm-es5/sqm-leaderboard-rank.entry.js +1 -1
- package/dist/esm-es5/{sqm-logout-current-user-view-2c6122cd.js → sqm-logout-current-user-view-dfcd508a.js} +1 -1
- package/dist/esm-es5/sqm-logout-current-user.entry.js +1 -1
- package/dist/esm-es5/{sqm-navigation-sidebar-item-view-14114804.js → sqm-navigation-sidebar-item-view-9fa7f5ea.js} +1 -1
- package/dist/esm-es5/sqm-navigation-sidebar-item.entry.js +1 -1
- package/dist/esm-es5/{sqm-navigation-sidebar-view-0312e073.js → sqm-navigation-sidebar-view-5f332ea1.js} +1 -1
- package/dist/esm-es5/sqm-navigation-sidebar.entry.js +1 -1
- package/dist/esm-es5/sqm-pagination_3.entry.js +1 -1
- package/dist/esm-es5/sqm-password-field.entry.js +1 -1
- package/dist/esm-es5/sqm-popup-container.entry.js +1 -1
- package/dist/esm-es5/{sqm-portal-container-view-6c582684.js → sqm-portal-container-view-83df005d.js} +1 -1
- package/dist/esm-es5/{sqm-portal-email-verification-view-ced567c9.js → sqm-portal-email-verification-view-332e1339.js} +1 -1
- package/dist/esm-es5/sqm-portal-email-verification.entry.js +1 -1
- package/dist/esm-es5/{sqm-portal-forgot-password-view-95cd454f.js → sqm-portal-forgot-password-view-8629f753.js} +1 -1
- package/dist/esm-es5/sqm-portal-forgot-password.entry.js +1 -1
- package/dist/esm-es5/sqm-portal-logout.entry.js +1 -1
- package/dist/esm-es5/{sqm-portal-profile-view-d72dd5ac.js → sqm-portal-profile-view-847526a2.js} +1 -1
- package/dist/esm-es5/sqm-portal-profile.entry.js +1 -1
- package/dist/esm-es5/sqm-portal-protected-route.entry.js +1 -1
- package/dist/esm-es5/sqm-portal-registration-form.entry.js +1 -1
- package/dist/esm-es5/{sqm-portal-reset-password-view-f1454d43.js → sqm-portal-reset-password-view-865655da.js} +1 -1
- package/dist/esm-es5/sqm-portal-reset-password.entry.js +1 -1
- package/dist/esm-es5/{sqm-portal-verify-email-view-3739f523.js → sqm-portal-verify-email-view-6c60df25.js} +1 -1
- package/dist/esm-es5/sqm-portal-verify-email.entry.js +1 -1
- package/dist/esm-es5/sqm-referral-table_11.entry.js +1 -1
- package/dist/esm-es5/sqm-referred-registration.entry.js +1 -1
- package/dist/esm-es5/sqm-rewards-table-customer-note-cell.entry.js +1 -1
- package/dist/esm-es5/sqm-rewards-table-customer-note-column.entry.js +1 -1
- package/dist/esm-es5/sqm-rewards-table_9.entry.js +1 -1
- package/dist/esm-es5/sqm-route.entry.js +1 -1
- package/dist/esm-es5/sqm-stencilbook.entry.js +1 -1
- package/dist/esm-es5/sqm-tab.entry.js +1 -1
- package/dist/esm-es5/sqm-tabs.entry.js +1 -1
- package/dist/esm-es5/{sqm-text-span-view-8d140661.js → sqm-text-span-view-d6e03f93.js} +1 -1
- package/dist/esm-es5/sqm-text-span.entry.js +1 -1
- package/dist/esm-es5/{stencil-hooks.module-ac12ca1c.js → stencil-hooks.module-576d7f01.js} +1 -1
- package/dist/esm-es5/useChildElements-ebcfbc19.js +1 -0
- package/dist/esm-es5/useInstantAccessRegistration-7b2ea2bd.js +1 -0
- package/dist/esm-es5/{useReferralTable-42f99ea2.js → useReferralTable-df227f15.js} +1 -1
- package/dist/esm-es5/useRegistrationFormState-faea9402.js +1 -0
- package/dist/esm-es5/{utilities-18d10876.js → utilities-292b61b9.js} +1 -1
- package/dist/mint-components/mint-components.esm.js +1 -1
- package/dist/mint-components/mint-components.js +1 -1
- package/dist/mint-components/{p-fd2c5407.js → p-019506c4.js} +1 -1
- package/dist/mint-components/p-03e2a88c.js +1 -0
- package/dist/mint-components/{p-01434e4a.entry.js → p-04643464.entry.js} +1 -1
- package/dist/mint-components/p-062051ad.entry.js +1 -0
- package/dist/mint-components/{p-18a19cb5.system.js → p-06b8a582.system.js} +1 -1
- package/dist/mint-components/p-0a26adee.js +1 -0
- package/dist/mint-components/{p-523ed056.system.js → p-0dc18b5c.system.js} +1 -1
- package/dist/mint-components/p-0ebd104c.js +1 -0
- package/dist/mint-components/{p-8077e9c6.js → p-134424df.js} +1 -1
- package/dist/mint-components/p-146c2a0e.js +1 -0
- package/dist/mint-components/{p-c7ce2c1e.system.js → p-16b9efe1.system.js} +1 -1
- package/dist/mint-components/{p-991c9787.js → p-195e306e.js} +2 -2
- package/dist/mint-components/{p-251e7567.js → p-1a4e5a3a.js} +1 -1
- package/dist/mint-components/p-1a5f4a13.system.entry.js +1 -0
- package/dist/mint-components/{p-3cc5474d.entry.js → p-1c45b7d0.entry.js} +1 -1
- package/dist/mint-components/{p-bb6f6681.system.js → p-1e03d640.system.js} +1 -1
- package/dist/mint-components/{p-1099290c.system.js → p-1e68fa26.system.js} +1 -1
- package/dist/mint-components/p-20c6c73e.entry.js +1 -0
- package/dist/mint-components/{p-ff17b3a4.system.js → p-21d94eab.system.js} +1 -1
- package/dist/mint-components/{p-2e16db11.entry.js → p-2474c5c6.entry.js} +1 -1
- package/dist/mint-components/p-2478ab2e.js +1 -0
- package/dist/mint-components/{p-3373d84e.js → p-249798d3.js} +1 -1
- package/dist/mint-components/{p-1b1d10e5.entry.js → p-26383fdd.entry.js} +1 -1
- package/dist/mint-components/p-284f26ec.system.entry.js +1 -0
- package/dist/mint-components/{p-c1a47137.system.entry.js → p-29952a5b.system.entry.js} +1 -1
- package/dist/mint-components/{p-64fcb97f.system.entry.js → p-29e0dedf.system.entry.js} +1 -1
- package/dist/mint-components/{p-4f775e84.system.js → p-2be11651.system.js} +1 -1
- package/dist/mint-components/{p-9deac406.system.js → p-2cb2401d.system.js} +1 -1
- package/dist/mint-components/{p-246a2827.entry.js → p-2d688fe9.entry.js} +1 -1
- package/dist/mint-components/{p-96cb9c17.entry.js → p-391b6274.entry.js} +1 -1
- package/dist/mint-components/{p-c39f9dc1.system.entry.js → p-3973cf23.system.entry.js} +1 -1
- package/dist/mint-components/{p-59c141a2.system.js → p-3c6bc373.system.js} +1 -1
- package/dist/mint-components/p-3ee0a8af.entry.js +1 -0
- package/dist/mint-components/p-3ef97112.system.js +1 -0
- package/dist/mint-components/{p-1c6e4a5f.entry.js → p-3f03a247.entry.js} +2 -2
- package/dist/mint-components/{p-855ae1b5.js → p-42390bcc.js} +1 -1
- package/dist/mint-components/{p-e546347e.system.js → p-4531488f.system.js} +1 -1
- package/dist/mint-components/{p-2a414b2e.system.js → p-45d71b2a.system.js} +1 -1
- package/dist/mint-components/{p-798ed3a2.entry.js → p-45f46e4c.entry.js} +1 -1
- package/dist/mint-components/{p-daba8cd2.system.entry.js → p-48a72a05.system.entry.js} +1 -1
- package/dist/mint-components/{p-b334bde8.entry.js → p-4be053fb.entry.js} +2 -2
- package/dist/mint-components/{p-ec8a9e91.system.entry.js → p-4c1b1914.system.entry.js} +1 -1
- package/dist/mint-components/{p-53ff8bd0.system.entry.js → p-4ef2f4f6.system.entry.js} +1 -1
- package/dist/mint-components/{p-48b7d703.entry.js → p-5073b8c9.entry.js} +1 -1
- package/dist/mint-components/{p-ea88142c.js → p-517bcc71.js} +1 -1
- package/dist/mint-components/{p-9288cca6.system.entry.js → p-51dba12d.system.entry.js} +1 -1
- package/dist/mint-components/p-53e25b79.entry.js +1 -0
- package/dist/mint-components/p-549139be.entry.js +1 -0
- package/dist/mint-components/p-57f92fe0.entry.js +1 -0
- package/dist/mint-components/{p-de2a8fae.system.entry.js → p-5922cd9e.system.entry.js} +1 -1
- package/dist/mint-components/{p-32cf8417.js → p-59e310c8.js} +1 -1
- package/dist/mint-components/{p-92110eef.entry.js → p-5c70bc39.entry.js} +1 -1
- package/dist/mint-components/{p-5c845bc2.system.entry.js → p-5dcd7fc9.system.entry.js} +1 -1
- package/dist/mint-components/p-5fe660bb.system.entry.js +1 -0
- package/dist/mint-components/{p-64c3217a.js → p-61d5f26e.js} +1 -1
- package/dist/mint-components/p-64473f17.system.js +1 -0
- package/dist/mint-components/{p-e41cb11f.js → p-65535cf7.js} +1 -1
- package/dist/mint-components/{p-0806343b.js → p-6568392b.js} +1 -1
- package/dist/mint-components/p-66aca488.entry.js +1 -0
- package/dist/mint-components/{p-9c3d78e9.js → p-66c7b15c.js} +1 -1
- package/dist/mint-components/{p-f44d88fa.system.js → p-66d9a540.system.js} +1 -1
- package/dist/mint-components/{p-79da7f18.js → p-6d164a9e.js} +1 -1
- package/dist/mint-components/{p-942d1c22.entry.js → p-6dab9a17.entry.js} +1 -1
- package/dist/mint-components/{p-0f028514.system.js → p-71e0ca2b.system.js} +1 -1
- package/dist/mint-components/{p-3036cf58.system.js → p-752650b9.system.js} +1 -1
- package/dist/mint-components/{p-1c710e16.entry.js → p-752fd47b.entry.js} +1 -1
- package/dist/mint-components/{p-55588b46.system.js → p-778b3774.system.js} +1 -1
- package/dist/mint-components/p-7956a44f.system.entry.js +1 -0
- package/dist/mint-components/{p-f3053c61.js → p-7ae55645.js} +1 -1
- package/dist/mint-components/p-7dc69a64.entry.js +13 -0
- package/dist/mint-components/{p-7962ab58.system.entry.js → p-7f43c280.system.entry.js} +1 -1
- package/dist/mint-components/{p-370a1a73.system.js → p-81ed0e97.system.js} +1 -1
- package/dist/mint-components/{p-6b5e355c.system.js → p-842cbd05.system.js} +1 -1
- package/dist/mint-components/p-87113437.entry.js +11 -0
- package/dist/mint-components/{p-5d37482d.entry.js → p-8925f3c5.entry.js} +1 -1
- package/dist/mint-components/{p-21d4f6ce.system.js → p-8b9408e5.system.js} +1 -1
- package/dist/mint-components/{p-00be5090.js → p-8c765c81.js} +1 -1
- package/dist/mint-components/{p-dbc0db45.js → p-8cd49ec4.js} +3 -3
- package/dist/mint-components/{p-d68ed4a6.system.entry.js → p-9a1a4d71.system.entry.js} +1 -1
- package/dist/mint-components/p-9ed09b3a.system.js +1 -0
- package/dist/mint-components/p-9ee50200.entry.js +1 -0
- package/dist/mint-components/{p-6afb4f48.system.entry.js → p-9f9f851d.system.entry.js} +1 -1
- package/dist/mint-components/{p-03a647c2.system.js → p-9fc73ff8.system.js} +1 -1
- package/dist/mint-components/p-a13c83c5.entry.js +1 -0
- package/dist/mint-components/{p-ce746af8.system.js → p-a2aed0da.system.js} +1 -1
- package/dist/mint-components/{p-178d2d2e.entry.js → p-a3fdbfed.entry.js} +1 -1
- package/dist/mint-components/{p-fbdf0738.entry.js → p-a4c1b404.entry.js} +1 -1
- package/dist/mint-components/{p-02f6cda4.js → p-a9ff5495.js} +1 -1
- package/dist/mint-components/{p-acc93caa.system.entry.js → p-af4cce6a.system.entry.js} +1 -1
- package/dist/mint-components/p-b08e9577.entry.js +1 -0
- package/dist/mint-components/{p-ce9e7c98.system.js → p-b210bcc2.system.js} +1 -1
- package/dist/mint-components/p-b3aaeb2f.system.entry.js +1 -0
- package/dist/mint-components/p-b3d193e3.system.entry.js +1 -0
- package/dist/mint-components/{p-6e7e8af6.system.js → p-b3f02315.system.js} +1 -1
- package/dist/mint-components/{p-67846dce.system.entry.js → p-b4448aec.system.entry.js} +1 -1
- package/dist/mint-components/p-b6f61a27.entry.js +9 -0
- package/dist/mint-components/{p-ed161025.js → p-b7705066.js} +1 -1
- package/dist/mint-components/{p-43a990b6.system.js → p-b8230f83.system.js} +1 -1
- package/dist/mint-components/p-bd5cb4f3.system.js +1 -0
- package/dist/mint-components/{p-f52c3aec.system.entry.js → p-c134af86.system.entry.js} +1 -1
- package/dist/mint-components/{p-f0806232.system.entry.js → p-c2281e04.system.entry.js} +1 -1
- package/dist/mint-components/{p-ecefeaa9.system.entry.js → p-c3188365.system.entry.js} +1 -1
- package/dist/mint-components/{p-e2bb72eb.system.entry.js → p-c3b8765c.system.entry.js} +1 -1
- package/dist/mint-components/{p-22de9f73.system.entry.js → p-ca182259.system.entry.js} +1 -1
- package/dist/mint-components/{p-cfbe2f86.entry.js → p-cc1ffc0c.entry.js} +1 -1
- package/dist/mint-components/{p-e3e16c36.js → p-d25af377.js} +1 -1
- package/dist/mint-components/{p-73decce7.system.js → p-d2abffc0.system.js} +1 -1
- package/dist/mint-components/p-d8d97ff5.js +1 -0
- package/dist/mint-components/{p-1ce4fa30.system.entry.js → p-dac99706.system.entry.js} +1 -1
- package/dist/mint-components/{p-ac1bf045.js → p-e039ce2f.js} +1 -1
- package/dist/mint-components/{p-82e09b8d.system.entry.js → p-e1e700b8.system.entry.js} +1 -1
- package/dist/mint-components/{p-fb2c0ce4.system.entry.js → p-e3411b86.system.entry.js} +1 -1
- package/dist/mint-components/{p-88aac6a9.system.entry.js → p-e401cb44.system.entry.js} +1 -1
- package/dist/mint-components/{p-ed6ebd60.system.js → p-e479d77e.system.js} +1 -1
- package/dist/mint-components/{p-88a2e66e.system.entry.js → p-e53e95ce.system.entry.js} +1 -1
- package/dist/mint-components/{p-41499327.entry.js → p-e909906f.entry.js} +1 -1
- package/dist/mint-components/{p-452b562d.entry.js → p-e91bdadf.entry.js} +1 -1
- package/dist/mint-components/{p-6e62f207.entry.js → p-e92f0fbb.entry.js} +1 -1
- package/dist/mint-components/p-ebd6c7e5.js +52 -0
- package/dist/mint-components/{p-5d0c9424.js → p-ee343d0b.js} +1 -1
- package/dist/mint-components/{p-bf834367.system.js → p-ee474d4c.system.js} +1 -1
- package/dist/mint-components/{p-ff41c804.system.entry.js → p-f246f7dd.system.entry.js} +1 -1
- package/dist/mint-components/{p-c7fd9e16.js → p-f29e62e1.js} +1 -1
- package/dist/mint-components/{p-14dac608.system.entry.js → p-f5c3a8cf.system.entry.js} +1 -1
- package/dist/mint-components/{p-a474b0ec.system.entry.js → p-f6712472.system.entry.js} +1 -1
- package/dist/mint-components/{p-46ca288c.system.js → p-f6c279d8.system.js} +1 -1
- package/dist/mint-components/{p-b3b5b4b7.system.entry.js → p-f9564398.system.entry.js} +1 -1
- package/dist/mint-components/{p-a1150633.system.entry.js → p-f9680769.system.entry.js} +1 -1
- package/dist/mint-components/{p-d3d281ff.entry.js → p-f9b9be03.entry.js} +1 -1
- package/dist/mint-components/{p-1df19ea2.js → p-fd04355d.js} +1 -1
- package/dist/mint-components/p-feace4a6.entry.js +1 -0
- package/dist/mint-components/{p-8c97bfb1.system.entry.js → p-fef83f2a.system.entry.js} +1 -1
- package/dist/mint-components/{p-fae82751.entry.js → p-ffdb1310.entry.js} +1 -1
- package/dist/types/components/sqm-empty/sqm-empty.d.ts +1 -1
- package/dist/types/components/sqm-pagination/sqm-pagination-view.d.ts +4 -0
- package/dist/types/components/sqm-pagination/sqm-pagination.d.ts +4 -0
- package/dist/types/components/sqm-pagination/usePagination.d.ts +1 -1
- package/dist/types/components/sqm-referral-code/sqm-referral-code.d.ts +1 -1
- package/dist/types/components/sqm-referral-codes/ReferralCodes.stories.d.ts +2 -0
- package/dist/types/components/sqm-referral-codes/sqm-referral-codes-view.d.ts +6 -0
- package/dist/types/components/sqm-referral-codes/sqm-referral-codes.d.ts +7 -1
- package/dist/types/components/sqm-referral-codes/useReferralCodes.d.ts +9 -5
- package/dist/types/components/views/copy-text-view.d.ts +1 -0
- package/dist/types/components.d.ts +21 -3
- package/dist/types/stories/Widget.stories.d.ts +6 -0
- package/docs/docs.docx +0 -0
- package/docs/raisins.json +1 -1
- package/grapesjs/grapesjs.js +1 -1
- package/package.json +1 -1
- package/dist/esm-es5/ShadowViewAddon-95520b03.js +0 -1
- package/dist/esm-es5/copy-text-view-73cd7a82.js +0 -1
- package/dist/esm-es5/sqm-leaderboard-rank-view-10657658.js +0 -1
- package/dist/esm-es5/useChildElements-37daf533.js +0 -1
- package/dist/esm-es5/useInstantAccessRegistration-9d4cb797.js +0 -1
- package/dist/esm-es5/useRegistrationFormState-53c71782.js +0 -1
- package/dist/mint-components/p-0a898ab1.js +0 -1
- package/dist/mint-components/p-110dddfe.entry.js +0 -1
- package/dist/mint-components/p-12c56ba6.entry.js +0 -1
- package/dist/mint-components/p-15dee492.js +0 -1
- package/dist/mint-components/p-18a7f543.system.entry.js +0 -1
- package/dist/mint-components/p-1a02cebe.entry.js +0 -13
- package/dist/mint-components/p-26306ac4.system.entry.js +0 -1
- package/dist/mint-components/p-4068bd43.system.js +0 -1
- package/dist/mint-components/p-476182e7.system.entry.js +0 -1
- package/dist/mint-components/p-494e407e.entry.js +0 -1
- package/dist/mint-components/p-4f815653.entry.js +0 -9
- package/dist/mint-components/p-5b7e2d53.entry.js +0 -1
- package/dist/mint-components/p-5fc8d87c.system.js +0 -1
- package/dist/mint-components/p-639d3dd3.entry.js +0 -1
- package/dist/mint-components/p-6b0e6a6c.js +0 -1
- package/dist/mint-components/p-753a19e2.js +0 -25
- package/dist/mint-components/p-89a760ea.js +0 -1
- package/dist/mint-components/p-9dcfa187.system.js +0 -1
- package/dist/mint-components/p-aed69f9e.system.entry.js +0 -1
- package/dist/mint-components/p-b4eb9c46.entry.js +0 -11
- package/dist/mint-components/p-b5176703.entry.js +0 -1
- package/dist/mint-components/p-bd4e9c2b.js +0 -1
- package/dist/mint-components/p-c1ba2ad0.system.entry.js +0 -1
- package/dist/mint-components/p-c8878e79.entry.js +0 -1
- package/dist/mint-components/p-ca17d998.entry.js +0 -1
- package/dist/mint-components/p-d666b326.js +0 -1
- package/dist/mint-components/p-dc41ff27.entry.js +0 -1
- package/dist/mint-components/p-dd0d79bf.entry.js +0 -1
- package/dist/mint-components/p-f1ec1180.entry.js +0 -1
- package/dist/mint-components/p-f26580a1.system.entry.js +0 -1
- package/dist/mint-components/p-f2a0658d.system.js +0 -1
- package/dist/types/global/android.d.ts +0 -7
- package/dist/types/global/demo.d.ts +0 -2
- package/dist/types/stories/features.d.ts +0 -4
- package/dist/types/stories/templates.d.ts +0 -4
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { h } from "@stencil/core";
|
|
1
|
+
import { Fragment, h } from "@stencil/core";
|
|
2
2
|
import { createStyleSheet } from "../../styling/JSS";
|
|
3
3
|
const style = {
|
|
4
4
|
Container: {
|
|
@@ -16,15 +16,13 @@ const style = {
|
|
|
16
16
|
const sheet = createStyleSheet(style);
|
|
17
17
|
const styleString = sheet.toString();
|
|
18
18
|
export function PaginationView(props) {
|
|
19
|
-
const { onNext, onPrev, currentPage, totalPages } = props;
|
|
19
|
+
const { onNext, onPrev, currentPage, totalPages, text, loading } = props;
|
|
20
20
|
return (h("span", { class: sheet.classes.Container, part: "sqm-base" },
|
|
21
21
|
h("style", { type: "text/css" }, styleString),
|
|
22
|
-
h(
|
|
23
|
-
h("sl-
|
|
24
|
-
|
|
25
|
-
h("
|
|
26
|
-
h("span", null, "of"),
|
|
27
|
-
h("span", null, totalPages)),
|
|
22
|
+
!loading && (h(Fragment, null,
|
|
23
|
+
h("sl-button", { onClick: onPrev, part: "sqm-pagination-button", circle: true, disabled: currentPage === 1 },
|
|
24
|
+
h("sl-icon", { name: "chevron-left", label: "Previous Page" })),
|
|
25
|
+
h("div", { class: sheet.classes.TextContainer }, text.paginationText))),
|
|
28
26
|
h("sl-button", { onClick: onNext, part: "sqm-pagination-button", circle: true, disabled: currentPage === totalPages },
|
|
29
27
|
h("sl-icon", { name: "chevron-right", label: "Previous Page" }))));
|
|
30
28
|
}
|
|
@@ -6,6 +6,7 @@ import deepmerge from "deepmerge";
|
|
|
6
6
|
import { withHooks } from "@saasquatch/stencil-hooks";
|
|
7
7
|
import { useState } from "@saasquatch/universal-hooks";
|
|
8
8
|
import { isDemo } from "@saasquatch/component-boilerplate";
|
|
9
|
+
import { intl } from "../../global/global";
|
|
9
10
|
/**
|
|
10
11
|
* @uiName Pagination
|
|
11
12
|
* @exampleGroup Common Components
|
|
@@ -14,29 +15,62 @@ import { isDemo } from "@saasquatch/component-boilerplate";
|
|
|
14
15
|
export class Pagination {
|
|
15
16
|
constructor() {
|
|
16
17
|
this.ignored = true;
|
|
18
|
+
/**
|
|
19
|
+
* @uiName Pagination text
|
|
20
|
+
*/
|
|
21
|
+
this.paginationText = "{currentPage} of {totalPages}";
|
|
17
22
|
withHooks(this);
|
|
18
23
|
}
|
|
19
24
|
disconnectedCallback() { }
|
|
20
25
|
render() {
|
|
21
|
-
|
|
22
|
-
var _a, _b;
|
|
26
|
+
var _a;
|
|
23
27
|
const hookProps = isDemo()
|
|
24
28
|
? useDemoPagination(getProps(this))
|
|
25
29
|
: usePagination();
|
|
30
|
+
const currentPage = hookProps.states.currentPage + 1;
|
|
31
|
+
const totalPages = (_a = hookProps.states) === null || _a === void 0 ? void 0 : _a.pageCount;
|
|
26
32
|
const props = {
|
|
27
|
-
currentPage
|
|
28
|
-
totalPages
|
|
33
|
+
currentPage,
|
|
34
|
+
totalPages,
|
|
29
35
|
onNext: () => { var _a, _b; return (_a = hookProps.callbacks) === null || _a === void 0 ? void 0 : _a.setCurrentPage(((_b = hookProps.states) === null || _b === void 0 ? void 0 : _b.currentPage) + 1); },
|
|
30
36
|
onPrev: () => { var _a, _b; return (_a = hookProps.callbacks) === null || _a === void 0 ? void 0 : _a.setCurrentPage(((_b = hookProps.states) === null || _b === void 0 ? void 0 : _b.currentPage) - 1); },
|
|
31
37
|
text: {
|
|
32
|
-
|
|
38
|
+
paginationText: intl.formatMessage({
|
|
39
|
+
id: `paginationText`,
|
|
40
|
+
defaultMessage: this.paginationText,
|
|
41
|
+
}, {
|
|
42
|
+
currentPage,
|
|
43
|
+
totalPages,
|
|
44
|
+
}),
|
|
33
45
|
},
|
|
46
|
+
loading: hookProps.states.loading,
|
|
34
47
|
};
|
|
35
48
|
return h(PaginationView, Object.assign({}, props));
|
|
36
49
|
}
|
|
37
50
|
static get is() { return "sqm-pagination"; }
|
|
38
51
|
static get encapsulation() { return "shadow"; }
|
|
39
52
|
static get properties() { return {
|
|
53
|
+
"paginationText": {
|
|
54
|
+
"type": "string",
|
|
55
|
+
"mutable": false,
|
|
56
|
+
"complexType": {
|
|
57
|
+
"original": "string",
|
|
58
|
+
"resolved": "string",
|
|
59
|
+
"references": {}
|
|
60
|
+
},
|
|
61
|
+
"required": false,
|
|
62
|
+
"optional": false,
|
|
63
|
+
"docs": {
|
|
64
|
+
"tags": [{
|
|
65
|
+
"text": "Pagination text",
|
|
66
|
+
"name": "uiName"
|
|
67
|
+
}],
|
|
68
|
+
"text": ""
|
|
69
|
+
},
|
|
70
|
+
"attribute": "pagination-text",
|
|
71
|
+
"reflect": false,
|
|
72
|
+
"defaultValue": "\"{currentPage} of {totalPages}\""
|
|
73
|
+
},
|
|
40
74
|
"demoData": {
|
|
41
75
|
"type": "unknown",
|
|
42
76
|
"mutable": false,
|
|
@@ -71,15 +105,18 @@ export class Pagination {
|
|
|
71
105
|
function useDemoPagination(props) {
|
|
72
106
|
const [currentPage, setCurrentPage] = useState(1);
|
|
73
107
|
return deepmerge({
|
|
74
|
-
states: {
|
|
75
|
-
currentPage: currentPage,
|
|
76
|
-
pageCount: 5,
|
|
77
|
-
},
|
|
108
|
+
states: {},
|
|
78
109
|
callbacks: {
|
|
79
110
|
setCurrentPage,
|
|
80
111
|
},
|
|
81
112
|
text: {
|
|
82
|
-
|
|
113
|
+
paginationText: intl.formatMessage({
|
|
114
|
+
id: `paginationText`,
|
|
115
|
+
defaultMessage: this.paginationText,
|
|
116
|
+
}, {
|
|
117
|
+
currentPage: currentPage + 1,
|
|
118
|
+
totalPages: 5,
|
|
119
|
+
}),
|
|
83
120
|
},
|
|
84
121
|
}, props.demoData || {}, { arrayMerge: (_, a) => a });
|
|
85
122
|
}
|
|
@@ -39,7 +39,7 @@ export class ReferralCode {
|
|
|
39
39
|
/**
|
|
40
40
|
* Change the text alignment
|
|
41
41
|
*
|
|
42
|
-
* @uiName
|
|
42
|
+
* @uiName Referral code alignment
|
|
43
43
|
* @uiType string
|
|
44
44
|
* @uiEnum ["left", "center", "right"]
|
|
45
45
|
* @uiEnumNames ["Left", "Center", "Right"]
|
|
@@ -190,7 +190,7 @@ export class ReferralCode {
|
|
|
190
190
|
"optional": false,
|
|
191
191
|
"docs": {
|
|
192
192
|
"tags": [{
|
|
193
|
-
"text": "
|
|
193
|
+
"text": "Referral code alignment",
|
|
194
194
|
"name": "uiName"
|
|
195
195
|
}, {
|
|
196
196
|
"text": "string",
|
|
@@ -264,7 +264,7 @@ export class ReferralCode {
|
|
|
264
264
|
"mutable": false,
|
|
265
265
|
"complexType": {
|
|
266
266
|
"original": "DemoData<CopyTextViewProps>",
|
|
267
|
-
"resolved": "{ loading?: boolean; copyString?: string; tooltiptext?: string; open?: boolean; copyButtonLabel?: string; disabled?: boolean; textAlign?: \"left\" | \"right\" | \"center\"; buttonStyle?: \"icon\" | \"button-outside\" | \"button-below\"; error?: boolean; errorText?: string; notificationText?: string; showNotificationText?: boolean; inputPlaceholderText?: string; dateAvailable?: string; onClick?: () => void; }",
|
|
267
|
+
"resolved": "{ loading?: boolean; copyString?: string; tooltiptext?: string; open?: boolean; copyButtonLabel?: string; disabled?: boolean; textAlign?: \"left\" | \"right\" | \"center\"; buttonStyle?: \"icon\" | \"button-outside\" | \"button-below\"; error?: boolean; errorText?: string; notificationText?: string; showNotificationText?: boolean; inputPlaceholderText?: string; dateAvailable?: string; isCopied?: boolean; onClick?: () => void; }",
|
|
268
268
|
"references": {
|
|
269
269
|
"DemoData": {
|
|
270
270
|
"location": "import",
|
|
@@ -302,6 +302,8 @@ function useDemoReferralCode(props) {
|
|
|
302
302
|
buttonStyle: props.buttonStyle,
|
|
303
303
|
notificationText: props.notificationText,
|
|
304
304
|
showNotificationText: props.showNotificationText,
|
|
305
|
+
isCopied: props.showNotificationText,
|
|
306
|
+
isUsed: false,
|
|
305
307
|
rewardStatus: "AVAILABLE",
|
|
306
308
|
open,
|
|
307
309
|
onClick: () => {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { useEngagementMedium, useMutation, useParentValue, useProgramId, useQuery, useUserIdentity, } from "@saasquatch/component-boilerplate";
|
|
2
2
|
import { useState } from "@saasquatch/universal-hooks";
|
|
3
3
|
import { gql } from "graphql-request";
|
|
4
|
-
import { REFERRAL_CODES_NAMESPACE,
|
|
4
|
+
import { REFERRAL_CODES_NAMESPACE, SET_CODE_COPIED, } from "../sqm-referral-codes/useReferralCodes";
|
|
5
5
|
const MessageLinkQuery = gql `
|
|
6
6
|
query ($programId: ID) {
|
|
7
7
|
user: viewer {
|
|
@@ -24,14 +24,15 @@ export function useReferralCode(props) {
|
|
|
24
24
|
const contextData = useParentValue(REFERRAL_CODES_NAMESPACE);
|
|
25
25
|
const { data } = useQuery(MessageLinkQuery, { programId }, !(user === null || user === void 0 ? void 0 : user.jwt) || (contextData === null || contextData === void 0 ? void 0 : contextData.referralCode) !== undefined);
|
|
26
26
|
const [sendLoadEvent] = useMutation(WIDGET_ENGAGEMENT_EVENT);
|
|
27
|
-
const [
|
|
27
|
+
const [setCopied, copiedRes] = useMutation(SET_CODE_COPIED);
|
|
28
28
|
const copyString = (_b = ((contextData === null || contextData === void 0 ? void 0 : contextData.referralCode) || ((_a = data === null || data === void 0 ? void 0 : data.user) === null || _a === void 0 ? void 0 : _a.referralCode))) !== null && _b !== void 0 ? _b :
|
|
29
29
|
// Shown during loading
|
|
30
30
|
"...";
|
|
31
31
|
const [open, setOpen] = useState(false);
|
|
32
|
-
function onClick() {
|
|
32
|
+
async function onClick() {
|
|
33
33
|
if (contextData) {
|
|
34
|
-
|
|
34
|
+
await setCopied({ referralCode: contextData.referralCode });
|
|
35
|
+
contextData.refresh();
|
|
35
36
|
}
|
|
36
37
|
// Should well supported: https://developer.mozilla.org/en-US/docs/Web/API/Clipboard#browser_compatibility
|
|
37
38
|
// Only if called from a user-initiated event
|
|
@@ -51,5 +52,11 @@ export function useReferralCode(props) {
|
|
|
51
52
|
},
|
|
52
53
|
});
|
|
53
54
|
}
|
|
54
|
-
return {
|
|
55
|
+
return {
|
|
56
|
+
...props,
|
|
57
|
+
onClick,
|
|
58
|
+
open,
|
|
59
|
+
copyString: copyString,
|
|
60
|
+
isCopied: contextData === null || contextData === void 0 ? void 0 : contextData.isCopied,
|
|
61
|
+
};
|
|
55
62
|
}
|
|
@@ -6,6 +6,12 @@ export default {
|
|
|
6
6
|
scenario,
|
|
7
7
|
},
|
|
8
8
|
};
|
|
9
|
+
const demoData = {
|
|
10
|
+
states: {
|
|
11
|
+
noCodes: false,
|
|
12
|
+
loading: false,
|
|
13
|
+
},
|
|
14
|
+
};
|
|
9
15
|
const pagination = (slot) => {
|
|
10
16
|
return h("sqm-pagination", { slot: slot });
|
|
11
17
|
};
|
|
@@ -33,3 +39,15 @@ export const WithPreviouslyCopiedCode = () => {
|
|
|
33
39
|
shareCodeWithPreviouslyCopied("shareCodes"),
|
|
34
40
|
shareButtons("shareButtons")));
|
|
35
41
|
};
|
|
42
|
+
export const Empty = () => {
|
|
43
|
+
return (h("sqm-referral-codes", { demoData: { states: { ...demoData.states, noCodes: true } } },
|
|
44
|
+
pagination("pagination"),
|
|
45
|
+
shareCodes("shareCodes"),
|
|
46
|
+
shareButtons("shareButtons")));
|
|
47
|
+
};
|
|
48
|
+
export const Loading = () => {
|
|
49
|
+
return (h("sqm-referral-codes", { demoData: { states: { ...demoData.states, loading: true } } },
|
|
50
|
+
pagination("pagination"),
|
|
51
|
+
shareCodes("shareCodes"),
|
|
52
|
+
shareButtons("shareButtons")));
|
|
53
|
+
};
|
|
@@ -46,7 +46,18 @@ const vanillaStyle = `
|
|
|
46
46
|
const sheet = createStyleSheet(style);
|
|
47
47
|
const styleString = sheet.toString();
|
|
48
48
|
export function ReferralCodesView(props) {
|
|
49
|
-
const { slots, titleText } = props;
|
|
49
|
+
const { slots, titleText, states } = props;
|
|
50
|
+
const getSlotContent = (states) => {
|
|
51
|
+
if (states.noCodes) {
|
|
52
|
+
return slots.empty;
|
|
53
|
+
}
|
|
54
|
+
if (states.loading) {
|
|
55
|
+
return slots.loading;
|
|
56
|
+
}
|
|
57
|
+
return (h("div", { class: sheet.classes.Wrapper },
|
|
58
|
+
h("div", { class: sheet.classes.ShareCodeContainer }, slots.shareCodes),
|
|
59
|
+
h("div", { class: sheet.classes.ShareButtonContainer }, slots.shareButtons)));
|
|
60
|
+
};
|
|
50
61
|
return (h("div", { class: sheet.classes.Wrapper, part: "sqm-base" },
|
|
51
62
|
h("style", { type: "text/css" },
|
|
52
63
|
vanillaStyle,
|
|
@@ -54,6 +65,5 @@ export function ReferralCodesView(props) {
|
|
|
54
65
|
h("div", { class: sheet.classes.HeaderContainer },
|
|
55
66
|
h("h2", { class: sheet.classes.TitleText }, titleText),
|
|
56
67
|
slots.pagination),
|
|
57
|
-
|
|
58
|
-
h("div", { class: sheet.classes.ShareButtonContainer }, slots.shareButtons)));
|
|
68
|
+
getSlotContent(states)));
|
|
59
69
|
}
|
|
@@ -3,19 +3,20 @@ import { withHooks } from "@saasquatch/stencil-hooks";
|
|
|
3
3
|
import { Component, Prop, h } from "@stencil/core";
|
|
4
4
|
import deepmerge from "deepmerge";
|
|
5
5
|
import { getProps } from "../../utils/utils";
|
|
6
|
-
import { useReferralCodes } from "./useReferralCodes";
|
|
7
6
|
import { ReferralCodesView, } from "./sqm-referral-codes-view";
|
|
7
|
+
import { useReferralCodes } from "./useReferralCodes";
|
|
8
8
|
/**
|
|
9
9
|
* @uiName Referral Codes
|
|
10
|
+
* @slots [{"name":"", "title":"Promo Codes Content"}]
|
|
10
11
|
* @exampleGroup Sharing
|
|
11
|
-
* @example Referral Codes - <sqm-referral-codes><sqm-pagination slot="pagination"></sqm-pagination><sqm-referral-code slot="shareCodes"></sqm-referral-code><sqm-portal-container gap="small" slot="shareButtons"><sqm-share-button medium="email">Share via email</sqm-share-button><sqm-share-button medium="
|
|
12
|
+
* @example Referral Codes - <sqm-referral-codes><sqm-pagination slot="pagination"></sqm-pagination><sqm-referral-code slot="shareCodes"></sqm-referral-code><sqm-portal-container gap="small" slot="shareButtons"><sqm-share-button medium="email">Share via email</sqm-share-button><sqm-share-button medium="fbmessenger">Share on Facebook</sqm-share-button><sqm-share-button medium="whatsapp">Share on WhatsApp</sqm-share-button></sqm-portal-container></sqm-referral-codes>
|
|
12
13
|
*/
|
|
13
14
|
export class ReferralCodes {
|
|
14
15
|
constructor() {
|
|
15
16
|
/**
|
|
16
17
|
* @uiName Title Text
|
|
17
18
|
*/
|
|
18
|
-
this.titleText = "
|
|
19
|
+
this.titleText = "Start sharing";
|
|
19
20
|
withHooks(this);
|
|
20
21
|
}
|
|
21
22
|
disconnectedCallback() { }
|
|
@@ -29,10 +30,14 @@ export class ReferralCodes {
|
|
|
29
30
|
shareButtons: h("slot", { name: "shareButtons" }),
|
|
30
31
|
shareCodes: h("slot", { name: "shareCodes" }),
|
|
31
32
|
pagination: h("slot", { name: "pagination" }),
|
|
33
|
+
empty: h(EmptySlot, null),
|
|
34
|
+
loading: h(LoadingSlot, null),
|
|
32
35
|
};
|
|
33
36
|
const viewProps = {
|
|
34
37
|
slots,
|
|
35
38
|
...props,
|
|
39
|
+
loading: props.states.loading,
|
|
40
|
+
noCodes: props.states.noCodes,
|
|
36
41
|
};
|
|
37
42
|
return h(ReferralCodesView, Object.assign({}, viewProps));
|
|
38
43
|
}
|
|
@@ -58,14 +63,37 @@ export class ReferralCodes {
|
|
|
58
63
|
},
|
|
59
64
|
"attribute": "title-text",
|
|
60
65
|
"reflect": false,
|
|
61
|
-
"defaultValue": "\"
|
|
66
|
+
"defaultValue": "\"Start sharing\""
|
|
67
|
+
},
|
|
68
|
+
"programId": {
|
|
69
|
+
"type": "string",
|
|
70
|
+
"mutable": false,
|
|
71
|
+
"complexType": {
|
|
72
|
+
"original": "string",
|
|
73
|
+
"resolved": "string",
|
|
74
|
+
"references": {}
|
|
75
|
+
},
|
|
76
|
+
"required": false,
|
|
77
|
+
"optional": true,
|
|
78
|
+
"docs": {
|
|
79
|
+
"tags": [{
|
|
80
|
+
"text": "Program ID",
|
|
81
|
+
"name": "uiName"
|
|
82
|
+
}, {
|
|
83
|
+
"text": "programSelector",
|
|
84
|
+
"name": "uiWidget"
|
|
85
|
+
}],
|
|
86
|
+
"text": ""
|
|
87
|
+
},
|
|
88
|
+
"attribute": "program-id",
|
|
89
|
+
"reflect": false
|
|
62
90
|
},
|
|
63
91
|
"demoData": {
|
|
64
92
|
"type": "unknown",
|
|
65
93
|
"mutable": false,
|
|
66
94
|
"complexType": {
|
|
67
95
|
"original": "DemoData<ReferralCodesViewProps>",
|
|
68
|
-
"resolved": "{ slots?: { shareButtons: VNode; shareCodes: VNode; pagination: VNode; }; titleText?: string; }",
|
|
96
|
+
"resolved": "{ states?: { noCodes: boolean; loading: boolean; }; slots?: { shareButtons: VNode; shareCodes: VNode; pagination: VNode; empty: VNode; loading: VNode; }; titleText?: string; }",
|
|
69
97
|
"references": {
|
|
70
98
|
"DemoData": {
|
|
71
99
|
"location": "import",
|
|
@@ -92,8 +120,26 @@ export class ReferralCodes {
|
|
|
92
120
|
}
|
|
93
121
|
}; }
|
|
94
122
|
}
|
|
123
|
+
function EmptySlot() {
|
|
124
|
+
return (h("slot", { name: "empty" },
|
|
125
|
+
h("sqm-empty", { emptyStateHeader: "Your new codes and links aren\u2019t ready yet", emptyStateText: "Please contact our program support team to let them know you\u2019re out of codes." })));
|
|
126
|
+
}
|
|
127
|
+
function LoadingSlot() {
|
|
128
|
+
return (h("slot", { name: "loading" },
|
|
129
|
+
h(LoadingRow, null),
|
|
130
|
+
h(LoadingRow, null),
|
|
131
|
+
h(LoadingRow, null),
|
|
132
|
+
h(LoadingRow, null)));
|
|
133
|
+
}
|
|
134
|
+
function LoadingRow() {
|
|
135
|
+
return h("sl-skeleton", { style: { width: "100%" } });
|
|
136
|
+
}
|
|
95
137
|
function useDemoReferralCodes(props) {
|
|
96
138
|
return deepmerge({
|
|
97
139
|
titleText: props.titleText,
|
|
140
|
+
states: {
|
|
141
|
+
noCodes: false,
|
|
142
|
+
loading: false,
|
|
143
|
+
},
|
|
98
144
|
}, props.demoData || {}, { arrayMerge: (_, a) => a });
|
|
99
145
|
}
|
|
@@ -1,19 +1,40 @@
|
|
|
1
|
-
import { usePaginatedQuery, useParentState, useUserIdentity, } from "@saasquatch/component-boilerplate";
|
|
2
|
-
import { gql } from "graphql-request";
|
|
1
|
+
import { useEngagementMedium, usePaginatedQuery, useParentState, useProgramId, useRefreshDispatcher, useUserIdentity, } from "@saasquatch/component-boilerplate";
|
|
3
2
|
import { useEffect } from "@saasquatch/universal-hooks";
|
|
3
|
+
import { gql } from "graphql-request";
|
|
4
4
|
const GET_REFERRAL_CODES = gql `
|
|
5
|
-
query getCodes(
|
|
5
|
+
query getCodes(
|
|
6
|
+
$engagementMedium: UserEngagementMedium!
|
|
7
|
+
$limit: Int!
|
|
8
|
+
$offset: Int!
|
|
9
|
+
$filter: ReferralCodeFilterInput
|
|
10
|
+
) {
|
|
6
11
|
viewer {
|
|
7
12
|
... on User {
|
|
8
|
-
referralCodeList(limit: $limit, offset: $offset) {
|
|
13
|
+
referralCodeList(limit: $limit, offset: $offset, filter: $filter) {
|
|
9
14
|
data {
|
|
10
15
|
code
|
|
11
16
|
dateUsed
|
|
12
17
|
dateCopied
|
|
13
|
-
|
|
18
|
+
singleUse
|
|
19
|
+
shareLinkCodes(limit: $limit) {
|
|
14
20
|
data {
|
|
15
21
|
linkCode
|
|
16
|
-
shortUrl
|
|
22
|
+
shareLink: shortUrl(
|
|
23
|
+
shareMedium: DIRECT
|
|
24
|
+
engagementMedium: EMBED
|
|
25
|
+
)
|
|
26
|
+
email: shortUrl(
|
|
27
|
+
shareMedium: EMAIL
|
|
28
|
+
engagementMedium: $engagementMedium
|
|
29
|
+
)
|
|
30
|
+
whatsApp: shortUrl(
|
|
31
|
+
shareMedium: WHATSAPP
|
|
32
|
+
engagementMedium: $engagementMedium
|
|
33
|
+
)
|
|
34
|
+
fbMessenger: shortUrl(
|
|
35
|
+
shareMedium: FBMESSENGER
|
|
36
|
+
engagementMedium: $engagementMedium
|
|
37
|
+
)
|
|
17
38
|
}
|
|
18
39
|
}
|
|
19
40
|
}
|
|
@@ -26,16 +47,32 @@ const GET_REFERRAL_CODES = gql `
|
|
|
26
47
|
`;
|
|
27
48
|
export const REFERRAL_CODES_NAMESPACE = "sq:referral-codes";
|
|
28
49
|
export const REFERRAL_CODES_PAGINATION_CONTEXT = "sq:referral-codes-pagination";
|
|
29
|
-
export const
|
|
30
|
-
mutation
|
|
50
|
+
export const SET_CODE_COPIED = gql `
|
|
51
|
+
mutation markReferralCodeCopied($referralCode: String!) {
|
|
52
|
+
markReferralCodeCopied(referralCode: $referralCode) {
|
|
53
|
+
referralCode {
|
|
54
|
+
dateCopied
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
31
58
|
`;
|
|
32
59
|
export function useReferralCodes(props) {
|
|
33
60
|
const user = useUserIdentity();
|
|
34
|
-
|
|
61
|
+
const engagementMedium = useEngagementMedium();
|
|
62
|
+
const programId = props.programId || useProgramId();
|
|
63
|
+
const { refresh } = useRefreshDispatcher();
|
|
35
64
|
const { envelope: referralData, states, callbacks, } = usePaginatedQuery(GET_REFERRAL_CODES, (data) => { var _a; return (_a = data === null || data === void 0 ? void 0 : data.viewer) === null || _a === void 0 ? void 0 : _a.referralCodeList; }, {
|
|
36
65
|
limit: 1,
|
|
37
66
|
offset: 0,
|
|
38
|
-
}, {
|
|
67
|
+
}, {
|
|
68
|
+
engagementMedium,
|
|
69
|
+
programId,
|
|
70
|
+
filter: {
|
|
71
|
+
fuelTank_eq: true,
|
|
72
|
+
programId_eq: programId,
|
|
73
|
+
dateUsed_exists: false,
|
|
74
|
+
},
|
|
75
|
+
}, !(user === null || user === void 0 ? void 0 : user.jwt));
|
|
39
76
|
const [paginationContext, setPaginationContext] = useParentState({
|
|
40
77
|
namespace: REFERRAL_CODES_PAGINATION_CONTEXT,
|
|
41
78
|
initialValue: { states, callbacks },
|
|
@@ -43,44 +80,49 @@ export function useReferralCodes(props) {
|
|
|
43
80
|
const [referralCodesContext, setReferralCodesContext] = useParentState({
|
|
44
81
|
namespace: REFERRAL_CODES_NAMESPACE,
|
|
45
82
|
initialValue: {
|
|
83
|
+
refresh,
|
|
46
84
|
loading: true,
|
|
47
85
|
referralCode: "",
|
|
48
86
|
shareLink: "",
|
|
87
|
+
isCopied: false,
|
|
88
|
+
isUsed: false,
|
|
49
89
|
email: {
|
|
50
90
|
messageLink: "",
|
|
51
91
|
},
|
|
52
|
-
|
|
92
|
+
fbmessenger: {
|
|
53
93
|
messageLink: "",
|
|
54
94
|
shareLink: "",
|
|
55
95
|
},
|
|
56
|
-
|
|
96
|
+
whatsapp: { messageLink: "" },
|
|
57
97
|
},
|
|
58
98
|
});
|
|
59
99
|
useEffect(() => {
|
|
60
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
|
100
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r;
|
|
61
101
|
if ((_a = referralData === null || referralData === void 0 ? void 0 : referralData.data) === null || _a === void 0 ? void 0 : _a.length) {
|
|
62
102
|
const data = referralData.data[0];
|
|
63
103
|
setReferralCodesContext({
|
|
104
|
+
refresh,
|
|
64
105
|
referralCode: data.code,
|
|
65
|
-
|
|
106
|
+
isCopied: !!data.dateCopied,
|
|
107
|
+
isUsed: !!data.dateUsed,
|
|
108
|
+
shareLink: (_d = (_c = (_b = data.shareLinkCodes) === null || _b === void 0 ? void 0 : _b.data) === null || _c === void 0 ? void 0 : _c[0]) === null || _d === void 0 ? void 0 : _d.direct,
|
|
66
109
|
email: {
|
|
67
|
-
messageLink: (
|
|
110
|
+
messageLink: (_g = (_f = (_e = data.shareLinkCodes) === null || _e === void 0 ? void 0 : _e.data) === null || _f === void 0 ? void 0 : _f[0]) === null || _g === void 0 ? void 0 : _g.email,
|
|
68
111
|
},
|
|
69
|
-
|
|
70
|
-
messageLink: (
|
|
71
|
-
shareLink: (
|
|
112
|
+
fbmessenger: {
|
|
113
|
+
messageLink: (_k = (_j = (_h = data.shareLinkCodes) === null || _h === void 0 ? void 0 : _h.data) === null || _j === void 0 ? void 0 : _j[0]) === null || _k === void 0 ? void 0 : _k.fbMessenger,
|
|
114
|
+
shareLink: (_o = (_m = (_l = data.shareLinkCodes) === null || _l === void 0 ? void 0 : _l.data) === null || _m === void 0 ? void 0 : _m[0]) === null || _o === void 0 ? void 0 : _o.fbMessenger,
|
|
72
115
|
},
|
|
73
|
-
|
|
116
|
+
whatsapp: { messageLink: (_r = (_q = (_p = data.shareLinkCodes) === null || _p === void 0 ? void 0 : _p.data) === null || _q === void 0 ? void 0 : _q[0]) === null || _r === void 0 ? void 0 : _r.whatsApp },
|
|
74
117
|
});
|
|
118
|
+
setPaginationContext({ states, callbacks });
|
|
75
119
|
}
|
|
76
120
|
}, [referralData]);
|
|
77
|
-
useEffect(() => {
|
|
78
|
-
setPaginationContext({ states, callbacks });
|
|
79
|
-
}, [states]);
|
|
80
121
|
console.log({ referralData, states });
|
|
81
122
|
return {
|
|
82
123
|
states: {
|
|
83
124
|
...states,
|
|
125
|
+
noCodes: (referralData === null || referralData === void 0 ? void 0 : referralData.totalCount) === 0,
|
|
84
126
|
},
|
|
85
127
|
data: referralCodesContext,
|
|
86
128
|
callbacks: {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { useEngagementMedium, useUserIdentity, useQuery, useParentValue, useMutation, } from "@saasquatch/component-boilerplate";
|
|
2
2
|
import { gql } from "graphql-request";
|
|
3
3
|
import { useProgramId, getEnvironmentSDK, } from "@saasquatch/component-boilerplate";
|
|
4
|
-
import { REFERRAL_CODES_NAMESPACE,
|
|
4
|
+
import { REFERRAL_CODES_NAMESPACE, SET_CODE_COPIED, } from "../sqm-referral-codes/useReferralCodes";
|
|
5
5
|
const MessageLinkQuery = gql `
|
|
6
6
|
query (
|
|
7
7
|
$programId: ID
|
|
@@ -58,25 +58,27 @@ export function useShareButton(props) {
|
|
|
58
58
|
const { sharetitle, sharetext, medium } = props;
|
|
59
59
|
const programId = props.programId ? props.programId : useProgramId();
|
|
60
60
|
const user = useUserIdentity();
|
|
61
|
+
const engagementMedium = useEngagementMedium();
|
|
61
62
|
const variables = {
|
|
62
|
-
engagementMedium
|
|
63
|
+
engagementMedium,
|
|
63
64
|
programId: programId,
|
|
64
65
|
shareMedium: medium.toUpperCase(),
|
|
65
66
|
};
|
|
66
|
-
const
|
|
67
|
-
const overrideData =
|
|
67
|
+
const contextData = useParentValue(REFERRAL_CODES_NAMESPACE);
|
|
68
|
+
const overrideData = contextData === null || contextData === void 0 ? void 0 : contextData[medium];
|
|
68
69
|
// only queries if a programId is available
|
|
69
70
|
const res = useQuery(MessageLinkQuery, variables, !(user === null || user === void 0 ? void 0 : user.jwt) || !programId || overrideData !== undefined);
|
|
70
|
-
const [
|
|
71
|
+
const [setCopied, copiedRes] = useMutation(SET_CODE_COPIED);
|
|
71
72
|
const directLink = (overrideData === null || overrideData === void 0 ? void 0 : overrideData.shareLink) || ((_b = (_a = res === null || res === void 0 ? void 0 : res.data) === null || _a === void 0 ? void 0 : _a.viewer) === null || _b === void 0 ? void 0 : _b.shareLink);
|
|
72
73
|
const environment = getEnvironmentSDK();
|
|
73
74
|
const hide = (medium.toLocaleUpperCase() === "SMS" &&
|
|
74
75
|
window.orientation === undefined) ||
|
|
75
76
|
(medium.toLocaleUpperCase() === "DIRECT" && !window.navigator.share);
|
|
76
|
-
function onClick() {
|
|
77
|
+
async function onClick() {
|
|
77
78
|
var _a, _b, _c, _d;
|
|
78
79
|
if (overrideData) {
|
|
79
|
-
|
|
80
|
+
await setCopied({ referralCode: contextData.referralCode });
|
|
81
|
+
contextData.refresh();
|
|
80
82
|
}
|
|
81
83
|
if (medium.toLocaleUpperCase() === "FACEBOOK" &&
|
|
82
84
|
environment.type === "SquatchAndroid") {
|
|
@@ -89,5 +91,10 @@ export function useShareButton(props) {
|
|
|
89
91
|
GenericShare((overrideData === null || overrideData === void 0 ? void 0 : overrideData.messageLink) || ((_d = (_c = res.data) === null || _c === void 0 ? void 0 : _c.viewer) === null || _d === void 0 ? void 0 : _d.messageLink), props.errorText);
|
|
90
92
|
}
|
|
91
93
|
}
|
|
92
|
-
return {
|
|
94
|
+
return {
|
|
95
|
+
...props,
|
|
96
|
+
loading: res.loading && !(overrideData === null || overrideData === void 0 ? void 0 : overrideData.messageLink),
|
|
97
|
+
onClick,
|
|
98
|
+
hide,
|
|
99
|
+
};
|
|
93
100
|
}
|
|
@@ -210,7 +210,7 @@ export class ShareCode {
|
|
|
210
210
|
"mutable": false,
|
|
211
211
|
"complexType": {
|
|
212
212
|
"original": "DemoData<CopyTextViewProps>",
|
|
213
|
-
"resolved": "{ loading?: boolean; copyString?: string; tooltiptext?: string; open?: boolean; copyButtonLabel?: string; disabled?: boolean; textAlign?: \"left\" | \"right\" | \"center\"; buttonStyle?: \"icon\" | \"button-outside\" | \"button-below\"; error?: boolean; errorText?: string; notificationText?: string; showNotificationText?: boolean; inputPlaceholderText?: string; dateAvailable?: string; onClick?: () => void; }",
|
|
213
|
+
"resolved": "{ loading?: boolean; copyString?: string; tooltiptext?: string; open?: boolean; copyButtonLabel?: string; disabled?: boolean; textAlign?: \"left\" | \"right\" | \"center\"; buttonStyle?: \"icon\" | \"button-outside\" | \"button-below\"; error?: boolean; errorText?: string; notificationText?: string; showNotificationText?: boolean; inputPlaceholderText?: string; dateAvailable?: string; isCopied?: boolean; onClick?: () => void; }",
|
|
214
214
|
"references": {
|
|
215
215
|
"DemoData": {
|
|
216
216
|
"location": "import",
|
|
@@ -210,7 +210,7 @@ export class ShareLink {
|
|
|
210
210
|
"mutable": false,
|
|
211
211
|
"complexType": {
|
|
212
212
|
"original": "DemoData<CopyTextViewProps>",
|
|
213
|
-
"resolved": "{ loading?: boolean; copyString?: string; tooltiptext?: string; open?: boolean; copyButtonLabel?: string; disabled?: boolean; textAlign?: \"left\" | \"right\" | \"center\"; buttonStyle?: \"icon\" | \"button-outside\" | \"button-below\"; error?: boolean; errorText?: string; notificationText?: string; showNotificationText?: boolean; inputPlaceholderText?: string; dateAvailable?: string; onClick?: () => void; }",
|
|
213
|
+
"resolved": "{ loading?: boolean; copyString?: string; tooltiptext?: string; open?: boolean; copyButtonLabel?: string; disabled?: boolean; textAlign?: \"left\" | \"right\" | \"center\"; buttonStyle?: \"icon\" | \"button-outside\" | \"button-below\"; error?: boolean; errorText?: string; notificationText?: string; showNotificationText?: boolean; inputPlaceholderText?: string; dateAvailable?: string; isCopied?: boolean; onClick?: () => void; }",
|
|
214
214
|
"references": {
|
|
215
215
|
"DemoData": {
|
|
216
216
|
"location": "import",
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { useEngagementMedium, useMutation, useParentValue, useProgramId, useQuery, useUserIdentity, } from "@saasquatch/component-boilerplate";
|
|
2
2
|
import { useState } from "@saasquatch/universal-hooks";
|
|
3
3
|
import { gql } from "graphql-request";
|
|
4
|
-
import { REFERRAL_CODES_NAMESPACE,
|
|
4
|
+
import { REFERRAL_CODES_NAMESPACE, SET_CODE_COPIED, } from "../sqm-referral-codes/useReferralCodes";
|
|
5
5
|
const MessageLinkQuery = gql `
|
|
6
6
|
query ($programId: ID, $engagementMedium: UserEngagementMedium!) {
|
|
7
7
|
user: viewer {
|
|
@@ -28,14 +28,15 @@ export function useShareLink(props) {
|
|
|
28
28
|
const contextData = useParentValue(REFERRAL_CODES_NAMESPACE);
|
|
29
29
|
const { data } = useQuery(MessageLinkQuery, { programId, engagementMedium }, !(user === null || user === void 0 ? void 0 : user.jwt) || !!props.linkOverride || (contextData === null || contextData === void 0 ? void 0 : contextData.shareLink) !== undefined);
|
|
30
30
|
const [sendLoadEvent] = useMutation(WIDGET_ENGAGEMENT_EVENT);
|
|
31
|
-
const [
|
|
31
|
+
const [setCopied, copiedRes] = useMutation(SET_CODE_COPIED);
|
|
32
32
|
const copyString = (_b = ((contextData === null || contextData === void 0 ? void 0 : contextData.shareLink) || ((_a = data === null || data === void 0 ? void 0 : data.user) === null || _a === void 0 ? void 0 : _a.shareLink))) !== null && _b !== void 0 ? _b :
|
|
33
33
|
// Shown during loading
|
|
34
34
|
"...";
|
|
35
35
|
const [open, setOpen] = useState(false);
|
|
36
|
-
function onClick() {
|
|
36
|
+
async function onClick() {
|
|
37
37
|
if (contextData) {
|
|
38
|
-
|
|
38
|
+
await setCopied({ referralCode: contextData.referralCode });
|
|
39
|
+
contextData.refresh();
|
|
39
40
|
}
|
|
40
41
|
// Should well supported: https://developer.mozilla.org/en-US/docs/Web/API/Clipboard#browser_compatibility
|
|
41
42
|
// Only if called from a user-initiated event
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { h } from "@stencil/core";
|
|
2
|
-
import { createStyleSheet } from "../../styling/JSS";
|
|
3
2
|
import { HostBlock } from "../../global/mixins";
|
|
3
|
+
import { createStyleSheet } from "../../styling/JSS";
|
|
4
4
|
const style = {
|
|
5
5
|
HostBlock: HostBlock,
|
|
6
6
|
inputStyle: {
|
|
@@ -86,5 +86,7 @@ export function CopyTextView(props) {
|
|
|
86
86
|
error && (h("p", { slot: "help-text", class: sheet.classes.errorTextStyle }, props.errorText))),
|
|
87
87
|
(buttonStyle === "button-outside" || buttonStyle === "button-below") &&
|
|
88
88
|
copyButton),
|
|
89
|
-
props.
|
|
89
|
+
props.isCopied &&
|
|
90
|
+
props.showNotificationText &&
|
|
91
|
+
props.notificationText && (h("p", { part: "sqm-notification-text", class: sheet.classes.notificationTextStyle }, props.notificationText))));
|
|
90
92
|
}
|