56 lines
1.4 KiB
TypeScript
56 lines
1.4 KiB
TypeScript
export function leftPad(str: string | number, length: number, fill = '0') {
|
|
let current = String(str);
|
|
while (current.length < length) {
|
|
current = `${fill}${str}`;
|
|
}
|
|
return current;
|
|
}
|
|
|
|
export const tuple = <T extends string[]>(...args: T) => args;
|
|
|
|
export function toArray<T>(val: T | T[]): T[] {
|
|
if (val === null || val === undefined) {
|
|
return [];
|
|
}
|
|
|
|
return Array.isArray(val) ? val : [val];
|
|
}
|
|
|
|
export default function getDataOrAriaProps(props: any) {
|
|
const retProps: any = {};
|
|
|
|
Object.keys(props).forEach(key => {
|
|
if (
|
|
(key.startsWith('data-') || key.startsWith('aria-') || key === 'role' || key === 'name') &&
|
|
!key.startsWith('data-__')
|
|
) {
|
|
retProps[key] = props[key];
|
|
}
|
|
});
|
|
|
|
return retProps;
|
|
}
|
|
|
|
export function getValue<T>(values: null | undefined | (T | null)[], index: number): T | null {
|
|
return values ? values[index] : null;
|
|
}
|
|
|
|
type UpdateValue<T> = (prev: T) => T;
|
|
|
|
export function updateValues<T, R = [T | null, T | null] | null>(
|
|
values: [T | null, T | null] | null,
|
|
value: T | UpdateValue<T>,
|
|
index: number,
|
|
): R {
|
|
const newValues: [T | null, T | null] = [getValue(values, 0), getValue(values, 1)];
|
|
|
|
newValues[index] =
|
|
typeof value === 'function' ? (value as UpdateValue<T | null>)(newValues[index]) : value;
|
|
|
|
if (!newValues[0] && !newValues[1]) {
|
|
return null as unknown as R;
|
|
}
|
|
|
|
return newValues as unknown as R;
|
|
}
|