import { sprintf } from 'sprintf-js'; /** * @returns {String} the string with all zeroes contained in a <span> */ export function spanAllZeroes(s: string): string { return s.replace(/(0+)/g, '<span class="zero">$1</span>'); } /** * @returns {String} the string with each character contained in a <span> */ export function spanAll(s: string, offset: number = 0): string { const letters = s.split(''); return letters .map( (n, i) => sprintf( '<span class="digit value-%s position-%d">%s</span>', n, i + offset, spanAllZeroes(n) ) // XXX Use #base-2 .value-0 instead? ) .join(''); } function spanLeadingZeroesSimple(group: string): string { return group.replace(/^(0+)/, '<span class="zero">$1</span>'); } /** * @returns {String} the string with leading zeroes contained in a <span> */ export function spanLeadingZeroes(address: string): string { const groups = address.split(':'); return groups.map((g) => spanLeadingZeroesSimple(g)).join(':'); } /** * Groups an address * @returns {String} a grouped address */ export function simpleGroup(addressString: string, offset: number = 0): string[] { const groups = addressString.split(':'); return groups.map((g, i) => { if (/group-v4/.test(g)) { return g; } return sprintf( '<span class="hover-group group-%d">%s</span>', i + offset, spanLeadingZeroesSimple(g) ); }); }