Files
url_tracker_tool/node_modules/fast-equals/recipes/using-meta-in-comparison.md
Andrei 58f8093689 Rebrand from 'Redirect Intelligence v2' to 'URL Tracker Tool V2' throughout UI
- Updated all component headers and documentation
- Changed navbar and footer branding
- Updated homepage hero badge
- Modified page title in index.html
- Simplified footer text to 'Built with ❤️'
- Consistent V2 capitalization across all references
2025-08-19 19:12:23 +00:00

21 lines
693 B
Markdown

# Using `meta` in comparison
Sometimes a "pure" equality between two objects is insufficient, because the comparison relies on some external state. While these kinds of scenarios should generally be avoided, it is possible to handle them with a custom internal comparator that checks `meta` values.
```ts
import { createCustomEqual } from 'fast-equals';
interface Meta {
value: string;
}
const meta: Meta = { value: 'baz' };
const deepEqual = createCustomEqual<Meta>({
createInternalComparator:
(compare) => (a, b, _keyA, _keyB, _parentA, _parentB, state) =>
compare(a, b, state) || a === state.meta.value || b === state.meta.value,
createState: () => ({ meta }),
});
```