antd-mobile
Version:
<img src="https://gw.alipayobjects.com/mdn/rms_ee68a8/afts/img/A*hjjDS5Yy-ooAAAAAAAAAAAAAARQnAQ" alt="logo" width="100%" />
35 lines (28 loc) • 747 B
JavaScript
import { useMemo } from 'react';
import memoize from 'lodash/memoize';
export function useCascaderValueExtend(options) {
const generateItems = useMemo(() => {
return memoize(val => {
const ret = [];
let currentOptions = options;
for (const v of val) {
const target = currentOptions.find(option => option.value === v);
if (!target) {
break;
}
ret.push(target);
if (!target.children) break;
currentOptions = target.children;
}
return ret;
}, val => JSON.stringify(val));
}, [options]);
function generateValueExtend(val) {
return {
get items() {
return generateItems(val);
}
};
}
return generateValueExtend;
}