cl
2026-04-21 228b881e5a893ec010a194ac42011a4169d0c590
rsf-admin/src/utils/common.js
@@ -1,4 +1,39 @@
/** 前端数量显示:统一保留2位小数(仅展示,后端不变) */
export const formatQuantity = (value) => {
    if (value == null || value === '') return '0.00';
    const n = Number(value);
    if (Number.isNaN(n)) return '0.00';
    if (n < 0) return '0.00';
    return n.toFixed(2);
};
/** 用于 react-admin NumberField 的数量展示 options(2位小数) */
export const QTY_NUMBER_OPTIONS = { minimumFractionDigits: 2, maximumFractionDigits: 2 };
/** 校验最多 N 位小数,用于数量类字段;超过时返回错误信息并阻止提交 */
export const maxDecimalPlaces = (maxDecimals, message) => {
    const factor = Math.pow(10, maxDecimals);
    const msg = message || `最多${maxDecimals}位小数`;
    return (value) => {
        if (value == null || value === '') return undefined;
        const n = Number(value);
        if (Number.isNaN(n)) return undefined;
        const rounded = Math.round(n * factor) / factor;
        if (Math.abs(n - rounded) > 1e-10) return msg;
        return undefined;
    };
};
/** 判断数值是否超过 6 位小数(用于提交前校验) */
export const hasMoreThan6Decimals = (value) => {
    if (value == null || value === '') return false;
    const n = Number(value);
    if (Number.isNaN(n)) return false;
    const rounded = Math.round(n * 1e6) / 1e6;
    return Math.abs(n - rounded) > 1e-10;
};
export const extractNavMenus = (data) => {
    if (!data) {
        return;
@@ -6,10 +41,15 @@
    const navMenus = [];
    const traverse = (nodes) => {
        nodes.forEach((node) => {
            if (!node.children) {
                navMenus.push(node);
            // 叶子:无子或 children 为空数组;仅收集有 component 的节点(页面资源)
            const children = node.children;
            const hasChildren = Array.isArray(children) && children.length > 0;
            if (!hasChildren) {
                if (node.component) {
                    navMenus.push(node);
                }
            } else {
                traverse(node.children);
                traverse(children);
            }
        });
    };
@@ -50,3 +90,21 @@
    });
    return result;
};
export const haveChildren = (item) => {
    if (Array.isArray(item)) {
        return item.map((k) => haveChildren(k));
    }
    if (item && typeof item === 'object') {
        if (item.id !== undefined) {
            item.id = item.id.toString();
        }
        if (item.children && Array.isArray(item.children)) {
            item.children = haveChildren(item.children);
        }
    }
    return item;
};