@crossmint/client-sdk-react-ui 0.0.8-alpha.2 → 0.1.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 +201 -201
- package/README.md +18 -12
- package/lib/cjs/CrossmintPayButton.d.ts +3 -0
- package/lib/cjs/CrossmintPayButton.js +87 -0
- package/lib/cjs/CrossmintPayButton.js.map +1 -0
- package/lib/cjs/CrossmintStatusButton.d.ts +3 -0
- package/lib/cjs/CrossmintStatusButton.js +71 -0
- package/lib/cjs/CrossmintStatusButton.js.map +1 -0
- package/lib/cjs/hooks/useCrossmintModal.d.ts +12 -0
- package/lib/cjs/hooks/useCrossmintModal.js +90 -0
- package/lib/cjs/hooks/useCrossmintModal.js.map +1 -0
- package/lib/cjs/{useCrossMintStatus.d.ts → hooks/useCrossmintStatus.d.ts} +19 -16
- package/lib/cjs/hooks/useCrossmintStatus.js +75 -0
- package/lib/cjs/hooks/useCrossmintStatus.js.map +1 -0
- package/lib/cjs/index.d.ts +2 -7
- package/lib/cjs/index.js +14 -19
- package/lib/cjs/index.js.map +1 -1
- package/lib/cjs/package.json +1 -3
- package/lib/cjs/styles/index.d.ts +9 -0
- package/lib/cjs/styles/index.js +45 -0
- package/lib/cjs/styles/index.js.map +1 -0
- package/lib/cjs/types.d.ts +48 -0
- package/lib/cjs/types.js +29 -0
- package/lib/cjs/types.js.map +1 -0
- package/lib/cjs/utils.d.ts +1 -0
- package/lib/cjs/utils.js +5 -0
- package/lib/cjs/utils.js.map +1 -0
- package/lib/cjs/version.d.ts +1 -0
- package/lib/cjs/version.js +5 -0
- package/lib/cjs/version.js.map +1 -0
- package/lib/esm/CrossmintPayButton.d.ts +3 -0
- package/lib/esm/CrossmintPayButton.js +49 -0
- package/lib/esm/CrossmintPayButton.js.map +1 -0
- package/lib/esm/CrossmintStatusButton.d.ts +3 -0
- package/lib/esm/CrossmintStatusButton.js +36 -0
- package/lib/esm/CrossmintStatusButton.js.map +1 -0
- package/lib/esm/hooks/useCrossmintModal.d.ts +12 -0
- package/lib/esm/hooks/useCrossmintModal.js +87 -0
- package/lib/esm/hooks/useCrossmintModal.js.map +1 -0
- package/lib/esm/{useCrossMintStatus.d.ts → hooks/useCrossmintStatus.d.ts} +19 -16
- package/lib/esm/hooks/useCrossmintStatus.js +60 -0
- package/lib/esm/hooks/useCrossmintStatus.js.map +1 -0
- package/lib/esm/index.d.ts +2 -7
- package/lib/esm/index.js +2 -7
- package/lib/esm/index.js.map +1 -1
- package/lib/esm/package.json +1 -3
- package/lib/esm/styles/index.d.ts +9 -0
- package/lib/esm/styles/index.js +41 -0
- package/lib/esm/styles/index.js.map +1 -0
- package/lib/esm/types.d.ts +48 -0
- package/lib/esm/types.js +26 -0
- package/lib/esm/types.js.map +1 -0
- package/lib/esm/utils.d.ts +1 -0
- package/lib/esm/utils.js +2 -0
- package/lib/esm/utils.js.map +1 -0
- package/lib/esm/version.d.ts +1 -0
- package/lib/esm/version.js +2 -0
- package/lib/esm/version.js.map +1 -0
- package/package.json +12 -8
- package/src/CrossmintPayButton.tsx +108 -0
- package/src/CrossmintStatusButton.tsx +77 -0
- package/src/hooks/useCrossmintModal.ts +143 -0
- package/src/hooks/useCrossmintStatus.ts +85 -0
- package/src/index.ts +2 -7
- package/src/styles/index.ts +50 -0
- package/src/types.ts +56 -0
- package/src/utils.ts +1 -0
- package/src/version.ts +1 -0
- package/lib/cjs/CrossMintButton.d.ts +0 -16
- package/lib/cjs/CrossMintButton.js +0 -60
- package/lib/cjs/CrossMintButton.js.map +0 -1
- package/lib/cjs/CrossMintModal.d.ts +0 -6
- package/lib/cjs/CrossMintModal.js +0 -55
- package/lib/cjs/CrossMintModal.js.map +0 -1
- package/lib/cjs/CrossMintModalProvider.d.ts +0 -6
- package/lib/cjs/CrossMintModalProvider.js +0 -48
- package/lib/cjs/CrossMintModalProvider.js.map +0 -1
- package/lib/cjs/CrossMintPopupProvider.d.ts +0 -6
- package/lib/cjs/CrossMintPopupProvider.js +0 -70
- package/lib/cjs/CrossMintPopupProvider.js.map +0 -1
- package/lib/cjs/CrossMintProvider.d.ts +0 -10
- package/lib/cjs/CrossMintProvider.js +0 -52
- package/lib/cjs/CrossMintProvider.js.map +0 -1
- package/lib/cjs/CrossMintStatusButton.d.ts +0 -10
- package/lib/cjs/CrossMintStatusButton.js +0 -66
- package/lib/cjs/CrossMintStatusButton.js.map +0 -1
- package/lib/cjs/CrossMintStatusProvider.d.ts +0 -8
- package/lib/cjs/CrossMintStatusProvider.js +0 -66
- package/lib/cjs/CrossMintStatusProvider.js.map +0 -1
- package/lib/cjs/useCrossMintModal.d.ts +0 -7
- package/lib/cjs/useCrossMintModal.js +0 -10
- package/lib/cjs/useCrossMintModal.js.map +0 -1
- package/lib/cjs/useCrossMintPopup.d.ts +0 -8
- package/lib/cjs/useCrossMintPopup.js +0 -10
- package/lib/cjs/useCrossMintPopup.js.map +0 -1
- package/lib/cjs/useCrossMintStatus.js +0 -18
- package/lib/cjs/useCrossMintStatus.js.map +0 -1
- package/lib/esm/CrossMintButton.d.ts +0 -16
- package/lib/esm/CrossMintButton.js +0 -25
- package/lib/esm/CrossMintButton.js.map +0 -1
- package/lib/esm/CrossMintModal.d.ts +0 -6
- package/lib/esm/CrossMintModal.js +0 -32
- package/lib/esm/CrossMintModal.js.map +0 -1
- package/lib/esm/CrossMintModalProvider.d.ts +0 -6
- package/lib/esm/CrossMintModalProvider.js +0 -13
- package/lib/esm/CrossMintModalProvider.js.map +0 -1
- package/lib/esm/CrossMintPopupProvider.d.ts +0 -6
- package/lib/esm/CrossMintPopupProvider.js +0 -47
- package/lib/esm/CrossMintPopupProvider.js.map +0 -1
- package/lib/esm/CrossMintProvider.d.ts +0 -10
- package/lib/esm/CrossMintProvider.js +0 -17
- package/lib/esm/CrossMintProvider.js.map +0 -1
- package/lib/esm/CrossMintStatusButton.d.ts +0 -10
- package/lib/esm/CrossMintStatusButton.js +0 -31
- package/lib/esm/CrossMintStatusButton.js.map +0 -1
- package/lib/esm/CrossMintStatusProvider.d.ts +0 -8
- package/lib/esm/CrossMintStatusProvider.js +0 -32
- package/lib/esm/CrossMintStatusProvider.js.map +0 -1
- package/lib/esm/useCrossMintModal.d.ts +0 -7
- package/lib/esm/useCrossMintModal.js +0 -6
- package/lib/esm/useCrossMintModal.js.map +0 -1
- package/lib/esm/useCrossMintPopup.d.ts +0 -8
- package/lib/esm/useCrossMintPopup.js +0 -6
- package/lib/esm/useCrossMintPopup.js.map +0 -1
- package/lib/esm/useCrossMintStatus.js +0 -14
- package/lib/esm/useCrossMintStatus.js.map +0 -1
- package/src/CrossMintButton.tsx +0 -75
- package/src/CrossMintModal.tsx +0 -54
- package/src/CrossMintModalProvider.tsx +0 -23
- package/src/CrossMintPopupProvider.tsx +0 -94
- package/src/CrossMintProvider.tsx +0 -44
- package/src/CrossMintStatusButton.tsx +0 -73
- package/src/CrossMintStatusProvider.tsx +0 -58
- package/src/useCrossMintModal.tsx +0 -12
- package/src/useCrossMintPopup.tsx +0 -21
- package/src/useCrossMintStatus.tsx +0 -22
- package/styles.css +0 -119
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
export interface CrossMintModalContextState {
|
|
3
|
-
visible: boolean;
|
|
4
|
-
setVisible: (open: boolean) => void;
|
|
5
|
-
}
|
|
6
|
-
export declare const CrossMintModalContext: import("react").Context<CrossMintModalContextState>;
|
|
7
|
-
export declare function useCrossMintModal(): CrossMintModalContextState;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useCrossMintModal.js","sourceRoot":"","sources":["../../src/useCrossMintModal.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAOlD,MAAM,CAAC,MAAM,qBAAqB,GAAG,aAAa,CAA6B,EAAgC,CAAC,CAAC;AAEjH,MAAM,UAAU,iBAAiB;IAC7B,OAAO,UAAU,CAAC,qBAAqB,CAAC,CAAC;AAC7C,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
export interface PopupContextState {
|
|
3
|
-
connecting: boolean;
|
|
4
|
-
connect: (collectionTitle?: string, collectionDescription?: string, collectionPhoto?: string, mintTo?: string, emailTo?: string, listingId?: string) => void;
|
|
5
|
-
popup: Window | null;
|
|
6
|
-
}
|
|
7
|
-
export declare const PopupContext: import("react").Context<PopupContextState>;
|
|
8
|
-
export declare function useCrossMintPopup(): PopupContextState;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useCrossMintPopup.js","sourceRoot":"","sources":["../../src/useCrossMintPopup.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAgBlD,MAAM,CAAC,MAAM,YAAY,GAAG,aAAa,CAAoB,EAAuB,CAAC,CAAC;AAEtF,MAAM,UAAU,iBAAiB;IAC7B,OAAO,UAAU,CAAC,YAAY,CAAC,CAAC;AACpC,CAAC"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { createContext, useContext } from "react";
|
|
2
|
-
export var OnboardingRequestStatusResponse;
|
|
3
|
-
(function (OnboardingRequestStatusResponse) {
|
|
4
|
-
OnboardingRequestStatusResponse["WAITING_SUBMISSION"] = "waiting-submission";
|
|
5
|
-
OnboardingRequestStatusResponse["PENDING"] = "pending";
|
|
6
|
-
OnboardingRequestStatusResponse["REJECTED"] = "rejected";
|
|
7
|
-
OnboardingRequestStatusResponse["ACCEPTED"] = "accepted";
|
|
8
|
-
OnboardingRequestStatusResponse["INVALID"] = "invalid";
|
|
9
|
-
})(OnboardingRequestStatusResponse || (OnboardingRequestStatusResponse = {}));
|
|
10
|
-
export const CrossMintStatusContext = createContext({});
|
|
11
|
-
export function useCrossMintStatus() {
|
|
12
|
-
return useContext(CrossMintStatusContext);
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=useCrossMintStatus.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useCrossMintStatus.js","sourceRoot":"","sources":["../../src/useCrossMintStatus.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAElD,MAAM,CAAN,IAAY,+BAMX;AAND,WAAY,+BAA+B;IACvC,4EAAyC,CAAA;IACzC,sDAAmB,CAAA;IACnB,wDAAqB,CAAA;IACrB,wDAAqB,CAAA;IACrB,sDAAmB,CAAA;AACvB,CAAC,EANW,+BAA+B,KAA/B,+BAA+B,QAM1C;AASD,MAAM,CAAC,MAAM,sBAAsB,GAAG,aAAa,CAA8B,EAAiC,CAAC,CAAC;AAEpH,MAAM,UAAU,kBAAkB;IAC9B,OAAO,UAAU,CAAC,sBAAsB,CAAC,CAAC;AAC9C,CAAC"}
|
package/src/CrossMintButton.tsx
DELETED
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import React, { CSSProperties, FC, MouseEvent, MouseEventHandler, useMemo, useCallback } from "react";
|
|
2
|
-
import { OnboardingRequestStatusResponse, useCrossMintStatus } from ".";
|
|
3
|
-
import { useCrossMintPopup } from "./useCrossMintPopup";
|
|
4
|
-
|
|
5
|
-
export interface ButtonProps {
|
|
6
|
-
className?: string;
|
|
7
|
-
disabled?: boolean;
|
|
8
|
-
onClick?: (e: MouseEvent<HTMLButtonElement>) => void;
|
|
9
|
-
style?: CSSProperties;
|
|
10
|
-
tabIndex?: number;
|
|
11
|
-
theme?: "light" | "dark";
|
|
12
|
-
collectionTitle?: string;
|
|
13
|
-
collectionDescription?: string;
|
|
14
|
-
collectionPhoto?: string;
|
|
15
|
-
mintTo?: string;
|
|
16
|
-
emailTo?: string;
|
|
17
|
-
listingId?: string;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export const CrossMintButton: FC<ButtonProps> = ({
|
|
21
|
-
className,
|
|
22
|
-
disabled,
|
|
23
|
-
onClick,
|
|
24
|
-
style,
|
|
25
|
-
tabIndex,
|
|
26
|
-
theme = "dark",
|
|
27
|
-
collectionTitle,
|
|
28
|
-
collectionDescription,
|
|
29
|
-
collectionPhoto,
|
|
30
|
-
mintTo,
|
|
31
|
-
emailTo,
|
|
32
|
-
listingId,
|
|
33
|
-
...props
|
|
34
|
-
}) => {
|
|
35
|
-
const { hideMintOnInactiveClient, status } = useCrossMintStatus();
|
|
36
|
-
|
|
37
|
-
const { connecting, connect } = useCrossMintPopup();
|
|
38
|
-
|
|
39
|
-
const handleClick: MouseEventHandler<HTMLButtonElement> = useCallback(
|
|
40
|
-
(event) => {
|
|
41
|
-
if (onClick) onClick(event);
|
|
42
|
-
|
|
43
|
-
if (!event.defaultPrevented)
|
|
44
|
-
connect(collectionTitle, collectionDescription, collectionPhoto, mintTo, emailTo, listingId);
|
|
45
|
-
},
|
|
46
|
-
[onClick]
|
|
47
|
-
);
|
|
48
|
-
|
|
49
|
-
const content = useMemo(() => {
|
|
50
|
-
if (connecting) return <p>Connecting ...</p>;
|
|
51
|
-
return <p>Buy with credit card</p>;
|
|
52
|
-
}, [connecting]);
|
|
53
|
-
|
|
54
|
-
if (hideMintOnInactiveClient && status !== OnboardingRequestStatusResponse.ACCEPTED) {
|
|
55
|
-
return null;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
return (
|
|
59
|
-
<button
|
|
60
|
-
className={`client-sdk-button-trigger client-sdk-button-trigger-${theme}`}
|
|
61
|
-
disabled={disabled}
|
|
62
|
-
onClick={handleClick}
|
|
63
|
-
style={{ ...style }}
|
|
64
|
-
tabIndex={tabIndex}
|
|
65
|
-
{...props}
|
|
66
|
-
>
|
|
67
|
-
<img
|
|
68
|
-
className="client-sdk-button-icon"
|
|
69
|
-
src="https://www.crossmint.io/assets/crossmint/logo.png"
|
|
70
|
-
alt="Crossmint logo"
|
|
71
|
-
/>
|
|
72
|
-
{content}
|
|
73
|
-
</button>
|
|
74
|
-
);
|
|
75
|
-
};
|
package/src/CrossMintModal.tsx
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import React, { FC, useCallback, useLayoutEffect, useRef, useState } from "react";
|
|
2
|
-
import { createPortal } from "react-dom";
|
|
3
|
-
import { useCrossMintModal } from "./useCrossMintModal";
|
|
4
|
-
|
|
5
|
-
export interface CrossMintModalProps {
|
|
6
|
-
className?: string;
|
|
7
|
-
container?: string;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export const CrossMintModal: FC<CrossMintModalProps> = ({ className = "", container = "body" }) => {
|
|
11
|
-
const ref = useRef<HTMLDivElement>(null);
|
|
12
|
-
const { setVisible } = useCrossMintModal();
|
|
13
|
-
|
|
14
|
-
const [fadeIn, setFadeIn] = useState(false);
|
|
15
|
-
const [portal, setPortal] = useState<Element | null>(null);
|
|
16
|
-
|
|
17
|
-
const hideModal = useCallback(() => {
|
|
18
|
-
setFadeIn(false);
|
|
19
|
-
setTimeout(() => setVisible(false), 150);
|
|
20
|
-
}, [setFadeIn, setVisible]);
|
|
21
|
-
|
|
22
|
-
useLayoutEffect(() => {
|
|
23
|
-
// Get original overflow
|
|
24
|
-
const { overflow } = window.getComputedStyle(document.body);
|
|
25
|
-
// Hack to enable fade in animation after mount
|
|
26
|
-
setTimeout(() => setFadeIn(true), 0);
|
|
27
|
-
// Prevent scrolling on mount
|
|
28
|
-
document.body.style.overflow = "hidden";
|
|
29
|
-
|
|
30
|
-
return () => {
|
|
31
|
-
// Re-enable scrolling when component unmounts
|
|
32
|
-
document.body.style.overflow = overflow;
|
|
33
|
-
};
|
|
34
|
-
}, [hideModal]);
|
|
35
|
-
|
|
36
|
-
useLayoutEffect(() => setPortal(document.querySelector(container)), [setPortal, container]);
|
|
37
|
-
|
|
38
|
-
return (
|
|
39
|
-
portal &&
|
|
40
|
-
createPortal(
|
|
41
|
-
<div
|
|
42
|
-
aria-modal="true"
|
|
43
|
-
className={`client-sdk-modal ${fadeIn ? "client-sdk-modal-fade-in" : ""} ${className}`}
|
|
44
|
-
ref={ref}
|
|
45
|
-
>
|
|
46
|
-
<div className="client-sdk-modal-container">
|
|
47
|
-
<span className="client-sdk-modal-loader" />
|
|
48
|
-
</div>
|
|
49
|
-
<div className="client-sdk-modal-overlay" />
|
|
50
|
-
</div>,
|
|
51
|
-
portal
|
|
52
|
-
)
|
|
53
|
-
);
|
|
54
|
-
};
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import React, { FC, ReactNode, useState } from "react";
|
|
2
|
-
import { CrossMintModal, CrossMintModalProps } from "./CrossMintModal";
|
|
3
|
-
import { CrossMintModalContext } from "./useCrossMintModal";
|
|
4
|
-
|
|
5
|
-
export interface CrossMintModalProviderProps extends CrossMintModalProps {
|
|
6
|
-
children: ReactNode;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export const CrossMintModalProvider: FC<CrossMintModalProviderProps> = ({ children, ...props }) => {
|
|
10
|
-
const [visible, setVisible] = useState(false);
|
|
11
|
-
|
|
12
|
-
return (
|
|
13
|
-
<CrossMintModalContext.Provider
|
|
14
|
-
value={{
|
|
15
|
-
visible,
|
|
16
|
-
setVisible,
|
|
17
|
-
}}
|
|
18
|
-
>
|
|
19
|
-
{children}
|
|
20
|
-
{visible && <CrossMintModal {...props} />}
|
|
21
|
-
</CrossMintModalContext.Provider>
|
|
22
|
-
);
|
|
23
|
-
};
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import React, { FC, ReactNode, useState } from "react";
|
|
2
|
-
import { useCrossMintModal, useCrossMintStatus } from ".";
|
|
3
|
-
import { PopupContext } from "./useCrossMintPopup";
|
|
4
|
-
|
|
5
|
-
export interface PopupProviderProps {
|
|
6
|
-
development: boolean;
|
|
7
|
-
children: ReactNode;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
const PROD_URL = "https://www.crossmint.io";
|
|
11
|
-
const DEV_URL = "http://localhost:3001";
|
|
12
|
-
|
|
13
|
-
export const CrossMintPopupProvider: FC<PopupProviderProps> = ({ development, children }) => {
|
|
14
|
-
const [connecting, setConnecting] = useState(false);
|
|
15
|
-
const [popup, setPopup] = useState<Window | null>(null);
|
|
16
|
-
|
|
17
|
-
const { clientId } = useCrossMintStatus();
|
|
18
|
-
|
|
19
|
-
const { setVisible } = useCrossMintModal();
|
|
20
|
-
|
|
21
|
-
const createPopup = (
|
|
22
|
-
collectionTitle?: string,
|
|
23
|
-
collectionDescription?: string,
|
|
24
|
-
collectionPhoto?: string,
|
|
25
|
-
mintTo?: string,
|
|
26
|
-
emailTo?: string,
|
|
27
|
-
listingId?: string
|
|
28
|
-
) => {
|
|
29
|
-
const pop = window.open(
|
|
30
|
-
`${development ? DEV_URL : PROD_URL}/signin?callbackUrl=${encodeURIComponent(
|
|
31
|
-
`${development ? DEV_URL : PROD_URL}/checkout/mint?clientId=${clientId}&closeOnSuccess=false${
|
|
32
|
-
collectionTitle ? `collectionTitle=${collectionTitle}` : ""
|
|
33
|
-
}${collectionDescription ? `&collectionDescription=${collectionDescription}` : ""}${
|
|
34
|
-
collectionPhoto ? `&collectionPhoto=${collectionPhoto}` : ""
|
|
35
|
-
}${mintTo ? `&mintTo=${mintTo}` : ""}${emailTo ? `&emailTo=${emailTo}` : ""}${
|
|
36
|
-
listingId ? `&listingId=${listingId}` : ""
|
|
37
|
-
}`
|
|
38
|
-
)}`,
|
|
39
|
-
"popUpWindow",
|
|
40
|
-
createPopupString()
|
|
41
|
-
);
|
|
42
|
-
if (pop) {
|
|
43
|
-
setVisible(true);
|
|
44
|
-
setPopup(pop);
|
|
45
|
-
registerListeners(pop);
|
|
46
|
-
} else {
|
|
47
|
-
setConnecting(false);
|
|
48
|
-
console.log("Failed to open popup window");
|
|
49
|
-
}
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
const connect = (
|
|
53
|
-
collectionTitle?: string,
|
|
54
|
-
collectionDescription?: string,
|
|
55
|
-
collectionPhoto?: string,
|
|
56
|
-
mintTo?: string,
|
|
57
|
-
emailTo?: string,
|
|
58
|
-
listingId?: string
|
|
59
|
-
) => {
|
|
60
|
-
if (connecting) return;
|
|
61
|
-
|
|
62
|
-
setConnecting(true);
|
|
63
|
-
|
|
64
|
-
createPopup(collectionTitle, collectionDescription, collectionPhoto, mintTo, emailTo, listingId);
|
|
65
|
-
};
|
|
66
|
-
|
|
67
|
-
function registerListeners(pop: Window) {
|
|
68
|
-
const timer = setInterval(function () {
|
|
69
|
-
if (pop.closed) {
|
|
70
|
-
clearInterval(timer);
|
|
71
|
-
setConnecting(false);
|
|
72
|
-
setVisible(false);
|
|
73
|
-
}
|
|
74
|
-
}, 500);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
function createPopupString() {
|
|
78
|
-
return `height=750,width=400,left=${window.innerWidth / 2 - 200},top=${
|
|
79
|
-
window.innerHeight / 2 - 375
|
|
80
|
-
},resizable=yes,scrollbars=yes,toolbar=yes,menubar=true,location=no,directories=no, status=yes`;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
return (
|
|
84
|
-
<PopupContext.Provider
|
|
85
|
-
value={{
|
|
86
|
-
connecting,
|
|
87
|
-
popup,
|
|
88
|
-
connect,
|
|
89
|
-
}}
|
|
90
|
-
>
|
|
91
|
-
{children}
|
|
92
|
-
</PopupContext.Provider>
|
|
93
|
-
);
|
|
94
|
-
};
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import React, { FC, ReactNode, useState } from "react";
|
|
2
|
-
import { CrossMintModal, CrossMintModalProps } from "./CrossMintModal";
|
|
3
|
-
import { CrossMintPopupProvider } from "./CrossMintPopupProvider";
|
|
4
|
-
import { CrossMintStatusProvider } from "./CrossMintStatusProvider";
|
|
5
|
-
import { CrossMintModalContext } from "./useCrossMintModal";
|
|
6
|
-
|
|
7
|
-
export interface CrossMintProviderProps extends CrossMintModalProps {
|
|
8
|
-
clientId: string;
|
|
9
|
-
auctionId?: string;
|
|
10
|
-
hideMintOnInactiveClient?: boolean;
|
|
11
|
-
development?: boolean;
|
|
12
|
-
children: ReactNode;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export const CrossMintProvider: FC<CrossMintProviderProps> = ({
|
|
16
|
-
clientId,
|
|
17
|
-
auctionId,
|
|
18
|
-
hideMintOnInactiveClient = false,
|
|
19
|
-
development = false,
|
|
20
|
-
children,
|
|
21
|
-
...props
|
|
22
|
-
}) => {
|
|
23
|
-
const [visible, setVisible] = useState(false);
|
|
24
|
-
|
|
25
|
-
return (
|
|
26
|
-
<CrossMintStatusProvider
|
|
27
|
-
clientId={clientId}
|
|
28
|
-
hideMintOnInactiveClient={hideMintOnInactiveClient}
|
|
29
|
-
auctionId={auctionId}
|
|
30
|
-
>
|
|
31
|
-
<CrossMintModalContext.Provider
|
|
32
|
-
value={{
|
|
33
|
-
visible,
|
|
34
|
-
setVisible,
|
|
35
|
-
}}
|
|
36
|
-
>
|
|
37
|
-
<CrossMintPopupProvider development={development}>
|
|
38
|
-
{children}
|
|
39
|
-
{visible && <CrossMintModal {...props} />}
|
|
40
|
-
</CrossMintPopupProvider>
|
|
41
|
-
</CrossMintModalContext.Provider>
|
|
42
|
-
</CrossMintStatusProvider>
|
|
43
|
-
);
|
|
44
|
-
};
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
import React, { CSSProperties, FC, MouseEvent, MouseEventHandler, useMemo, useCallback } from "react";
|
|
2
|
-
import { OnboardingRequestStatusResponse, useCrossMintStatus } from "./useCrossMintStatus";
|
|
3
|
-
|
|
4
|
-
export interface StatusButtonProps {
|
|
5
|
-
className?: string;
|
|
6
|
-
disabled?: boolean;
|
|
7
|
-
onClick?: (e: MouseEvent<HTMLButtonElement>) => void;
|
|
8
|
-
style?: CSSProperties;
|
|
9
|
-
tabIndex?: number;
|
|
10
|
-
theme?: "light" | "dark";
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export const CrossMintStatusButton: FC<StatusButtonProps> = ({
|
|
14
|
-
className,
|
|
15
|
-
disabled,
|
|
16
|
-
onClick,
|
|
17
|
-
style,
|
|
18
|
-
tabIndex,
|
|
19
|
-
theme = "dark",
|
|
20
|
-
...props
|
|
21
|
-
}) => {
|
|
22
|
-
const { status, clientId, auctionId } = useCrossMintStatus();
|
|
23
|
-
|
|
24
|
-
const handleClick: MouseEventHandler<HTMLButtonElement> = useCallback(
|
|
25
|
-
(event) => {
|
|
26
|
-
if (onClick) onClick(event);
|
|
27
|
-
|
|
28
|
-
if (status === OnboardingRequestStatusResponse.WAITING_SUBMISSION) {
|
|
29
|
-
window.open(
|
|
30
|
-
`https://crossmint.io/developers/onboarding${clientId ? `?clientId=${clientId}` : ""}${
|
|
31
|
-
auctionId ? `&auctionId=${auctionId}` : ""
|
|
32
|
-
}`,
|
|
33
|
-
"_blank"
|
|
34
|
-
);
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
},
|
|
38
|
-
[status]
|
|
39
|
-
);
|
|
40
|
-
|
|
41
|
-
const content = useMemo(() => {
|
|
42
|
-
switch (status) {
|
|
43
|
-
case OnboardingRequestStatusResponse.INVALID:
|
|
44
|
-
return <p>Invalid clientId</p>;
|
|
45
|
-
case OnboardingRequestStatusResponse.WAITING_SUBMISSION:
|
|
46
|
-
return <p>Click here to setup CrossMint</p>;
|
|
47
|
-
case OnboardingRequestStatusResponse.PENDING:
|
|
48
|
-
return <p>Your application is under review</p>;
|
|
49
|
-
case OnboardingRequestStatusResponse.ACCEPTED:
|
|
50
|
-
return <p>You're good to go!</p>;
|
|
51
|
-
case OnboardingRequestStatusResponse.REJECTED:
|
|
52
|
-
return <p>You're application was rejected</p>;
|
|
53
|
-
}
|
|
54
|
-
}, [status]);
|
|
55
|
-
|
|
56
|
-
return (
|
|
57
|
-
<button
|
|
58
|
-
className={`client-sdk-button-trigger client-sdk-button-trigger-${theme}`}
|
|
59
|
-
disabled={status !== OnboardingRequestStatusResponse.WAITING_SUBMISSION}
|
|
60
|
-
onClick={handleClick}
|
|
61
|
-
style={{ ...style }}
|
|
62
|
-
tabIndex={tabIndex}
|
|
63
|
-
{...props}
|
|
64
|
-
>
|
|
65
|
-
<img
|
|
66
|
-
className="client-sdk-button-icon"
|
|
67
|
-
src="https://www.crossmint.io/assets/crossmint/logo.png"
|
|
68
|
-
alt="Crossmint logo"
|
|
69
|
-
/>
|
|
70
|
-
{content}
|
|
71
|
-
</button>
|
|
72
|
-
);
|
|
73
|
-
};
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import React, { FC, ReactNode, useEffect, useState } from "react";
|
|
2
|
-
import { OnboardingRequestStatusResponse, CrossMintStatusContext } from "./useCrossMintStatus";
|
|
3
|
-
|
|
4
|
-
export interface CrossMintStatusProviderProps {
|
|
5
|
-
clientId: string;
|
|
6
|
-
auctionId?: string;
|
|
7
|
-
hideMintOnInactiveClient: boolean;
|
|
8
|
-
children: ReactNode;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export const CrossMintStatusProvider: FC<CrossMintStatusProviderProps> = ({
|
|
12
|
-
clientId,
|
|
13
|
-
auctionId,
|
|
14
|
-
hideMintOnInactiveClient,
|
|
15
|
-
children,
|
|
16
|
-
}) => {
|
|
17
|
-
const [status, setStatus] = useState<OnboardingRequestStatusResponse>(
|
|
18
|
-
OnboardingRequestStatusResponse.WAITING_SUBMISSION
|
|
19
|
-
);
|
|
20
|
-
|
|
21
|
-
async function fetchClientIntegration() {
|
|
22
|
-
const res = await fetch(`https://www.crossmint.io/api/crossmint/onboardingRequests/${clientId}/status`);
|
|
23
|
-
|
|
24
|
-
if (res.status === 200) {
|
|
25
|
-
const resData: { clientId: string; status: OnboardingRequestStatusResponse } = await res.json();
|
|
26
|
-
|
|
27
|
-
console.log("resData", resData);
|
|
28
|
-
setStatus(resData.status);
|
|
29
|
-
} else {
|
|
30
|
-
if (status !== OnboardingRequestStatusResponse.INVALID) {
|
|
31
|
-
setStatus(OnboardingRequestStatusResponse.INVALID);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
useEffect(() => {
|
|
37
|
-
fetchClientIntegration();
|
|
38
|
-
|
|
39
|
-
const interval = setInterval(() => {
|
|
40
|
-
fetchClientIntegration();
|
|
41
|
-
}, 60 * 1000);
|
|
42
|
-
|
|
43
|
-
return () => clearInterval(interval);
|
|
44
|
-
}, []);
|
|
45
|
-
|
|
46
|
-
return (
|
|
47
|
-
<CrossMintStatusContext.Provider
|
|
48
|
-
value={{
|
|
49
|
-
status,
|
|
50
|
-
clientId,
|
|
51
|
-
auctionId,
|
|
52
|
-
hideMintOnInactiveClient,
|
|
53
|
-
}}
|
|
54
|
-
>
|
|
55
|
-
{children}
|
|
56
|
-
</CrossMintStatusContext.Provider>
|
|
57
|
-
);
|
|
58
|
-
};
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { createContext, useContext } from "react";
|
|
2
|
-
|
|
3
|
-
export interface CrossMintModalContextState {
|
|
4
|
-
visible: boolean;
|
|
5
|
-
setVisible: (open: boolean) => void;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
export const CrossMintModalContext = createContext<CrossMintModalContextState>({} as CrossMintModalContextState);
|
|
9
|
-
|
|
10
|
-
export function useCrossMintModal(): CrossMintModalContextState {
|
|
11
|
-
return useContext(CrossMintModalContext);
|
|
12
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { createContext, useContext } from "react";
|
|
2
|
-
|
|
3
|
-
export interface PopupContextState {
|
|
4
|
-
connecting: boolean;
|
|
5
|
-
connect: (
|
|
6
|
-
collectionTitle?: string,
|
|
7
|
-
collectionDescription?: string,
|
|
8
|
-
collectionPhoto?: string,
|
|
9
|
-
mintTo?: string,
|
|
10
|
-
emailTo?: string,
|
|
11
|
-
listingId?: string
|
|
12
|
-
) => void;
|
|
13
|
-
|
|
14
|
-
popup: Window | null;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export const PopupContext = createContext<PopupContextState>({} as PopupContextState);
|
|
18
|
-
|
|
19
|
-
export function useCrossMintPopup(): PopupContextState {
|
|
20
|
-
return useContext(PopupContext);
|
|
21
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { createContext, useContext } from "react";
|
|
2
|
-
|
|
3
|
-
export enum OnboardingRequestStatusResponse {
|
|
4
|
-
WAITING_SUBMISSION = "waiting-submission",
|
|
5
|
-
PENDING = "pending",
|
|
6
|
-
REJECTED = "rejected",
|
|
7
|
-
ACCEPTED = "accepted",
|
|
8
|
-
INVALID = "invalid",
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export interface CrossMintStatusContextState {
|
|
12
|
-
status: OnboardingRequestStatusResponse;
|
|
13
|
-
clientId: string;
|
|
14
|
-
auctionId?: string;
|
|
15
|
-
hideMintOnInactiveClient: boolean;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export const CrossMintStatusContext = createContext<CrossMintStatusContextState>({} as CrossMintStatusContextState);
|
|
19
|
-
|
|
20
|
-
export function useCrossMintStatus(): CrossMintStatusContextState {
|
|
21
|
-
return useContext(CrossMintStatusContext);
|
|
22
|
-
}
|
package/styles.css
DELETED
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
@import url("https://cdn.rawgit.com/mfd/09b70eb47474836f25a21660282ce0fd/raw/e06a670afcb2b861ed2ac4a1ef752d062ef6b46b/Gilroy.css");
|
|
2
|
-
|
|
3
|
-
:root {
|
|
4
|
-
--crossmint-main-green: #00ff85;
|
|
5
|
-
--crossmint-main-blue: #00e0ff;
|
|
6
|
-
--crossmint-main-dark-bg: #1e1e1e;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
/* Mint Button */
|
|
10
|
-
|
|
11
|
-
.client-sdk-button-trigger {
|
|
12
|
-
display: flex;
|
|
13
|
-
flex-direction: row;
|
|
14
|
-
align-items: center;
|
|
15
|
-
padding: 0.875rem 0.875rem;
|
|
16
|
-
font-weight: 900;
|
|
17
|
-
transition: opacity ease-in-out 0.25s;
|
|
18
|
-
border-radius: 0.5rem;
|
|
19
|
-
font-family: "Gilroy", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans",
|
|
20
|
-
"Helvetica Neue", sans-serif;
|
|
21
|
-
outline: none;
|
|
22
|
-
border: none;
|
|
23
|
-
box-shadow: 0px 8px 15px rgba(0, 0, 0, 0.1);
|
|
24
|
-
justify-content: center;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
.client-sdk-button-trigger p {
|
|
28
|
-
margin: 0;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
.client-sdk-button-trigger:hover:enabled {
|
|
32
|
-
opacity: 0.6;
|
|
33
|
-
cursor: pointer;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
.client-sdk-button-trigger-dark {
|
|
37
|
-
background: var(--crossmint-main-dark-bg);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
.client-sdk-button-trigger-light {
|
|
41
|
-
background: white;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
.client-sdk-button-trigger-light p {
|
|
45
|
-
color: black;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
.client-sdk-button-trigger-dark p {
|
|
49
|
-
color: white;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
.client-sdk-button-trigger-colored {
|
|
53
|
-
background-image: linear-gradient(to bottom right, var(--crossmint-main-green), var(--crossmint-main-blue));
|
|
54
|
-
color: white;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
.client-sdk-button-icon {
|
|
58
|
-
width: 21px;
|
|
59
|
-
height: 21px;
|
|
60
|
-
margin-right: 0.875rem;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
/* Modal */
|
|
64
|
-
.client-sdk-modal {
|
|
65
|
-
position: fixed;
|
|
66
|
-
top: 0;
|
|
67
|
-
left: 0;
|
|
68
|
-
right: 0;
|
|
69
|
-
bottom: 0;
|
|
70
|
-
opacity: 0;
|
|
71
|
-
transition: opacity linear 150ms;
|
|
72
|
-
background: rgba(0, 0, 0, 0.5);
|
|
73
|
-
z-index: 1040;
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
.client-sdk-modal.client-sdk-modal-fade-in {
|
|
77
|
-
opacity: 1;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
.client-sdk-modal-overlay {
|
|
81
|
-
background: rgba(0, 0, 0, 0.5);
|
|
82
|
-
position: fixed;
|
|
83
|
-
top: 0;
|
|
84
|
-
left: 0;
|
|
85
|
-
bottom: 0;
|
|
86
|
-
right: 0;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
.client-sdk-modal-container {
|
|
90
|
-
position: absolute;
|
|
91
|
-
top: 0;
|
|
92
|
-
left: 0;
|
|
93
|
-
bottom: 0;
|
|
94
|
-
right: 0;
|
|
95
|
-
width: 100%;
|
|
96
|
-
height: 100%;
|
|
97
|
-
display: flex;
|
|
98
|
-
justify-content: center;
|
|
99
|
-
align-items: center;
|
|
100
|
-
z-index: 1041;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
.client-sdk-modal-loader {
|
|
104
|
-
border: 3px solid transparent; /* Light grey */
|
|
105
|
-
border-top: 3px solid white; /* Blue */
|
|
106
|
-
border-radius: 50%;
|
|
107
|
-
width: 35px;
|
|
108
|
-
height: 35px;
|
|
109
|
-
animation: crossmintSpin 1s linear infinite;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
@keyframes crossmintSpin {
|
|
113
|
-
0% {
|
|
114
|
-
transform: rotate(0deg);
|
|
115
|
-
}
|
|
116
|
-
100% {
|
|
117
|
-
transform: rotate(360deg);
|
|
118
|
-
}
|
|
119
|
-
}
|