diff --git a/.changeset/clean-bears-fold.md b/.changeset/clean-bears-fold.md
new file mode 100644
index 00000000000..50d1e2c21cb
--- /dev/null
+++ b/.changeset/clean-bears-fold.md
@@ -0,0 +1,11 @@
+---
+'@clerk/clerk-js': minor
+'@clerk/themes': patch
+'@clerk/types': minor
+---
+
+Introduces three new element appearence descriptors:
+
+- `tableHead` let's you customize the tables head styles.
+- `paginationButton` let's you customize the pagination buttons.
+- `paginationRowText` let's you customize the pagination text.
diff --git a/packages/clerk-js/src/ui/components/OrganizationProfile/MemberListTable.tsx b/packages/clerk-js/src/ui/components/OrganizationProfile/MemberListTable.tsx
index 43a5b19e2f4..5e4fbcf8208 100644
--- a/packages/clerk-js/src/ui/components/OrganizationProfile/MemberListTable.tsx
+++ b/packages/clerk-js/src/ui/components/OrganizationProfile/MemberListTable.tsx
@@ -2,7 +2,20 @@ import type { MembershipRole } from '@clerk/types';
import React from 'react';
import type { LocalizationKey } from '../../customizables';
-import { Col, Flex, Spinner, Table, Tbody, Td, Text, Th, Thead, Tr, useLocalizations } from '../../customizables';
+import {
+ Col,
+ descriptors,
+ Flex,
+ Spinner,
+ Table,
+ Tbody,
+ Td,
+ Text,
+ Th,
+ Thead,
+ Tr,
+ useLocalizations,
+} from '../../customizables';
import { Pagination, Select, SelectButton, SelectOptionList } from '../../elements';
import type { PropsOfComponent } from '../../styledSystem';
import { roleLocalizationKey } from '../../utils';
@@ -54,6 +67,7 @@ export const DataTable = (props: MembersListTableProps) => {
{headers.map((h, index) => (
|
diff --git a/packages/clerk-js/src/ui/customizables/elementDescriptors.ts b/packages/clerk-js/src/ui/customizables/elementDescriptors.ts
index 675216aa3fb..2a98c8463e5 100644
--- a/packages/clerk-js/src/ui/customizables/elementDescriptors.ts
+++ b/packages/clerk-js/src/ui/customizables/elementDescriptors.ts
@@ -190,6 +190,11 @@ export const APPEARANCE_KEYS = containsAllElementsConfigKeys([
'tabButton',
'tabListContainer',
+ 'tableHead',
+
+ 'paginationButton',
+ 'paginationRowText',
+
'selectButton',
'selectSearchInput',
'selectButtonIcon',
diff --git a/packages/clerk-js/src/ui/elements/Pagination.tsx b/packages/clerk-js/src/ui/elements/Pagination.tsx
index 391a06b3f9e..81a358cbbda 100644
--- a/packages/clerk-js/src/ui/elements/Pagination.tsx
+++ b/packages/clerk-js/src/ui/elements/Pagination.tsx
@@ -1,6 +1,6 @@
import { useState } from 'react';
-import { Button, Flex, localizationKeys, Text } from '../customizables';
+import { Button, descriptors, Flex, localizationKeys, Text } from '../customizables';
import type { PropsOfComponent } from '../styledSystem';
import { mqu } from '../styledSystem';
import { range } from '../utils';
@@ -31,6 +31,7 @@ const PageButton = (props: PropsOfComponent & { isActive?: boolea
},
sx,
]}
+ elementDescriptor={descriptors.paginationButton}
{...rest}
/>
);
@@ -55,29 +56,30 @@ const RowInformation = (props: RowInfoProps) => {
({
- color: t.colors.$blackAlpha700,
- })}
+ elementDescriptor={descriptors.paginationRowText}
+ elementId={descriptors.paginationRowText?.setId('displaying')}
+ sx={t => ({ opacity: t.opacity.$inactive })}
localizationKey={localizationKeys('paginationRowText__displaying')}
/>{' '}
({ fontWeight: t.fontWeights.$medium })}
>
{startingRow === endingRow && [0, 1].includes(startingRow) ? startingRow : `${startingRow} – ${endingRow}`}
{' '}
({
- color: t.colors.$blackAlpha700,
- })}
+ elementDescriptor={descriptors.paginationRowText}
+ elementId={descriptors.paginationRowText?.setId('displaying')}
+ sx={t => ({ opacity: t.opacity.$inactive })}
localizationKey={localizationKeys('paginationRowText__of')}
/>{' '}
({
- color: t.colors.$blackAlpha700,
- })}
+ elementDescriptor={descriptors.paginationRowText}
+ elementId={descriptors.paginationRowText?.setId('allRowsCount')}
>
{allRowsCount}
diff --git a/packages/themes/src/createTheme.ts b/packages/themes/src/createTheme.ts
index 7eb78953bf6..916eaf71247 100644
--- a/packages/themes/src/createTheme.ts
+++ b/packages/themes/src/createTheme.ts
@@ -4,12 +4,12 @@ import type { Appearance, BaseTheme, DeepPartial, Elements, Theme } from '@clerk
import type { InternalTheme } from '../../clerk-js/src/ui/foundations';
-type CreateClerkThemeParams = DeepPartial & {
+interface CreateClerkThemeParams extends DeepPartial {
/**
* {@link Theme.elements}
*/
elements?: Elements | ((params: { theme: InternalTheme }) => Elements);
-};
+}
export const unstable_createTheme = (appearance: Appearance): BaseTheme => {
// Placeholder method that might hande more transformations in the future
diff --git a/packages/types/src/appearance.ts b/packages/types/src/appearance.ts
index a06b59352de..657cd1cb4f7 100644
--- a/packages/types/src/appearance.ts
+++ b/packages/types/src/appearance.ts
@@ -344,6 +344,11 @@ export type ElementsConfig = {
tabButton: WithOptions;
tabListContainer: WithOptions;
+ tableHead: WithOptions;
+
+ paginationButton: WithOptions;
+ paginationRowText: WithOptions<'allRowsCount' | 'rowsCount' | 'displaying', never, never>;
+
selectButton: WithOptions;
selectSearchInput: WithOptions;
selectButtonIcon: WithOptions;