Skip to content

Commit

Permalink
rework hooks, fix useAppColorScheme init, expose memo-buster
Browse files Browse the repository at this point in the history
  • Loading branch information
jaredh159 committed Feb 12, 2024
1 parent 96c9740 commit 1fa5e42
Show file tree
Hide file tree
Showing 11 changed files with 851 additions and 717 deletions.
2 changes: 1 addition & 1 deletion jest.config.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@
"transform": {
"^.+\\.tsx?$": "ts-jest"
},
"testRegex": "__tests__/.*spec\\.ts$"
"testRegex": "__tests__/.*spec\\.tsx?$"
}
53 changes: 51 additions & 2 deletions migration-guide.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,53 @@
## Migrating from 2.x.x
# Migrating to 4.x.x

## 🚨 Breaking Changes

### `useAppColorScheme()` Initialization

_NB: If you were not using dark mode, or were only observing the device's color scheme
(which is the default and most common), you can ignore this section._

The mechanism for opting-out of listening to device color scheme changes in order to
_control color scheme manually_ from your app has changed in `v4.0.0`. First,
`useAppColorScheme()` no longer takes a second parameter for initialization:

```diff
-const [colorScheme, ...] = useAppColorScheme(tw, `dark`);
+const [colorScheme, ...] = useAppColorScheme(tw);
```

This means that `useAppColorScheme()` is now safe to use multiple times in your app,
anywhere you need to read or modify the app color scheme. As part of this change the
**initialization has moved** to `useDeviceContext()` (which should only ever be called
once, at the root of the app):

```diff
useDeviceContext(tw, {
- withDeviceColorScheme: false,
+ observeDeviceColorSchemeChanges: false,
+ initialColorScheme: "light",
});
```

The value for `initialColorScheme` can be `"light"`, `"dark"`, or `"device"`. `device`
means initialize to the _current_ color scheme of the device one time before the app
assumes control.

_Please note:_ there was a bug in `v3.x.x` when omitting the optional initialization param
(now removed) passed to `useAppColorScheme()` that caused the color scheme to not be
correctly initialized when the device was in **dark mode**. Version `4.x.x` fixes this
issue, but the bugfix can result in an observable difference in your app's initialization
for users whose devices are set to dark mode. If you want to replicate the former behavior
before the bug was fixed, you should explicitly pass `"light"` for `initialColorScheme`
when calling `useDeviceContext()`.

## New Features

The main `tw` object now exposes a `.memoBuster` string property, which can be useful for
resolving some simple memoization re-render failure issues. See
[here for more](./readme.md#memo-buster).

# Migrating to 3.x.x

**Color renames**. In line with the
[upgrade guide](https://tailwindcss.com/docs/upgrade-guide#removed-color-aliases),
Expand All @@ -18,7 +67,7 @@ feature that would help your development, please
and include any libraries / hooks that could help someone in the community put a PR
together.

## Migrating from 1.x.x
# Migrating to 2.x.x

**1.** During the rewrite, the package name on npm was changed to `twrnc`. To remove the
old library and install v2, run:
Expand Down
Loading

0 comments on commit 1fa5e42

Please sign in to comment.