Skip to content

Commit

Permalink
Update TS types
Browse files Browse the repository at this point in the history
  • Loading branch information
bmuller committed Apr 25, 2024
1 parent 45a5533 commit 76b7794
Show file tree
Hide file tree
Showing 10 changed files with 80 additions and 116 deletions.
1 change: 1 addition & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,3 +19,4 @@ jobs:
- run: pnpm install --no-optional
- run: pnpm lint
- run: pnpm test
- run: pnpm build
1 change: 1 addition & 0 deletions packages/react/src/__tests__/index-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import React from 'react'
import { ParallelProvider, PassportButton } from '../index'

const ParallelMock = {
getProfile: (cb, _eb) => cb({}),
getLoginStatus: (cb) => cb({}),
subscribe: () => null,
unsubscribe: () => null,
Expand Down
25 changes: 3 additions & 22 deletions packages/react/src/index.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,8 @@
import React, { PropsWithChildren, createContext, useContext, useEffect, useState } from 'react'
import ButtonImg from './medium-passport-button.svg'

import { ParallelApiRecord, loadParallel } from '@parallelmarkets/vanilla'
import type { AuthCallbackResult, Parallel } from '@parallelmarkets/vanilla'
import { ProfileApiResponse } from './profile_api_types'

export * from './profile_api_types'
import { loadParallel } from '@parallelmarkets/vanilla'
import type { AuthCallbackResult, Parallel, ProfileApiResponse } from '@parallelmarkets/vanilla'

Check warning on line 5 in packages/react/src/index.tsx

View workflow job for this annotation

GitHub Actions / test

'Parallel' is defined but never used. Allowed unused vars must match /^_/u

type LoadParallelPromise = ReturnType<typeof loadParallel>
type LoadParallelResult = Awaited<ReturnType<typeof loadParallel>>
Expand All @@ -29,22 +26,6 @@ const isPromise = (thing: unknown): thing is PromiseLike<unknown> => {
return typeof (thing as PromiseLike<unknown>)?.then === 'function'
}

// The Embed API works with callback functions. This wrapper converts them to promises.
const promisifyApiCall = <ResultType extends ParallelApiRecord>(parallel: Parallel, endpoint: string) => {
return () => {
// This promise resolves with the type of the API's Success Callback function's first Parameter
return new Promise<ResultType>((resolve, reject) => {
parallel.api(
endpoint,
(result) => {
resolve(result as ResultType)
},
reject,
)
})
}
}

export const useParallel = () => {
const { parallel: parallelPromise } = useContext(ParallelContext)
const [parallel, setParallel] = useState<LoadParallelResult>(null)
Expand Down Expand Up @@ -104,7 +85,7 @@ export const useParallel = () => {
parallel,
error,
loginStatus,
getProfile: promisifyApiCall<ProfileApiResponse>(parallel, '/profile'),
getProfile: new Promise<ProfileApiResponse>(parallel.getProfile),
login: parallel.login,
logout: parallel.logout,
}
Expand Down
36 changes: 0 additions & 36 deletions packages/react/src/profile_api_types.ts

This file was deleted.

5 changes: 4 additions & 1 deletion packages/react/tsconfig.cjs.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@
"target": "ES5",
"module": "ESNext",
"moduleResolution": "Bundler",
"noEmit": true // Type check only. Rollup runs Babel to compile for lower targets in the next step
"noEmit": true, // Type check only. Rollup runs Babel to compile for lower targets in the next step
"paths": {
"@parallelmarkets/*": ["../*"]
}
}
}
13 changes: 7 additions & 6 deletions packages/vanilla/src/__tests__/index-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,22 +9,23 @@ declare global {
}

global.window.Parallel = {
get _config() {
return window.config
},
init: ({ on_init, ...params }: ParallelConfig) => {
window.config = params
on_init?.()
},
api: () => null,
getLoginStatus: () => null,
getProfile: () => null,
login: () => null,
logout: () => null,
unsubscribe: () => null,
subscribe: () => null,
showButton: () => null,
hideButton: () => null,
unsubscribe: () => null,
getLoginStatus: () => null,
subscribeWithButton: () => null,
_appendLoadContext: () => null,
get _config() {
return window.config
}
}

