From 37ccfdfb31a847298d3038e3b31d81901cd772e3 Mon Sep 17 00:00:00 2001 From: Gregor Wassmann Date: Fri, 24 Mar 2023 22:20:50 +0100 Subject: [PATCH] chore: rename `Theme` to `GlobalTheme` Carbon Design System provides the idea of [inline theming](https://carbondesignsystem.com/guidelines/color/implementation/#how-inline-theming-works). As was mentioned in #1648 the Carbon standard implementation is [documented here](https://react.carbondesignsystem.com/?path=/docs/components-theme--playground). It says: > The `GlobalTheme` and `Theme` components allow you to specify the theme for a page, or for a part of a page, respectively. `Theme` is most often used to implement inline theming where you can style a portion of your page with a particular theme. What this means for `carbon-components-svelte` is that we should rename the existing `Theme` component to `GlobalTheme`. This leads us a tiny bit closer to [feature parity with Carbon v11](https://github.com/carbon-design-system/carbon-components-svelte/discussions/1614) and gives room for a new component dedicated to v11 inline theming. --- COMPONENT_INDEX.md | 66 +++--- docs/src/COMPONENT_API.json | 222 +++++++++--------- .../framed/GlobalTheme/GlobalTheme.svelte | 4 +- .../GlobalTheme/GlobalThemePersist.svelte | 4 +- .../GlobalTheme/GlobalThemeSelect.svelte | 4 +- .../GlobalThemeSelectCustom.svelte | 4 +- .../GlobalTheme/GlobalThemeToggle.svelte | 4 +- .../GlobalThemeToggleCustom.svelte | 4 +- .../GlobalTheme/GlobalThemeTokens.svelte | 4 +- src/GlobalTheme/index.js | 2 +- src/index.js | 2 +- tests/GlobalTheme.test.svelte | 6 +- types/GlobalTheme/GlobalTheme.svelte.d.ts | 6 +- types/index.d.ts | 2 +- 14 files changed, 167 insertions(+), 167 deletions(-) diff --git a/COMPONENT_INDEX.md b/COMPONENT_INDEX.md index f572789659..236a213a1c 100644 --- a/COMPONENT_INDEX.md +++ b/COMPONENT_INDEX.md @@ -50,6 +50,7 @@ - [`FormGroup`](#formgroup) - [`FormItem`](#formitem) - [`FormLabel`](#formlabel) +- [`GlobalTheme`](#globaltheme) - [`Grid`](#grid) - [`Header`](#header) - [`HeaderAction`](#headeraction) @@ -148,7 +149,6 @@ - [`TextAreaSkeleton`](#textareaskeleton) - [`TextInput`](#textinput) - [`TextInputSkeleton`](#textinputskeleton) -- [`Theme`](#theme) - [`Tile`](#tile) - [`TileGroup`](#tilegroup) - [`TimePicker`](#timepicker) @@ -1538,6 +1538,38 @@ None. | mouseenter | forwarded | -- | | mouseleave | forwarded | -- | +## `GlobalTheme` + +### Types + +```ts +export type CarbonTheme = "white" | "g10" | "g80" | "g90" | "g100"; +``` + +### Props + +| Prop name | Required | Kind | Reactive | Type | Default value | Description | +| :--------- | :------- | :--------------- | :------- | -------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------ | +| theme | No | let | Yes | CarbonTheme | "white" | Set the current Carbon theme | +| tokens | No | let | No | { [token: string]: any; } | {} | Customize a theme with your own tokens
@see https://carbondesignsystem.com/guidelines/themes/overview#customizing-a-theme | +| persist | No | let | No | boolean | false | Set to `true` to persist the theme using window.localStorage | +| persistKey | No | let | No | string | "theme" | Specify the local storage key | +| render | No | let | No | "toggle" | "select" | undefined | Render a toggle or select dropdown to control the theme | +| toggle | No | let | No | import("../Toggle/Toggle").ToggleProps & { themes?: [labelA: CarbonTheme, labelB: CarbonTheme]; } | { themes: ["white", "g100"], labelA: "", labelB: "", labelText: "Dark mode", hideLabel: false, } | Override the default toggle props | +| select | No | let | No | import("../Select/Select").SelectProps & { themes?: CarbonTheme[]; } | { themes: themeKeys, labelText: "Themes", hideLabel: false, } | Override the default select props | + +### Slots + +| Slot name | Default | Props | Fallback | +| :-------- | :------ | :------------------------------------ | :------- | +| -- | Yes | { theme: CarbonTheme; } | -- | + +### Events + +| Event name | Type | Detail | +| :--------- | :--------- | :----------------------------------- | +| update | dispatched | { theme: CarbonTheme; } | + ## `Grid` ### Props @@ -4159,38 +4191,6 @@ None. | mouseenter | forwarded | -- | | mouseleave | forwarded | -- | -## `Theme` - -### Types - -```ts -export type CarbonTheme = "white" | "g10" | "g80" | "g90" | "g100"; -``` - -### Props - -| Prop name | Required | Kind | Reactive | Type | Default value | Description | -| :--------- | :------- | :--------------- | :------- | -------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------ | -| theme | No | let | Yes | CarbonTheme | "white" | Set the current Carbon theme | -| tokens | No | let | No | { [token: string]: any; } | {} | Customize a theme with your own tokens
@see https://carbondesignsystem.com/guidelines/themes/overview#customizing-a-theme | -| persist | No | let | No | boolean | false | Set to `true` to persist the theme using window.localStorage | -| persistKey | No | let | No | string | "theme" | Specify the local storage key | -| render | No | let | No | "toggle" | "select" | undefined | Render a toggle or select dropdown to control the theme | -| toggle | No | let | No | import("../Toggle/Toggle").ToggleProps & { themes?: [labelA: CarbonTheme, labelB: CarbonTheme]; } | { themes: ["white", "g100"], labelA: "", labelB: "", labelText: "Dark mode", hideLabel: false, } | Override the default toggle props | -| select | No | let | No | import("../Select/Select").SelectProps & { themes?: CarbonTheme[]; } | { themes: themeKeys, labelText: "Themes", hideLabel: false, } | Override the default select props | - -### Slots - -| Slot name | Default | Props | Fallback | -| :-------- | :------ | :------------------------------------ | :------- | -| -- | Yes | { theme: CarbonTheme; } | -- | - -### Events - -| Event name | Type | Detail | -| :--------- | :--------- | :----------------------------------- | -| update | dispatched | { theme: CarbonTheme; } | - ## `Tile` ### Props diff --git a/docs/src/COMPONENT_API.json b/docs/src/COMPONENT_API.json index 578a31d6e8..346fdfe102 100644 --- a/docs/src/COMPONENT_API.json +++ b/docs/src/COMPONENT_API.json @@ -4579,6 +4579,117 @@ "typedefs": [], "rest_props": { "type": "Element", "name": "label" } }, + { + "moduleName": "GlobalTheme", + "filePath": "src/GlobalTheme/GlobalTheme.svelte", + "props": [ + { + "name": "theme", + "kind": "let", + "description": "Set the current Carbon theme", + "type": "CarbonTheme", + "value": "\"white\"", + "isFunction": false, + "isFunctionDeclaration": false, + "isRequired": false, + "constant": false, + "reactive": true + }, + { + "name": "tokens", + "kind": "let", + "description": "Customize a theme with your own tokens\n@see https://carbondesignsystem.com/guidelines/themes/overview#customizing-a-theme", + "type": "{ [token: string]: any; }", + "value": "{}", + "isFunction": false, + "isFunctionDeclaration": false, + "isRequired": false, + "constant": false, + "reactive": false + }, + { + "name": "persist", + "kind": "let", + "description": "Set to `true` to persist the theme using window.localStorage", + "type": "boolean", + "value": "false", + "isFunction": false, + "isFunctionDeclaration": false, + "isRequired": false, + "constant": false, + "reactive": false + }, + { + "name": "persistKey", + "kind": "let", + "description": "Specify the local storage key", + "type": "string", + "value": "\"theme\"", + "isFunction": false, + "isFunctionDeclaration": false, + "isRequired": false, + "constant": false, + "reactive": false + }, + { + "name": "render", + "kind": "let", + "description": "Render a toggle or select dropdown to control the theme", + "type": "\"toggle\" | \"select\"", + "isFunction": false, + "isFunctionDeclaration": false, + "isRequired": false, + "constant": false, + "reactive": false + }, + { + "name": "toggle", + "kind": "let", + "description": "Override the default toggle props", + "type": "import(\"../Toggle/Toggle\").ToggleProps & { themes?: [labelA: CarbonTheme, labelB: CarbonTheme]; }", + "value": "{ themes: [\"white\", \"g100\"], labelA: \"\", labelB: \"\", labelText: \"Dark mode\", hideLabel: false, }", + "isFunction": false, + "isFunctionDeclaration": false, + "isRequired": false, + "constant": false, + "reactive": false + }, + { + "name": "select", + "kind": "let", + "description": "Override the default select props", + "type": "import(\"../Select/Select\").SelectProps & { themes?: CarbonTheme[]; }", + "value": "{ themes: themeKeys, labelText: \"Themes\", hideLabel: false, }", + "isFunction": false, + "isFunctionDeclaration": false, + "isRequired": false, + "constant": false, + "reactive": false + } + ], + "moduleExports": [], + "slots": [ + { + "name": "__default__", + "default": true, + "slot_props": "{ theme: CarbonTheme; }" + } + ], + "events": [ + { + "type": "dispatched", + "name": "update", + "detail": "{ theme: CarbonTheme; }" + } + ], + "typedefs": [ + { + "type": "\"white\" | \"g10\" | \"g80\" | \"g90\" | \"g100\"", + "name": "CarbonTheme", + "ts": "type CarbonTheme = \"white\" | \"g10\" | \"g80\" | \"g90\" | \"g100\"" + } + ] + }, { "moduleName": "Grid", "filePath": "src/Grid/Grid.svelte", @@ -12837,117 +12948,6 @@ "typedefs": [], "rest_props": { "type": "Element", "name": "div" } }, - { - "moduleName": "Theme", - "filePath": "src/Theme/Theme.svelte", - "props": [ - { - "name": "theme", - "kind": "let", - "description": "Set the current Carbon theme", - "type": "CarbonTheme", - "value": "\"white\"", - "isFunction": false, - "isFunctionDeclaration": false, - "isRequired": false, - "constant": false, - "reactive": true - }, - { - "name": "tokens", - "kind": "let", - "description": "Customize a theme with your own tokens\n@see https://carbondesignsystem.com/guidelines/themes/overview#customizing-a-theme", - "type": "{ [token: string]: any; }", - "value": "{}", - "isFunction": false, - "isFunctionDeclaration": false, - "isRequired": false, - "constant": false, - "reactive": false - }, - { - "name": "persist", - "kind": "let", - "description": "Set to `true` to persist the theme using window.localStorage", - "type": "boolean", - "value": "false", - "isFunction": false, - "isFunctionDeclaration": false, - "isRequired": false, - "constant": false, - "reactive": false - }, - { - "name": "persistKey", - "kind": "let", - "description": "Specify the local storage key", - "type": "string", - "value": "\"theme\"", - "isFunction": false, - "isFunctionDeclaration": false, - "isRequired": false, - "constant": false, - "reactive": false - }, - { - "name": "render", - "kind": "let", - "description": "Render a toggle or select dropdown to control the theme", - "type": "\"toggle\" | \"select\"", - "isFunction": false, - "isFunctionDeclaration": false, - "isRequired": false, - "constant": false, - "reactive": false - }, - { - "name": "toggle", - "kind": "let", - "description": "Override the default toggle props", - "type": "import(\"../Toggle/Toggle\").ToggleProps & { themes?: [labelA: CarbonTheme, labelB: CarbonTheme]; }", - "value": "{ themes: [\"white\", \"g100\"], labelA: \"\", labelB: \"\", labelText: \"Dark mode\", hideLabel: false, }", - "isFunction": false, - "isFunctionDeclaration": false, - "isRequired": false, - "constant": false, - "reactive": false - }, - { - "name": "select", - "kind": "let", - "description": "Override the default select props", - "type": "import(\"../Select/Select\").SelectProps & { themes?: CarbonTheme[]; }", - "value": "{ themes: themeKeys, labelText: \"Themes\", hideLabel: false, }", - "isFunction": false, - "isFunctionDeclaration": false, - "isRequired": false, - "constant": false, - "reactive": false - } - ], - "moduleExports": [], - "slots": [ - { - "name": "__default__", - "default": true, - "slot_props": "{ theme: CarbonTheme; }" - } - ], - "events": [ - { - "type": "dispatched", - "name": "update", - "detail": "{ theme: CarbonTheme; }" - } - ], - "typedefs": [ - { - "type": "\"white\" | \"g10\" | \"g80\" | \"g90\" | \"g100\"", - "name": "CarbonTheme", - "ts": "type CarbonTheme = \"white\" | \"g10\" | \"g80\" | \"g90\" | \"g100\"" - } - ] - }, { "moduleName": "Tile", "filePath": "src/Tile/Tile.svelte", diff --git a/docs/src/pages/framed/GlobalTheme/GlobalTheme.svelte b/docs/src/pages/framed/GlobalTheme/GlobalTheme.svelte index b99cb54071..04b4e5412c 100644 --- a/docs/src/pages/framed/GlobalTheme/GlobalTheme.svelte +++ b/docs/src/pages/framed/GlobalTheme/GlobalTheme.svelte @@ -1,6 +1,6 @@ - + {#each ["white", "g10", "g80", "g90", "g100"] as value} diff --git a/docs/src/pages/framed/GlobalTheme/GlobalThemePersist.svelte b/docs/src/pages/framed/GlobalTheme/GlobalThemePersist.svelte index bd43a91a08..1726e7e318 100644 --- a/docs/src/pages/framed/GlobalTheme/GlobalThemePersist.svelte +++ b/docs/src/pages/framed/GlobalTheme/GlobalThemePersist.svelte @@ -1,6 +1,6 @@ - + {#each ["white", "g10", "g80", "g90", "g100"] as value} diff --git a/docs/src/pages/framed/GlobalTheme/GlobalThemeSelect.svelte b/docs/src/pages/framed/GlobalTheme/GlobalThemeSelect.svelte index 3d96752660..4c005d9595 100644 --- a/docs/src/pages/framed/GlobalTheme/GlobalThemeSelect.svelte +++ b/docs/src/pages/framed/GlobalTheme/GlobalThemeSelect.svelte @@ -1,5 +1,5 @@ - + diff --git a/docs/src/pages/framed/GlobalTheme/GlobalThemeSelectCustom.svelte b/docs/src/pages/framed/GlobalTheme/GlobalThemeSelectCustom.svelte index 0a8ad4b13e..b9f15c10f2 100644 --- a/docs/src/pages/framed/GlobalTheme/GlobalThemeSelectCustom.svelte +++ b/docs/src/pages/framed/GlobalTheme/GlobalThemeSelectCustom.svelte @@ -1,8 +1,8 @@ - - + diff --git a/docs/src/pages/framed/GlobalTheme/GlobalThemeToggleCustom.svelte b/docs/src/pages/framed/GlobalTheme/GlobalThemeToggleCustom.svelte index 635bd7b340..7e222ec589 100644 --- a/docs/src/pages/framed/GlobalTheme/GlobalThemeToggleCustom.svelte +++ b/docs/src/pages/framed/GlobalTheme/GlobalThemeToggleCustom.svelte @@ -1,8 +1,8 @@ - - - import { Theme } from "../types"; - import type { CarbonTheme } from "../types/Theme/Theme.svelte"; + import { GlobalTheme } from "../types"; + import type { CarbonTheme } from "../types/GlobalTheme/GlobalTheme.svelte"; let theme: CarbonTheme = "g10"; - }, { default: { theme: CarbonTheme } } > {} diff --git a/types/index.d.ts b/types/index.d.ts index 1174ce26c1..bb045cfa42 100644 --- a/types/index.d.ts +++ b/types/index.d.ts @@ -127,7 +127,7 @@ export { default as TextAreaSkeleton } from "./TextArea/TextAreaSkeleton.svelte" export { default as TextInput } from "./TextInput/TextInput.svelte"; export { default as TextInputSkeleton } from "./TextInput/TextInputSkeleton.svelte"; export { default as PasswordInput } from "./TextInput/PasswordInput.svelte"; -export { default as Theme } from "./Theme/Theme.svelte"; +export { default as GlobalTheme } from "./GlobalTheme/GlobalTheme.svelte"; export { default as Tile } from "./Tile/Tile.svelte"; export { default as ClickableTile } from "./Tile/ClickableTile.svelte"; export { default as ExpandableTile } from "./Tile/ExpandableTile.svelte";