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

693 B

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.

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 }),
});