You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1 line
9.4 KiB

3 months ago
{"ast":null,"code":"import \"core-js/modules/es.array.push.js\";\nimport { defineComponent, h } from 'vue';\nimport '../../../../hooks/index.mjs';\nimport useStyle from './style-helper.mjs';\nimport { useNamespace } from '../../../../hooks/use-namespace/index.mjs';\nvar TableFooter = defineComponent({\n name: \"ElTableFooter\",\n props: {\n fixed: {\n type: String,\n default: \"\"\n },\n store: {\n required: true,\n type: Object\n },\n summaryMethod: Function,\n sumText: String,\n border: Boolean,\n defaultSort: {\n type: Object,\n default: () => {\n return {\n prop: \"\",\n order: \"\"\n };\n }\n }\n },\n setup(props) {\n const {\n getCellClasses,\n getCellStyles,\n columns\n } = useStyle(props);\n const ns = useNamespace(\"table\");\n return {\n ns,\n getCellClasses,\n getCellStyles,\n columns\n };\n },\n render() {\n const {\n columns,\n getCellStyles,\n getCellClasses,\n summaryMethod,\n sumText\n } = this;\n const data = this.store.states.data.value;\n let sums = [];\n if (summaryMethod) {\n sums = summaryMethod({\n columns,\n data\n });\n } else {\n columns.forEach((column, index) => {\n if (index === 0) {\n sums[index] = sumText;\n return;\n }\n const values = data.map(item => Number(item[column.property]));\n const precisions = [];\n let notNumber = true;\n values.forEach(value => {\n if (!Number.isNaN(+value)) {\n notNumber = false;\n const decimal = `${value}`.split(\".\")[1];\n precisions.push(decimal ? decimal.length : 0);\n }\n });\n const precision = Math.max.apply(null, precisions);\n if (!notNumber) {\n sums[index] = values.reduce((prev, curr) => {\n const value = Number(curr);\n if (!Number.isNaN(+value)) {\n return Number.parseFloat((prev + curr).toFixed(Math.min(precision, 20)));\n } else {\n return prev;\n }\n }, 0);\n } else {\n sums[index] = \"\";\n }\n });\n }\n return h(h(\"tfoot\", [h(\"tr\", {}, [...columns.map((column, cellIndex) => h(\"td\", {\n key: cellIndex,\n colspan: column.colSpan,\n rowspan: column.rowSpan,\n class: getCellClasses(columns, cellIndex),\n style: getCellStyles(column, cellIndex)\n }, [h(\"div\", {\n class: [\"cell\", column.labelClassName]\n }, [sums[cellIndex]])]))])]));\n }\n});\nexport { TableFooter as default };","map":{"version":3,"names":["TableFooter","defineComponent","name","props","fixed","type","String","default","store","required","Object","summaryMethod","Function","sumText","border","Boolean","defaultSort","prop","order","setup","getCellClasses","getCellStyles","columns","useStyle","ns","useNamespace","render","data","states","value","sums","forEach","column","index","values","map","item","Number","property","precisions","notNumber","isNaN","decimal","split","push","length","precision","Math","max","apply","reduce","prev","curr","parseFloat","toFixed","min","h","cellIndex","key","colspan","colSpan","rowspan","rowSpan","class","style","labelClassName"],"sources":["../../../../../../../packages/components/table/src/table-footer/index.ts"],"sourcesContent":["// @ts-nocheck\nimport { defineComponent, h } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport useStyle from './style-helper'\nimport type { Store } from '../store'\n\nimport type { PropType } from 'vue'\nimport type { DefaultRow, Sort, SummaryMethod } from '../table/defaults'\nexport interface TableFooter<T> {\n fixed: string\n store: Store<T>\n summaryMethod: SummaryMethod<T>\n sumText: string\n border: boolean\n defaultSort: Sort\n}\n\nexport default defineComponent({\n name: 'ElTableFooter',\n\n props: {\n fixed: {\n type: String,\n default: '',\n },\n