style-dictionary
Version:
Style once, use everywhere. A build system for creating cross-platform styles.
33 lines (29 loc) • 1.32 kB
JavaScript
import GroupMessages from '../groupMessages.js';
import { getReferences } from './getReferences.js';
const FILTER_WARNINGS = GroupMessages.GROUP.FilteredOutputReferences;
/**
* @typedef {import('../../../types/DesignToken.d.ts').TransformedToken} TransformedToken
* @typedef {import('../../../types/DesignToken.d.ts').Dictionary} Dictionary
*
* @param {TransformedToken} token
* @param {{ dictionary: Dictionary, usesDtcg?: boolean }} dictionary
* @returns
*/
export function outputReferencesFilter(token, { dictionary, usesDtcg }) {
const originalValue = usesDtcg ? token.original.$value : token.original.value;
// get refs, pass unfilteredTokens to ensure we find the refs even if they are filtered out
const refs = getReferences(originalValue, dictionary.tokens, {
unfilteredTokens: dictionary.unfilteredTokens,
usesDtcg,
warnImmediately: false,
});
return refs.every((ref) => {
// check whether every ref can be found in the filtered set of tokens
const foundToken = dictionary.allTokens.find((token) => token.name === ref.name);
if (!foundToken) {
// remove the warning about this ref being filtered out, since we now prevent it from outputting it as a ref
GroupMessages.remove(FILTER_WARNINGS, ref.path.join('.'));
}
return !!foundToken;
});
}