test('Configuration is set correctly', async () => {
Expand Down
29 changes: 0 additions & 29 deletions packages/vanilla/src/common_api_types.ts

This file was deleted.

1 change: 0 additions & 1 deletion packages/vanilla/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { Parallel, ParallelConfig } from './types'

export * from './types'
export * from './common_api_types'

const V2_URL = 'https://app.parallelmarkets.com/sdk/v2/parallel.js'
let parallelPromise: Promise<Parallel | null> | undefined
Expand Down
80 changes: 60 additions & 20 deletions packages/vanilla/src/types.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,15 @@
import { type BusinessType } from './common_api_types'
export type EntityKind = 'individual' | 'business'

export type BusinessType =
| 'Public Charity'
| 'Private Foundation'
| 'S Corporation'
| 'C Corporation'
| 'Irrevocable Trust'
| 'Revocable Trust'
| 'Family Office'
| 'Limited Liability Company'
| 'Limited Partnership'

/* eslint-disable @typescript-eslint/no-explicit-any */
type AuthResponse = {
Expand All @@ -16,17 +27,19 @@ export type AuthCallbackResult = {
errorDescription?: string
}

// https://developer.parallelmarkets.com/docs/server/scopes
export type ParallelScope = 'profile' | 'accreditation_status' | 'identity' | 'blockchain'
// https://developer.parallelmarkets.com/docs/javascript/configuration#scopes
export type ParallelScope = 'profile' | 'accreditation_status' | 'identity'

// https://developer.parallelmarkets.com/docs/javascript/configuration
type EmbedParallelConfig = {
flow_type: 'embed'
embed_into_id: string
}

type OverlayRedirectParallelConfig = {
flow_type: 'overlay' | 'redirect'
}

export type ParallelConfig = (EmbedParallelConfig | OverlayRedirectParallelConfig) & {
client_id?: string
environment?: 'production' | 'demo'
Expand All @@ -40,21 +53,47 @@ export type ParallelConfig = (EmbedParallelConfig | OverlayRedirectParallelConfi
raw_config?: Record<string, any>
}

type AuthSuccessCallbackFunc = (result: AuthCallbackResult) => void
type AuthFailureCallbackFunc = (result: { error: unknown }) => void
export type IndividualProfile = {
email: string
first_name: string
last_name: string
}

export type BusinessProfile = {
name: string
business_type: BusinessType
primary_contact: IndividualProfile
}

export type ProfileApiResponse = {
id: string
type: EntityKind
profile: IndividualProfile | BusinessProfile
user_id: string
user_profile: IndividualProfile
user_providing_for: 'self' | 'controlled-business' | 'other-individual'
access_expires_at: string | null
access_revoked_by: 'subject' | 'partner' | 'system' | null
available_scopes: Array<ParallelScope>
}

type GetProfileSuccessCallbackFunc = (_result: ProfileApiResponse) => void

type GetProfileFailureCallbackFunc = (_result: { error: unknown }) => void

// TODO: implement this
export type ParallelApiRecord = Record<string, any>
export type ParallelApiSuccessCallback = (response: ParallelApiRecord) => void
export type ParallelApiErrorCallback = (reason: any) => void
type AuthSuccessCallbackFunc = (_result: AuthCallbackResult) => void

type AuthFailureCallbackFunc = (_result: { error: unknown }) => void

type SubscribeEvents = 'auth.login' | 'auth.logout' | 'auth.statusChange' | 'auth.authResponseChange'

type OAuthErrorCode =
| 'invalid_request'
| 'invalid_client'
| 'invalid_grant'
| 'unauthorized_client'
| 'unsupported_grant_type'

type SubscriptionEvent = {
status: 'not_authorized' | 'unknown' | 'connected'
error?: OAuthErrorCode
Expand All @@ -67,7 +106,8 @@ type SubscriptionEvent = {
refresh_expires_in: number
}
}
type SubscriptionHandler = (response: SubscriptionEvent) => void

type SubscriptionHandler = (_response: SubscriptionEvent) => void

export interface LoginOptions {
email?: string
Expand All @@ -80,24 +120,24 @@ export interface LoginOptions {
}

export interface Parallel {
init(options: ParallelConfig): void
_config: ParallelConfig
login: (options?: LoginOptions) => void
init(_options: ParallelConfig): void
getLoginStatus: (_callback: AuthSuccessCallbackFunc) => void
getProfile: (_successFunc: GetProfileSuccessCallbackFunc, _errorFunc: GetProfileFailureCallbackFunc) => void
login: (_options?: LoginOptions) => void
logout: () => void
subscribeWithButton: (successFunc: AuthSuccessCallbackFunc, errorFunc: AuthFailureCallbackFunc) => void
unsubscribe: (_event: SubscribeEvents, _callback: SubscriptionHandler) => void
subscribe: (_event: SubscribeEvents, _callback: SubscriptionHandler) => void
showButton: () => void
hideButton: () => void
api: (endpoint: string, callback: ParallelApiSuccessCallback, errorback: ParallelApiErrorCallback) => void
subscribe: (event: SubscribeEvents, callback: SubscriptionHandler) => void
unsubscribe: (event: SubscribeEvents, callback: SubscriptionHandler) => void
getLoginStatus: (callback: AuthSuccessCallbackFunc) => void
_appendLoadContext: (context: string) => void
subscribeWithButton: (_successFunc: AuthSuccessCallbackFunc, _errorFunc: AuthFailureCallbackFunc) => void
_appendLoadContext: (_context: string) => void
_config: ParallelConfig
}

declare global {
interface Window {
// parallel.js must be loaded directly from app.parallelmarkets.com/sdk/v2/parallel.js
// which places a `Paralell` object at the window level
// which places a `Parallel` object at the window level
Parallel?: Parallel
}
}
5 changes: 4 additions & 1 deletion packages/vanilla/tsconfig.cjs.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@
"target": "ES5",
"module": "ESNext",
"moduleResolution": "Node",
"noEmit": true // Type check only. Rollup runs Babel to compile for lower targets in the next step
"noEmit": true, // Type check only. Rollup runs Babel to compile for lower targets in the next step
"paths": {
"@parallelmarkets/*": ["../*"]
}
}
}

0 comments on commit 76b7794

Please sign in to comment.