@commercelayer/app-elements 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/dist/@types/Elements.d.ts +1 -0
- package/dist/Async-ba6be658.js +80 -0
- package/dist/InputDateComponent-89d2ab03.js +8923 -0
- package/dist/Select-72746d2c.js +34 -0
- package/dist/helpers/date.d.ts +8 -0
- package/dist/helpers/downloadJsonAsFile.d.ts +9 -0
- package/dist/hooks/useClickAway.d.ts +2 -0
- package/dist/main-dc0e3952.js +5009 -0
- package/dist/main.d.ts +55 -0
- package/dist/main.js +67 -0
- package/dist/overrides-52d8822b.js +4253 -0
- package/dist/providers/CoreSdkProvider/index.d.ts +20 -0
- package/dist/providers/CoreSdkProvider/makeSdkClient.d.ts +7 -0
- package/dist/providers/ErrorBoundary.d.ts +19 -0
- package/dist/providers/TokenProvider/getAccessTokenFromUrl.d.ts +1 -0
- package/dist/providers/TokenProvider/getInfoFromJwt.d.ts +7 -0
- package/dist/providers/TokenProvider/index.d.ts +62 -0
- package/dist/providers/TokenProvider/reducer.d.ts +21 -0
- package/dist/providers/TokenProvider/storage.d.ts +14 -0
- package/dist/providers/TokenProvider/types.d.ts +44 -0
- package/dist/providers/TokenProvider/url.d.ts +7 -0
- package/dist/providers/TokenProvider/validateToken.d.ts +24 -0
- package/dist/style.css +1 -0
- package/dist/ui/atoms/A.d.ts +8 -0
- package/dist/ui/atoms/Badge.d.ts +11 -0
- package/dist/ui/atoms/BlockCode.d.ts +11 -0
- package/dist/ui/atoms/Button.d.ts +23 -0
- package/dist/ui/atoms/Card.d.ts +8 -0
- package/dist/ui/atoms/Container.d.ts +20 -0
- package/dist/ui/atoms/CopyToClipboard.d.ts +19 -0
- package/dist/ui/atoms/DelayShow.d.ts +10 -0
- package/dist/ui/atoms/EmptyState.d.ts +13 -0
- package/dist/ui/atoms/FormFooter.d.ts +10 -0
- package/dist/ui/atoms/Hint.d.ts +11 -0
- package/dist/ui/atoms/Icon.d.ts +37 -0
- package/dist/ui/atoms/Legend.d.ts +20 -0
- package/dist/ui/atoms/PageHeading.d.ts +39 -0
- package/dist/ui/atoms/Pagination.d.ts +27 -0
- package/dist/ui/atoms/Skeleton.d.ts +41 -0
- package/dist/ui/atoms/Spacer.d.ts +28 -0
- package/dist/ui/atoms/StatusDot.d.ts +9 -0
- package/dist/ui/atoms/StatusIcon.d.ts +16 -0
- package/dist/ui/atoms/Tabs.d.ts +46 -0
- package/dist/ui/atoms/Text.d.ts +21 -0
- package/dist/ui/atoms/dropdown/DropdownMenu.d.ts +10 -0
- package/dist/ui/atoms/dropdown/DropdownMenuDivider.d.ts +9 -0
- package/dist/ui/atoms/dropdown/DropdownMenuItem.d.ts +10 -0
- package/dist/ui/atoms/dropdown/index.d.ts +3 -0
- package/dist/ui/atoms/tables/Td.d.ts +9 -0
- package/dist/ui/atoms/tables/Th.d.ts +9 -0
- package/dist/ui/atoms/tables/Tr.d.ts +9 -0
- package/dist/ui/atoms/tables/index.d.ts +3 -0
- package/dist/ui/composite/ContextMenu.d.ts +10 -0
- package/dist/ui/composite/PageError.d.ts +30 -0
- package/dist/ui/composite/PageLayout.d.ts +17 -0
- package/dist/ui/composite/PageSkeleton.d.ts +10 -0
- package/dist/ui/composite/Report.d.ts +19 -0
- package/dist/ui/forms/Input.d.ts +14 -0
- package/dist/ui/forms/InputDate/InputDateComponent.d.ts +45 -0
- package/dist/ui/forms/InputDate/index.d.ts +5 -0
- package/dist/ui/forms/InputDateRange.d.ts +23 -0
- package/dist/ui/forms/InputFeedback.d.ts +11 -0
- package/dist/ui/forms/InputFile.d.ts +10 -0
- package/dist/ui/forms/InputJson.d.ts +14 -0
- package/dist/ui/forms/InputReadonly.d.ts +24 -0
- package/dist/ui/forms/InputSelect/Async.d.ts +11 -0
- package/dist/ui/forms/InputSelect/Select.d.ts +10 -0
- package/dist/ui/forms/InputSelect/index.d.ts +59 -0
- package/dist/ui/forms/InputSelect/overrides.d.ts +10 -0
- package/dist/ui/forms/InputSelect/styles.d.ts +4 -0
- package/dist/ui/forms/InputTextArea.d.ts +6 -0
- package/dist/ui/forms/InputToggleBox.d.ts +9 -0
- package/dist/ui/forms/InputToggleListBox.d.ts +15 -0
- package/dist/ui/forms/InputWrapper.d.ts +34 -0
- package/dist/ui/forms/Label.d.ts +9 -0
- package/dist/ui/forms/RadioButtons.d.ts +18 -0
- package/dist/ui/lists/List.d.ts +37 -0
- package/dist/ui/lists/ListDetails.d.ts +32 -0
- package/dist/ui/lists/ListDetailsItem.d.ts +22 -0
- package/dist/ui/lists/ListItem.d.ts +12 -0
- package/dist/ui/lists/ListItemTask.d.ts +33 -0
- package/dist/ui/tables/Table.d.ts +10 -0
- package/dist/ui/tables/TableData.d.ts +13 -0
- package/dist/utils/children.d.ts +15 -0
- package/dist/utils/extractHeaders.d.ts +6 -0
- package/dist/utils/pagination.d.ts +43 -0
- package/package.json +70 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { CommerceLayerClient } from '@commercelayer/sdk';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
interface CoreSdkProviderValue {
|
|
4
|
+
/**
|
|
5
|
+
* Valid SDK client
|
|
6
|
+
*/
|
|
7
|
+
sdkClient?: CommerceLayerClient;
|
|
8
|
+
}
|
|
9
|
+
interface CoreSdkProviderProps {
|
|
10
|
+
/**
|
|
11
|
+
* Entire app content
|
|
12
|
+
*/
|
|
13
|
+
children: ((props: CoreSdkProviderValue) => ReactNode) | ReactNode;
|
|
14
|
+
}
|
|
15
|
+
export declare const useCoreSdkProvider: () => CoreSdkProviderValue;
|
|
16
|
+
declare function CoreSdkProvider({ children }: CoreSdkProviderProps): JSX.Element | null;
|
|
17
|
+
declare namespace CoreSdkProvider {
|
|
18
|
+
var displayName: string;
|
|
19
|
+
}
|
|
20
|
+
export { CoreSdkProvider };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { CommerceLayerClient } from '@commercelayer/sdk';
|
|
2
|
+
export declare function makeSdkClient({ accessToken, organization, domain, onInvalidToken }: {
|
|
3
|
+
accessToken: string;
|
|
4
|
+
organization: string;
|
|
5
|
+
domain?: string;
|
|
6
|
+
onInvalidToken: () => void;
|
|
7
|
+
}): CommerceLayerClient;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Component, ErrorInfo, ReactNode } from 'react';
|
|
2
|
+
interface Props {
|
|
3
|
+
children?: ReactNode;
|
|
4
|
+
errorTitle?: string;
|
|
5
|
+
errorDescription?: string;
|
|
6
|
+
onRetry?: () => void;
|
|
7
|
+
hasContainer?: boolean;
|
|
8
|
+
}
|
|
9
|
+
interface State {
|
|
10
|
+
hasError: boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare class ErrorBoundary extends Component<Props, State> {
|
|
13
|
+
static displayName: string;
|
|
14
|
+
state: State;
|
|
15
|
+
static getDerivedStateFromError(_error: Error): State;
|
|
16
|
+
componentDidCatch(error: Error, errorInfo: ErrorInfo): void;
|
|
17
|
+
render(): ReactNode;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const getAccessTokenFromUrl: () => string | null;
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
import { TokenProviderAllowedApp, TokenProviderRoleActions, TokenProviderResourceType, TokenProviderAuthSettings } from './types';
|
|
4
|
+
interface TokenProviderValue {
|
|
5
|
+
dashboardUrl?: string;
|
|
6
|
+
settings: TokenProviderAuthSettings;
|
|
7
|
+
canUser: (action: TokenProviderRoleActions, resource: TokenProviderResourceType) => boolean;
|
|
8
|
+
emitInvalidAuth: (reason: string) => void;
|
|
9
|
+
}
|
|
10
|
+
export interface TokenProviderProps {
|
|
11
|
+
/**
|
|
12
|
+
* Token kind (will be validated)
|
|
13
|
+
*/
|
|
14
|
+
clientKind: 'integration' | 'sales_channel' | 'webapp';
|
|
15
|
+
/**
|
|
16
|
+
* Slug of the current app (will be validated). Can be one of imports, exports, webhooks, resources, orders or custom
|
|
17
|
+
*/
|
|
18
|
+
currentApp: TokenProviderAllowedApp;
|
|
19
|
+
/**
|
|
20
|
+
* Base domain to be used for Commerce Layer API requests (eg. `commercelayer.io`)
|
|
21
|
+
*/
|
|
22
|
+
domain?: string;
|
|
23
|
+
/**
|
|
24
|
+
* Callback invoked when token is not valid
|
|
25
|
+
*/
|
|
26
|
+
onInvalidAuth?: (info: {
|
|
27
|
+
dashboardUrl: string;
|
|
28
|
+
reason: string;
|
|
29
|
+
}) => void;
|
|
30
|
+
/**
|
|
31
|
+
* Automatically redirect to dashboard to start re-authentication flow and return to app with fresh token
|
|
32
|
+
*/
|
|
33
|
+
reauthenticateOnInvalidAuth?: boolean;
|
|
34
|
+
/**
|
|
35
|
+
* Element to be used as loader (eg: skeleton or spinner icon)
|
|
36
|
+
*/
|
|
37
|
+
loadingElement?: ReactNode;
|
|
38
|
+
/**
|
|
39
|
+
* Element to display in case of invalid token
|
|
40
|
+
*/
|
|
41
|
+
errorElement?: ReactNode;
|
|
42
|
+
/**
|
|
43
|
+
* skip domain slug validation when is dev mode
|
|
44
|
+
*/
|
|
45
|
+
devMode: boolean;
|
|
46
|
+
/**
|
|
47
|
+
* Optional. In case you already have an access token, this will skip the retrieval of token from URL or localStorage.
|
|
48
|
+
* When undefined (default scenario), token is expected to be retrieved from `?accessToken=xxxx` query string or localStorage (in this order).
|
|
49
|
+
*/
|
|
50
|
+
accessToken?: string;
|
|
51
|
+
/**
|
|
52
|
+
* Entire app content
|
|
53
|
+
*/
|
|
54
|
+
children: ((props: TokenProviderValue) => ReactNode) | ReactNode;
|
|
55
|
+
}
|
|
56
|
+
export declare const AuthContext: React.Context<TokenProviderValue>;
|
|
57
|
+
export declare const useTokenProvider: () => TokenProviderValue;
|
|
58
|
+
declare function TokenProvider({ currentApp, clientKind, domain, onInvalidAuth, reauthenticateOnInvalidAuth, loadingElement, errorElement, devMode, children, accessToken: accessTokenFromProp }: TokenProviderProps): JSX.Element;
|
|
59
|
+
declare namespace TokenProvider {
|
|
60
|
+
var displayName: string;
|
|
61
|
+
}
|
|
62
|
+
export { TokenProvider };
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { TokenProviderAuthSettings, TokenProviderRolePermissions } from './types';
|
|
2
|
+
interface TokenProviderInternalState {
|
|
3
|
+
validAuthToken?: string;
|
|
4
|
+
dashboardUrl: string;
|
|
5
|
+
isLoading: boolean;
|
|
6
|
+
isTokenError: boolean;
|
|
7
|
+
rolePermissions: TokenProviderRolePermissions;
|
|
8
|
+
settings: TokenProviderAuthSettings;
|
|
9
|
+
}
|
|
10
|
+
export declare const initialTokenProviderState: TokenProviderInternalState;
|
|
11
|
+
declare type Action = {
|
|
12
|
+
type: 'invalidAuth';
|
|
13
|
+
} | {
|
|
14
|
+
type: 'validToken';
|
|
15
|
+
payload: {
|
|
16
|
+
settings: TokenProviderAuthSettings;
|
|
17
|
+
rolePermissions: TokenProviderRolePermissions;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
export declare const reducer: (state: TokenProviderInternalState, action: Action) => TokenProviderInternalState;
|
|
21
|
+
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { TokenProviderAllowedApp } from './types';
|
|
2
|
+
declare type PersistentItem = 'accessToken';
|
|
3
|
+
export declare function makeStorageKey({ currentApp, item }: {
|
|
4
|
+
currentApp: TokenProviderAllowedApp;
|
|
5
|
+
item: PersistentItem;
|
|
6
|
+
}): string;
|
|
7
|
+
export declare function getPersistentAccessToken({ currentApp }: {
|
|
8
|
+
currentApp: TokenProviderAllowedApp;
|
|
9
|
+
}): string | null;
|
|
10
|
+
export declare function savePersistentAccessToken({ currentApp, accessToken }: {
|
|
11
|
+
currentApp: TokenProviderAllowedApp;
|
|
12
|
+
accessToken: string;
|
|
13
|
+
}): void;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
export declare type TokenProviderResourceType = 'addresses' | 'adjustments' | 'adyen_gateways' | 'adyen_payments' | 'application' | 'attachments' | 'authorizations' | 'avalara_accounts' | 'billing_info_validation_rules' | 'bing_geocoders' | 'braintree_gateways' | 'braintree_payments' | 'bundles' | 'captures' | 'carrier_accounts' | 'checkout_com_gateways' | 'checkout_com_payments' | 'cleanups' | 'coupon_codes_promotion_rules' | 'coupon_recipients' | 'coupons' | 'customer_addresses' | 'customer_groups' | 'customer_password_resets' | 'customer_payment_sources' | 'customer_subscriptions' | 'customers' | 'delivery_lead_times' | 'event_callbacks' | 'events' | 'exports' | 'external_gateways' | 'external_payments' | 'external_promotions' | 'external_tax_calculators' | 'fixed_amount_promotions' | 'fixed_price_promotions' | 'free_gift_promotions' | 'free_shipping_promotions' | 'geocoders' | 'gift_card_recipients' | 'gift_cards' | 'google_geocoders' | 'imports' | 'in_stock_subscriptions' | 'inventory_models' | 'inventory_return_locations' | 'inventory_stock_locations' | 'klarna_gateways' | 'klarna_payments' | 'line_item_options' | 'line_items' | 'manual_gateways' | 'manual_tax_calculators' | 'markets' | 'merchants' | 'order_amount_promotion_rules' | 'order_copies' | 'order_subscriptions' | 'order_validation_rules' | 'orders' | 'organization' | 'packages' | 'parcel_line_items' | 'parcels' | 'payment_gateways' | 'payment_methods' | 'paypal_gateways' | 'paypal_payments' | 'percentage_discount_promotions' | 'price_lists' | 'price_tiers' | 'price_volume_tiers' | 'prices' | 'promotion_rules' | 'promotions' | 'refunds' | 'return_line_items' | 'returns' | 'shipments' | 'shipping_categories' | 'shipping_method_tiers' | 'shipping_methods' | 'shipping_weight_tiers' | 'shipping_zones' | 'sku_list_items' | 'sku_list_promotion_rules' | 'sku_lists' | 'sku_options' | 'skus' | 'stock_items' | 'stock_line_items' | 'stock_locations' | 'stock_transfers' | 'stripe_gateways' | 'stripe_payments' | 'tax_calculators' | 'tax_categories' | 'tax_rules' | 'taxjar_accounts' | 'transactions' | 'voids' | 'webhooks' | 'wire_transfers';
|
|
2
|
+
export declare type TokenProviderAllowedApp = 'imports' | 'exports' | 'webhooks' | 'resources' | 'orders' | 'custom';
|
|
3
|
+
export declare type TokenProviderRoleActions = 'create' | 'destroy' | 'read' | 'update';
|
|
4
|
+
export declare type TokenProviderPermissionItem = Record<TokenProviderRoleActions, boolean>;
|
|
5
|
+
export declare type TokenProviderRolePermissions = Partial<Record<TokenProviderResourceType, TokenProviderPermissionItem>>;
|
|
6
|
+
export interface TokenProviderTokenInfo {
|
|
7
|
+
token: {
|
|
8
|
+
test: boolean;
|
|
9
|
+
market_ids: string[];
|
|
10
|
+
stock_location_ids: string[];
|
|
11
|
+
lifespan: number;
|
|
12
|
+
};
|
|
13
|
+
role: {
|
|
14
|
+
id: string;
|
|
15
|
+
kind: string;
|
|
16
|
+
name: string;
|
|
17
|
+
};
|
|
18
|
+
application: {
|
|
19
|
+
id: string;
|
|
20
|
+
kind: 'integration' | 'sales_channel' | 'webapp';
|
|
21
|
+
name: string;
|
|
22
|
+
core: boolean;
|
|
23
|
+
};
|
|
24
|
+
permissions: Record<TokenProviderResourceType, {
|
|
25
|
+
actions: TokenProviderRoleActions[];
|
|
26
|
+
}>;
|
|
27
|
+
owner?: {
|
|
28
|
+
id: string;
|
|
29
|
+
type: 'User';
|
|
30
|
+
first_name?: string;
|
|
31
|
+
last_name?: string;
|
|
32
|
+
email?: string;
|
|
33
|
+
owner?: boolean;
|
|
34
|
+
time_zone?: string;
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
export declare type Mode = 'live' | 'test';
|
|
38
|
+
export interface TokenProviderAuthSettings {
|
|
39
|
+
accessToken: string;
|
|
40
|
+
organizationSlug: string;
|
|
41
|
+
domain: string;
|
|
42
|
+
mode: Mode;
|
|
43
|
+
timezone?: string;
|
|
44
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Mode } from './types';
|
|
2
|
+
export declare function getOrgSlugFromCurrentUrl(): string;
|
|
3
|
+
export declare function makeDashboardUrl({ domain, mode }: {
|
|
4
|
+
domain?: string;
|
|
5
|
+
mode?: Mode;
|
|
6
|
+
}): string;
|
|
7
|
+
export declare function makeReAuthenticationUrl(dashboardUrl: string, appName: string): string | undefined;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { TokenProviderRolePermissions, Mode } from './types';
|
|
2
|
+
export declare function isTokenExpired({ accessToken, compareTo }: {
|
|
3
|
+
accessToken: string;
|
|
4
|
+
compareTo: Date;
|
|
5
|
+
}): boolean;
|
|
6
|
+
interface ValidToken {
|
|
7
|
+
isValidToken: true;
|
|
8
|
+
accessToken: string;
|
|
9
|
+
mode: Mode;
|
|
10
|
+
organizationSlug: string;
|
|
11
|
+
permissions?: TokenProviderRolePermissions;
|
|
12
|
+
timezone?: string;
|
|
13
|
+
}
|
|
14
|
+
interface InvalidToken {
|
|
15
|
+
isValidToken: false;
|
|
16
|
+
}
|
|
17
|
+
export declare function isValidTokenForCurrentApp({ accessToken, clientKind, domain, currentApp, isProduction }: {
|
|
18
|
+
accessToken: string;
|
|
19
|
+
clientKind: string;
|
|
20
|
+
currentApp: string;
|
|
21
|
+
domain: string;
|
|
22
|
+
isProduction: boolean;
|
|
23
|
+
}): Promise<ValidToken | InvalidToken>;
|
|
24
|
+
export {};
|
package/dist/style.css
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@charset "UTF-8";*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e6e7e7}:before,:after{--tw-content: ""}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Manrope,ui-sans-serif,sans-serif;font-feature-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,Menlo,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#878888}input::placeholder,textarea::placeholder{opacity:1;color:#878888}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}[type=text],[type=email],[type=url],[type=password],[type=number],[type=date],[type=datetime-local],[type=month],[type=search],[type=tel],[type=time],[type=week],[multiple],textarea,select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#686e6e;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow: 0 0 #0000}[type=text]:focus,[type=email]:focus,[type=url]:focus,[type=password]:focus,[type=number]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=month]:focus,[type=search]:focus,[type=tel]:focus,[type=time]:focus,[type=week]:focus,[multiple]:focus,textarea:focus,select:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}input::-moz-placeholder,textarea::-moz-placeholder{color:#686e6e;opacity:1}input::placeholder,textarea::placeholder{color:#686e6e;opacity:1}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-date-and-time-value{min-height:1.5em}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-top:0;padding-bottom:0}select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23686E6E' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}[multiple]{background-image:initial;background-position:initial;background-repeat:unset;background-size:initial;padding-right:.75rem;-webkit-print-color-adjust:unset;print-color-adjust:unset}[type=checkbox],[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#686e6e;border-width:1px;--tw-shadow: 0 0 #0000}[type=checkbox]{border-radius:0}[type=radio]{border-radius:100%}[type=checkbox]:focus,[type=radio]:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 2px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}[type=checkbox]:checked,[type=radio]:checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}[type=checkbox]:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e")}[type=radio]:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e")}[type=checkbox]:checked:hover,[type=checkbox]:checked:focus,[type=radio]:checked:hover,[type=radio]:checked:focus{border-color:transparent;background-color:currentColor}[type=checkbox]:indeterminate{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}[type=checkbox]:indeterminate:hover,[type=checkbox]:indeterminate:focus{border-color:transparent;background-color:currentColor}[type=file]{background:unset;border-color:inherit;border-width:0;border-radius:0;padding:0;font-size:unset;line-height:inherit}[type=file]:focus{outline:1px solid ButtonText;outline:1px auto -webkit-focus-ring-color}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.container{width:100%}@media (min-width: 540px){.container{max-width:540px}}.pointer-events-none{pointer-events:none}.static{position:static}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0px;right:0px;bottom:0px;left:0px}.top-0{top:0px}.right-0{right:0px}.bottom-0{bottom:0px}.left-0{left:0px}.right-4{right:1rem}.top-\[-5px\]{top:-5px}.right-\[8px\]{right:8px}.right-11{right:2.75rem}.z-10{z-index:10}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:1rem;margin-bottom:1rem}.mb-4{margin-bottom:1rem}.mt-16{margin-top:4rem}.mt-auto{margin-top:auto}.mb-2{margin-bottom:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mb-6{margin-bottom:1.5rem}.mt-8{margin-top:2rem}.mb-8{margin-bottom:2rem}.mt-12{margin-top:3rem}.mb-12{margin-bottom:3rem}.mt-14{margin-top:3.5rem}.mb-14{margin-bottom:3.5rem}.mt-2{margin-top:.5rem}.-mb-\[2px\]{margin-bottom:-2px}.mr-\[2px\]{margin-right:2px}.mt-1{margin-top:.25rem}.mb-3{margin-bottom:.75rem}.ml-2{margin-left:.5rem}.mb-1{margin-bottom:.25rem}.ml-auto{margin-left:auto}.mt-\[5px\]{margin-top:5px}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-5{height:1.25rem}.h-\[38px\]{height:38px}.h-2{height:.5rem}.h-\[42px\]{height:42px}.h-full{height:100%}.h-6{height:1.5rem}.h-8{height:2rem}.h-\[30px\]{height:30px}.h-\[21px\]{height:21px}.h-10{height:2.5rem}.h-52{height:13rem}.h-1{height:.25rem}.h-72{height:18rem}.h-\[18px\]{height:18px}.h-16{height:4rem}.h-7{height:1.75rem}.h-\[53px\]{height:53px}.h-0{height:0px}.h-11{height:2.75rem}.min-h-screen{min-height:100vh}.w-5{width:1.25rem}.w-full{width:100%}.w-\[102px\]{width:102px}.w-\[46px\]{width:46px}.w-2{width:.5rem}.w-\[42px\]{width:42px}.w-6{width:1.5rem}.w-8{width:2rem}.w-36{width:9rem}.w-20{width:5rem}.w-24{width:6rem}.w-\[18px\]{width:18px}.w-32{width:8rem}.w-5\/12{width:41.666667%}.w-28{width:7rem}.w-0{width:0px}.min-w-\[150px\]{min-width:150px}.flex-1{flex:1 1 0%}.flex-none{flex:none}.flex-shrink-0{flex-shrink:0}.-rotate-90{--tw-rotate: -90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-75{--tw-scale-x: .75;--tw-scale-y: .75;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-2{gap:.5rem}.gap-8{gap:2rem}.gap-\[5px\]{gap:5px}.gap-5{gap:1.25rem}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.text-ellipsis{text-overflow:ellipsis}.whitespace-normal{white-space:normal}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.break-normal{overflow-wrap:normal;word-break:normal}.rounded{border-radius:.313rem}.rounded-md{border-radius:.625rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-2{border-width:2px}.border-0{border-width:0px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-l{border-left-width:1px}.border-l-\[6px\]{border-left-width:6px}.border-b-\[5px\]{border-bottom-width:5px}.border-r-\[6px\]{border-right-width:6px}.border-solid{border-style:solid}.border-dashed{border-style:dashed}.border-primary-light{border-color:#666effcc}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(219 220 220 / var(--tw-border-opacity))}.border-red{--tw-border-opacity: 1;border-color:rgb(255 101 107 / var(--tw-border-opacity))}.border-transparent{border-color:transparent}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(230 231 231 / var(--tw-border-opacity))}.border-gray-500{--tw-border-opacity: 1;border-color:rgb(104 110 110 / var(--tw-border-opacity))}.border-gray-100{--tw-border-opacity: 1;border-color:rgb(237 238 238 / var(--tw-border-opacity))}.border-gray-50{--tw-border-opacity: 1;border-color:rgb(248 248 248 / var(--tw-border-opacity))}.border-green{--tw-border-opacity: 1;border-color:rgb(31 218 138 / var(--tw-border-opacity))}.border-orange{--tw-border-opacity: 1;border-color:rgb(255 171 46 / var(--tw-border-opacity))}.border-teal{--tw-border-opacity: 1;border-color:rgb(5 84 99 / var(--tw-border-opacity))}.border-black{--tw-border-opacity: 1;border-color:rgb(16 17 17 / var(--tw-border-opacity))}.\!border-red{--tw-border-opacity: 1 !important;border-color:rgb(255 101 107 / var(--tw-border-opacity))!important}.\!border-green{--tw-border-opacity: 1 !important;border-color:rgb(31 218 138 / var(--tw-border-opacity))!important}.\!border-orange{--tw-border-opacity: 1 !important;border-color:rgb(255 171 46 / var(--tw-border-opacity))!important}.border-gray-600{--tw-border-opacity: 1;border-color:rgb(64 65 65 / var(--tw-border-opacity))}.border-b-gray-100{--tw-border-opacity: 1;border-bottom-color:rgb(237 238 238 / var(--tw-border-opacity))}.border-b-black{--tw-border-opacity: 1;border-bottom-color:rgb(16 17 17 / var(--tw-border-opacity))}.border-b-transparent{border-bottom-color:transparent}.border-l-transparent{border-left-color:transparent}.border-r-transparent{border-right-color:transparent}.bg-primary\/10{background-color:#666eff1a}.bg-gray-500\/10{background-color:#686e6e1a}.bg-orange\/10{background-color:#ffab2e1a}.bg-red\/10{background-color:#ff656b1a}.bg-green\/10{background-color:#1fda8a1a}.bg-primary{--tw-bg-opacity: 1;background-color:rgb(102 110 255 / var(--tw-bg-opacity))}.bg-gray-500{--tw-bg-opacity: 1;background-color:rgb(104 110 110 / var(--tw-bg-opacity))}.bg-orange{--tw-bg-opacity: 1;background-color:rgb(255 171 46 / var(--tw-bg-opacity))}.bg-red{--tw-bg-opacity: 1;background-color:rgb(255 101 107 / var(--tw-bg-opacity))}.bg-green{--tw-bg-opacity: 1;background-color:rgb(31 218 138 / var(--tw-bg-opacity))}.bg-black{--tw-bg-opacity: 1;background-color:rgb(16 17 17 / var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(248 248 248 / var(--tw-bg-opacity))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(219 220 220 / var(--tw-bg-opacity))}.bg-teal{--tw-bg-opacity: 1;background-color:rgb(5 84 99 / var(--tw-bg-opacity))}.p-6{padding:1.5rem}.p-3{padding:.75rem}.p-\[3px\]{padding:3px}.p-0{padding:0}.p-\[2px\]{padding:2px}.p-4{padding:1rem}.p-5{padding:1.25rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.px-2{padding-left:.5rem;padding-right:.5rem}.py-0{padding-top:0;padding-bottom:0}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.px-8{padding-left:2rem;padding-right:2rem}.py-4{padding-top:1rem;padding-bottom:1rem}.px-4{padding-left:1rem;padding-right:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-\[5px\]{padding-top:5px;padding-bottom:5px}.py-1{padding-top:.25rem;padding-bottom:.25rem}.pt-14{padding-top:3.5rem}.pl-6{padding-left:1.5rem}.pt-20{padding-top:5rem}.pb-3{padding-bottom:.75rem}.pt-10{padding-top:2.5rem}.pb-14{padding-bottom:3.5rem}.pt-2{padding-top:.5rem}.pb-4{padding-bottom:1rem}.pt-4{padding-top:1rem}.pt-1{padding-top:.25rem}.pr-9{padding-right:2.25rem}.pt-9{padding-top:2.25rem}.pb-24{padding-bottom:6rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,Menlo,monospace}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-lg{font-size:1.125rem}.text-10xl{font-size:8rem}.text-title{font-size:2rem}.text-base{font-size:1rem}.text-\[18px\]{font-size:18px}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-title{line-height:2.375rem}.leading-6{line-height:1.5rem}.leading-\[22px\]{line-height:22px}.text-primary{--tw-text-opacity: 1;color:rgb(102 110 255 / var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity: 1;color:rgb(104 110 110 / var(--tw-text-opacity))}.text-orange{--tw-text-opacity: 1;color:rgb(255 171 46 / var(--tw-text-opacity))}.text-red{--tw-text-opacity: 1;color:rgb(255 101 107 / var(--tw-text-opacity))}.text-green{--tw-text-opacity: 1;color:rgb(31 218 138 / var(--tw-text-opacity))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.text-black{--tw-text-opacity: 1;color:rgb(16 17 17 / var(--tw-text-opacity))}.text-gray-300{--tw-text-opacity: 1;color:rgb(219 220 220 / var(--tw-text-opacity))}.text-gray-100{--tw-text-opacity: 1;color:rgb(237 238 238 / var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity: 1;color:rgb(40 41 41 / var(--tw-text-opacity))}.text-teal{--tw-text-opacity: 1;color:rgb(5 84 99 / var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity: 1;color:rgb(135 136 136 / var(--tw-text-opacity))}.opacity-50{opacity:.5}.opacity-0{opacity:0}.opacity-40{opacity:.4}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.outline-0{outline-width:0px}.outline-offset-4{outline-offset:4px}.outline-primary-light{outline-color:#666effcc}.\!ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)!important}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-bg{transition-property:background;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-500{transition-duration:.5s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}body{--tw-text-opacity: 1;color:rgb(40 41 41 / var(--tw-text-opacity));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.placeholder\:text-gray-400::-moz-placeholder{--tw-text-opacity: 1;color:rgb(135 136 136 / var(--tw-text-opacity))}.placeholder\:text-gray-400::placeholder{--tw-text-opacity: 1;color:rgb(135 136 136 / var(--tw-text-opacity))}.after\:h-4:after{content:var(--tw-content);height:1rem}.after\:w-4:after{content:var(--tw-content);width:1rem}.after\:rounded-full:after{content:var(--tw-content);border-radius:9999px}.after\:bg-white:after{content:var(--tw-content);--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.after\:shadow-md:after{content:var(--tw-content);--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.after\:duration-300:after{content:var(--tw-content);transition-duration:.3s}.first\:border-l-0:first-child{border-left-width:0px}.first\:border-t:first-child{border-top-width:1px}.last\:mb-0:last-child{margin-bottom:0}.last\:border-b-0:last-child{border-bottom-width:0px}.last-of-type\:border-b:last-of-type{border-bottom-width:1px}.checked\:border-none:checked{border-style:none}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(248 248 248 / var(--tw-bg-opacity))}.hover\:bg-red\/10:hover{background-color:#ff656b1a}.hover\:bg-primary:hover{--tw-bg-opacity: 1;background-color:rgb(102 110 255 / var(--tw-bg-opacity))}.hover\:text-primary-light:hover{color:#666effcc}.hover\:text-gray-500:hover{--tw-text-opacity: 1;color:rgb(104 110 110 / var(--tw-text-opacity))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-80:hover{opacity:.8}.focus\:border-primary-light:focus{border-color:#666effcc}.focus\:shadow-none:focus{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:outline-0:focus{outline-width:0px}.focus\:ring-0:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:\!ring-0:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)!important}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-primary:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(102 110 255 / var(--tw-ring-opacity))}.focus\:ring-offset-0:focus{--tw-ring-offset-width: 0px}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.group:hover .group-hover\:underline{text-decoration-line:underline}.peer:checked~.peer-checked\:bg-primary{--tw-bg-opacity: 1;background-color:rgb(102 110 255 / var(--tw-bg-opacity))}.peer:checked~.peer-checked\:after\:translate-x-3:after{content:var(--tw-content);--tw-translate-x: .75rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width: 640px){.sm\:\!scale-100{--tw-scale-x: 1 !important;--tw-scale-y: 1 !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.sm\:\!px-5{padding-left:1.25rem!important;padding-right:1.25rem!important}}@media (min-width: 768px){.md\:\!mt-0{margin-top:0!important}.md\:\!flex-row{flex-direction:row!important}.md\:\!gap-4{gap:1rem!important}.md\:\!p-14{padding:3.5rem!important}.md\:\!px-0{padding-left:0!important;padding-right:0!important}.md\:\!py-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.md\:\!pr-0{padding-right:0!important}}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__navigation-icon:before{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{margin-left:-4px;position:absolute;width:0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after{box-sizing:content-box;position:absolute;border:8px solid transparent;height:0;width:1px;content:"";z-index:-1;border-width:8px;left:-8px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before{border-bottom-color:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{top:0;margin-top:-8px}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after{border-top:none;border-bottom-color:#f0f0f0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:after{top:0}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle:before{top:-1px;border-bottom-color:#aeaeae}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{bottom:0;margin-bottom:-8px}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after{border-bottom:none;border-top-color:#fff}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:after{bottom:0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle:before{bottom:-1px;border-top-color:#aeaeae}.react-datepicker-wrapper{display:inline-block;padding:0;border:0;width:100%}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative}.react-datepicker--time-only .react-datepicker__triangle{left:35px}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__triangle{position:absolute;left:50px}.react-datepicker-popper{z-index:1}.react-datepicker-popper[data-placement^=bottom]{padding-top:10px}.react-datepicker-popper[data-placement=bottom-end] .react-datepicker__triangle,.react-datepicker-popper[data-placement=top-end] .react-datepicker__triangle{left:auto;right:50px}.react-datepicker-popper[data-placement^=top]{padding-bottom:10px}.react-datepicker-popper[data-placement^=right]{padding-left:8px}.react-datepicker-popper[data-placement^=right] .react-datepicker__triangle{left:auto;right:42px}.react-datepicker-popper[data-placement^=left]{padding-right:8px}.react-datepicker-popper[data-placement^=left] .react-datepicker__triangle{left:42px;right:auto}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 2px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.3rem;position:absolute;right:-72px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:white;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + .85rem);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day-names,.react-datepicker__week{white-space:nowrap}.react-datepicker__day-names{margin-bottom:-8px}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__month--selected,.react-datepicker__month--in-selecting-range,.react-datepicker__month--in-range,.react-datepicker__quarter--selected,.react-datepicker__quarter--in-selecting-range,.react-datepicker__quarter--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__month--selected:hover,.react-datepicker__month--in-selecting-range:hover,.react-datepicker__month--in-range:hover,.react-datepicker__quarter--selected:hover,.react-datepicker__quarter--in-selecting-range:hover,.react-datepicker__quarter--in-range:hover{background-color:#1d5d90}.react-datepicker__month--disabled,.react-datepicker__quarter--disabled{color:#ccc;pointer-events:none}.react-datepicker__month--disabled:hover,.react-datepicker__quarter--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:hover,.react-datepicker__month-text:hover,.react-datepicker__quarter-text:hover,.react-datepicker__year-text:hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:hover,.react-datepicker__month-text--highlighted:hover,.react-datepicker__quarter-text--highlighted:hover,.react-datepicker__year-text--highlighted:hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:hover,.react-datepicker__day--in-selecting-range:hover,.react-datepicker__day--in-range:hover,.react-datepicker__month-text--selected:hover,.react-datepicker__month-text--in-selecting-range:hover,.react-datepicker__month-text--in-range:hover,.react-datepicker__quarter-text--selected:hover,.react-datepicker__quarter-text--in-selecting-range:hover,.react-datepicker__quarter-text--in-range:hover,.react-datepicker__year-text--selected:hover,.react-datepicker__year-text--in-selecting-range:hover,.react-datepicker__year-text--in-range:hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#2579ba;color:#fff}.react-datepicker__day--keyboard-selected:hover,.react-datepicker__month-text--keyboard-selected:hover,.react-datepicker__quarter-text--keyboard-selected:hover,.react-datepicker__year-text--keyboard-selected:hover{background-color:#1d5d90}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled:hover,.react-datepicker__month-text--disabled:hover,.react-datepicker__quarter-text--disabled:hover,.react-datepicker__year-text--disabled:hover{background-color:transparent}.react-datepicker__month-text.react-datepicker__month--selected:hover,.react-datepicker__month-text.react-datepicker__month--in-range:hover,.react-datepicker__month-text.react-datepicker__quarter--selected:hover,.react-datepicker__month-text.react-datepicker__quarter--in-range:hover,.react-datepicker__quarter-text.react-datepicker__month--selected:hover,.react-datepicker__quarter-text.react-datepicker__month--in-range:hover,.react-datepicker__quarter-text.react-datepicker__quarter--selected:hover,.react-datepicker__quarter-text.react-datepicker__quarter--in-range:hover{background-color:#216ba5}.react-datepicker__month-text:hover,.react-datepicker__quarter-text:hover{background-color:#f0f0f0}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"\d7"}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:3rem;line-height:3rem}@media (max-width: 400px),(max-height: 550px){.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:2rem;line-height:2rem}}.react-datepicker__portal .react-datepicker__current-month,.react-datepicker__portal .react-datepicker-time__header{font-size:1.44rem}.react-datepicker-popper .react-datepicker__triangle{display:none}.react-datepicker__header{background-color:#dbdcdc}.react-datepicker__day--selected{background-color:#666eff}.react-datepicker__day--keyboard-selected{background-color:#fff;color:#101111}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export declare type BadgeVariant = 'primary' | 'secondary' | 'warning' | 'danger' | 'success' | 'primary-solid' | 'secondary-solid' | 'warning-solid' | 'danger-solid' | 'success-solid';
|
|
3
|
+
interface Props extends Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> {
|
|
4
|
+
variant: BadgeVariant;
|
|
5
|
+
label: string;
|
|
6
|
+
}
|
|
7
|
+
declare function Badge({ variant, label, className, ...rest }: Props): JSX.Element;
|
|
8
|
+
declare namespace Badge {
|
|
9
|
+
var displayName: string;
|
|
10
|
+
}
|
|
11
|
+
export { Badge };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
interface BlockCodeProps {
|
|
2
|
+
/**
|
|
3
|
+
* Object to render as pre-formatted block
|
|
4
|
+
*/
|
|
5
|
+
json?: object;
|
|
6
|
+
}
|
|
7
|
+
declare function BlockCode({ json, ...rest }: BlockCodeProps): JSX.Element;
|
|
8
|
+
declare namespace BlockCode {
|
|
9
|
+
var displayName: string;
|
|
10
|
+
}
|
|
11
|
+
export { BlockCode };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
interface Props extends React.ButtonHTMLAttributes<HTMLButtonElement> {
|
|
4
|
+
/**
|
|
5
|
+
* Button content
|
|
6
|
+
*/
|
|
7
|
+
children: ReactNode;
|
|
8
|
+
/**
|
|
9
|
+
* Render a different variant
|
|
10
|
+
*/
|
|
11
|
+
variant?: ButtonVariant;
|
|
12
|
+
/**
|
|
13
|
+
* Set button size
|
|
14
|
+
*/
|
|
15
|
+
size?: ButtonSize;
|
|
16
|
+
}
|
|
17
|
+
export declare type ButtonVariant = 'primary' | 'secondary' | 'danger' | 'link';
|
|
18
|
+
export declare type ButtonSize = 'small' | 'regular' | 'large';
|
|
19
|
+
declare function Button({ children, className, size, variant, disabled, ...rest }: Props): JSX.Element;
|
|
20
|
+
declare namespace Button {
|
|
21
|
+
var displayName: string;
|
|
22
|
+
}
|
|
23
|
+
export { Button };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface Props {
|
|
3
|
+
/**
|
|
4
|
+
* css class name
|
|
5
|
+
*/
|
|
6
|
+
className?: string;
|
|
7
|
+
/**
|
|
8
|
+
* set min height as screen size. Default is `true`.
|
|
9
|
+
*/
|
|
10
|
+
minHeight?: boolean;
|
|
11
|
+
/**
|
|
12
|
+
* content to be rendered inside the container
|
|
13
|
+
*/
|
|
14
|
+
children: React.ReactNode;
|
|
15
|
+
}
|
|
16
|
+
declare function Container({ children, className, minHeight, ...rest }: Props): JSX.Element;
|
|
17
|
+
declare namespace Container {
|
|
18
|
+
var displayName: string;
|
|
19
|
+
}
|
|
20
|
+
export { Container };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
interface CopyToClipboardProps {
|
|
2
|
+
/**
|
|
3
|
+
* text to display that will be copied on button click
|
|
4
|
+
*/
|
|
5
|
+
value?: string;
|
|
6
|
+
/**
|
|
7
|
+
* css classes
|
|
8
|
+
*/
|
|
9
|
+
className?: string;
|
|
10
|
+
/**
|
|
11
|
+
* conditional prop to show a preview string containing the defined value before the copy button
|
|
12
|
+
*/
|
|
13
|
+
showValue?: boolean;
|
|
14
|
+
}
|
|
15
|
+
declare function CopyToClipboard({ value, className, showValue, ...rest }: CopyToClipboardProps): JSX.Element;
|
|
16
|
+
declare namespace CopyToClipboard {
|
|
17
|
+
var displayName: string;
|
|
18
|
+
}
|
|
19
|
+
export { CopyToClipboard };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
interface Props {
|
|
3
|
+
delayMs: number;
|
|
4
|
+
children: ReactNode;
|
|
5
|
+
}
|
|
6
|
+
declare function DelayShow({ delayMs, children }: Props): JSX.Element | null;
|
|
7
|
+
declare namespace DelayShow {
|
|
8
|
+
var displayName: string;
|
|
9
|
+
}
|
|
10
|
+
export { DelayShow };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
interface Props {
|
|
3
|
+
title: string;
|
|
4
|
+
description?: ReactNode;
|
|
5
|
+
action?: ReactNode;
|
|
6
|
+
className?: string;
|
|
7
|
+
icon?: 'stack' | 'none';
|
|
8
|
+
}
|
|
9
|
+
declare function EmptyState({ title, description, action, icon, className, ...rest }: Props): JSX.Element;
|
|
10
|
+
declare namespace EmptyState {
|
|
11
|
+
var displayName: string;
|
|
12
|
+
}
|
|
13
|
+
export { EmptyState };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface FormFooterProps extends Omit<React.HTMLAttributes<HTMLElement>, 'children'> {
|
|
3
|
+
buttonSubmit: JSX.Element;
|
|
4
|
+
buttonCancel?: JSX.Element;
|
|
5
|
+
}
|
|
6
|
+
declare function FormFooter({ buttonSubmit, buttonCancel, className, ...rest }: FormFooterProps): JSX.Element;
|
|
7
|
+
declare namespace FormFooter {
|
|
8
|
+
var displayName: string;
|
|
9
|
+
}
|
|
10
|
+
export { FormFooter };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare type HintIcon = 'bulb';
|
|
2
|
+
export interface HintProps {
|
|
3
|
+
icon?: HintIcon;
|
|
4
|
+
className?: string;
|
|
5
|
+
children: ElementChildren;
|
|
6
|
+
}
|
|
7
|
+
declare function Hint({ icon, className, children, ...rest }: HintProps): JSX.Element;
|
|
8
|
+
declare namespace Hint {
|
|
9
|
+
var displayName: string;
|
|
10
|
+
}
|
|
11
|
+
export { Hint };
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface IconProps extends React.HTMLAttributes<HTMLDivElement>, IconSvgProps {
|
|
3
|
+
/**
|
|
4
|
+
* Name of the icon to display
|
|
5
|
+
*/
|
|
6
|
+
name: keyof typeof IconSvg;
|
|
7
|
+
/**
|
|
8
|
+
* Background color, `none` for no background
|
|
9
|
+
*/
|
|
10
|
+
background?: 'green' | 'orange' | 'red' | 'gray' | 'teal' | 'white' | 'none';
|
|
11
|
+
/**
|
|
12
|
+
* padding around the icon can bne: 'none' | 'small' | 'large'
|
|
13
|
+
*/
|
|
14
|
+
gap?: 'none' | 'small' | 'large';
|
|
15
|
+
/**
|
|
16
|
+
* Icon size as css unit (eg: 32px, 4rem) or number as pixels value.
|
|
17
|
+
* Works only when background is `none`
|
|
18
|
+
*/
|
|
19
|
+
size?: string | number;
|
|
20
|
+
}
|
|
21
|
+
declare function Icon({ name, background, gap, size, ...rest }: IconProps): JSX.Element;
|
|
22
|
+
declare namespace Icon {
|
|
23
|
+
var displayName: string;
|
|
24
|
+
}
|
|
25
|
+
export { Icon };
|
|
26
|
+
interface IconSvgProps extends Pick<IconProps, 'size'> {
|
|
27
|
+
}
|
|
28
|
+
declare const IconSvg: {
|
|
29
|
+
x: ({ size }: IconSvgProps) => JSX.Element;
|
|
30
|
+
caretRight: ({ size }: IconSvgProps) => JSX.Element;
|
|
31
|
+
check: ({ size }: IconSvgProps) => JSX.Element;
|
|
32
|
+
arrowDown: ({ size }: IconSvgProps) => JSX.Element;
|
|
33
|
+
arrowLeft: ({ size }: IconSvgProps) => JSX.Element;
|
|
34
|
+
warning: ({ size }: IconSvgProps) => JSX.Element;
|
|
35
|
+
arrowClockwise: ({ size }: IconSvgProps) => JSX.Element;
|
|
36
|
+
eye: ({ size }: IconSvgProps) => JSX.Element;
|
|
37
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
interface LegendProps {
|
|
3
|
+
/**
|
|
4
|
+
* Main section title
|
|
5
|
+
*/
|
|
6
|
+
title?: ReactNode;
|
|
7
|
+
/**
|
|
8
|
+
* This will render a button on the right side of the row
|
|
9
|
+
*/
|
|
10
|
+
actionButton?: ReactNode;
|
|
11
|
+
/**
|
|
12
|
+
* CSS classes
|
|
13
|
+
*/
|
|
14
|
+
className?: string;
|
|
15
|
+
}
|
|
16
|
+
declare function Legend({ title, actionButton, className, ...rest }: LegendProps): JSX.Element;
|
|
17
|
+
declare namespace Legend {
|
|
18
|
+
var displayName: string;
|
|
19
|
+
}
|
|
20
|
+
export { Legend };
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
import { BadgeVariant } from './Badge';
|
|
4
|
+
export interface PageHeadingProps {
|
|
5
|
+
/**
|
|
6
|
+
* Main page title wrapped in a h1 element
|
|
7
|
+
*/
|
|
8
|
+
title: ReactNode;
|
|
9
|
+
/**
|
|
10
|
+
* A short text that helps to describe the page
|
|
11
|
+
*/
|
|
12
|
+
description?: ReactNode;
|
|
13
|
+
/**
|
|
14
|
+
* Optional callback that will be called when "go back" button is pressed
|
|
15
|
+
* If missing, the "go back" button will not be shown
|
|
16
|
+
*/
|
|
17
|
+
onGoBack?: () => void;
|
|
18
|
+
/**
|
|
19
|
+
* If `true` removes element vertical paddings
|
|
20
|
+
*/
|
|
21
|
+
noGap?: boolean;
|
|
22
|
+
/**
|
|
23
|
+
* When set, it will render a badge (warning variant)
|
|
24
|
+
*/
|
|
25
|
+
badgeLabel?: string;
|
|
26
|
+
/**
|
|
27
|
+
* When set, it will render a badge (default as warning variant) above the title
|
|
28
|
+
*/
|
|
29
|
+
badgeVariant?: BadgeVariant;
|
|
30
|
+
/**
|
|
31
|
+
* When set, it will render a button on the right side of the first row
|
|
32
|
+
*/
|
|
33
|
+
actionButton?: React.ReactNode;
|
|
34
|
+
}
|
|
35
|
+
declare function PageHeading({ noGap, badgeLabel, onGoBack, title, description, badgeVariant, actionButton, ...rest }: PageHeadingProps): JSX.Element;
|
|
36
|
+
declare namespace PageHeading {
|
|
37
|
+
var displayName: string;
|
|
38
|
+
}
|
|
39
|
+
export { PageHeading };
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export interface PaginationProps {
|
|
2
|
+
/**
|
|
3
|
+
* CSS classes
|
|
4
|
+
*/
|
|
5
|
+
className?: string;
|
|
6
|
+
/**
|
|
7
|
+
* You might want to set this as `true` on page change when new page is loading
|
|
8
|
+
*/
|
|
9
|
+
isDisabled?: boolean;
|
|
10
|
+
/**
|
|
11
|
+
* the number of the current/active page
|
|
12
|
+
*/
|
|
13
|
+
currentPage: number;
|
|
14
|
+
/**
|
|
15
|
+
* Callback invoked when a different page button is clicked
|
|
16
|
+
*/
|
|
17
|
+
onChangePageRequest: (pageNumber: number) => void;
|
|
18
|
+
/**
|
|
19
|
+
* Total number of pages
|
|
20
|
+
*/
|
|
21
|
+
pageCount: number;
|
|
22
|
+
}
|
|
23
|
+
declare function Pagination({ className, currentPage, isDisabled, onChangePageRequest, pageCount, ...rest }: PaginationProps): JSX.Element | null;
|
|
24
|
+
declare namespace Pagination {
|
|
25
|
+
var displayName: string;
|
|
26
|
+
}
|
|
27
|
+
export { Pagination };
|