@ai-table/grid 0.0.41 → 0.0.43
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/components/cell-editors/link/link-editor.component.mjs +2 -2
- package/esm2022/components/drag/drag.component.mjs +2 -2
- package/esm2022/grid.component.mjs +4 -3
- package/esm2022/utils/clipboard/clipboard.mjs +19 -8
- package/esm2022/utils/clipboard/paste.mjs +43 -27
- package/esm2022/utils/field/model/date.mjs +36 -7
- package/esm2022/utils/field/model/select.mjs +2 -2
- package/fesm2022/ai-table-grid.mjs +100 -44
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/utils/clipboard/clipboard.d.ts.map +1 -1
- package/utils/clipboard/paste.d.ts.map +1 -1
@@ -14,27 +14,39 @@ function extractContentFromClipboardText(clipboardText) {
|
|
14
14
|
.filter((row) => row.length > 0 && row.some((cell) => cell.trim().length > 0));
|
15
15
|
return contents;
|
16
16
|
}
|
17
|
+
function processTableCell(cellHtml) {
|
18
|
+
const linkPattern = /<a[^>]*?href=["']([^"']+)["'][^>]*?>([^<]*?)<\/a>/i;
|
19
|
+
const match = cellHtml.match(linkPattern);
|
20
|
+
const link = match ? { href: match[1], text: match[2] } : null;
|
21
|
+
const content = link ? cellHtml.replace(linkPattern, `[LINK:${link.text}](${link.href})`) : cellHtml;
|
22
|
+
const cleanContent = content
|
23
|
+
.replace(/<[^>]+>/g, '')
|
24
|
+
.replace(/ /g, ' ')
|
25
|
+
.replace(/\s+/g, ' ')
|
26
|
+
.trim();
|
27
|
+
return link ? cleanContent.replace(`[LINK:${link.text}](${link.href})`, `<a href="${link.href}">${link.text}</a>`) : cleanContent;
|
28
|
+
}
|
17
29
|
function extractContentFromClipboardHtml(clipboardHtml) {
|
18
30
|
const tablePattern = /<table[^>]*>([\s\S]*?)<\/table>/i;
|
19
31
|
const trPattern = /<tr[^>]*>([\s\S]*?)<\/tr>/gi;
|
20
|
-
const
|
21
|
-
const contents = [];
|
32
|
+
const tdPattern = /<td[^>]*?>([\s\S]*?)<\/td>/gi;
|
22
33
|
try {
|
23
34
|
const tableMatch = clipboardHtml.match(tablePattern);
|
24
35
|
const tableContent = tableMatch ? tableMatch[1] : clipboardHtml;
|
25
36
|
const rows = tableContent.match(trPattern) || [];
|
26
|
-
rows
|
27
|
-
|
28
|
-
const
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
}
|
33
|
-
contents
|
34
|
-
})
|
35
|
-
|
37
|
+
return rows
|
38
|
+
.map((row) => {
|
39
|
+
const contents = [];
|
40
|
+
let tdMatch;
|
41
|
+
while ((tdMatch = tdPattern.exec(row)) !== null) {
|
42
|
+
contents.push(processTableCell(tdMatch[1]));
|
43
|
+
}
|
44
|
+
return contents;
|
45
|
+
})
|
46
|
+
.filter((row) => row.length > 0);
|
36
47
|
}
|
37
48
|
catch (error) {
|
49
|
+
console.warn('Failed to extract content from HTML:', error);
|
38
50
|
return [];
|
39
51
|
}
|
40
52
|
}
|
@@ -82,21 +94,25 @@ function getPasteValue(plainText, aiTableContent, recordIndex, fieldIndex, targe
|
|
82
94
|
let originData = field && record ? { field, cellValue: getFieldValue(record, field) } : null;
|
83
95
|
if (targetField.type === AITableFieldType.select) {
|
84
96
|
let { existOptionIds, newOptions } = processPastedValueForSelect(plainText, targetField, originData);
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
97
|
+
let newField = null;
|
98
|
+
let newOptionIds = [];
|
99
|
+
if (newOptions.length) {
|
100
|
+
newOptions = newOptions.map((option) => {
|
101
|
+
return {
|
102
|
+
...option,
|
103
|
+
_id: idCreator()
|
104
|
+
};
|
105
|
+
});
|
106
|
+
newField = {
|
107
|
+
...targetField,
|
108
|
+
settings: {
|
109
|
+
...targetField.settings,
|
110
|
+
options: [...(targetField.settings?.options || []), ...newOptions]
|
111
|
+
}
|
89
112
|
};
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
settings: {
|
94
|
-
...targetField.settings,
|
95
|
-
options: [...(targetField.settings?.options || []), ...newOptions]
|
96
|
-
}
|
97
|
-
};
|
98
|
-
const newOptionIds = newOptions.map((option) => option._id).filter((id) => !!id);
|
99
|
-
const selectFieldValue = [...existOptionIds, ...newOptionIds];
|
113
|
+
newOptionIds = newOptions.map((option) => option._id).filter((id) => !!id);
|
114
|
+
}
|
115
|
+
const selectFieldValue = newOptionIds?.length ? [...existOptionIds, ...newOptionIds] : existOptionIds;
|
100
116
|
return {
|
101
117
|
value: selectFieldValue,
|
102
118
|
newField
|
@@ -177,4 +193,4 @@ export const writeToAITable = async (aiTable, actions) => {
|
|
177
193
|
});
|
178
194
|
return isPasteSuccess;
|
179
195
|
};
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paste.js","sourceRoot":"","sources":["../../../../../packages/grid/src/utils/clipboard/paste.ts"],"names":[],"mappings":"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","sourcesContent":["import { AITableContent, AITableReferences } from '../../types';\nimport {\n    AITable,\n    AITableField,\n    AITableFieldType,\n    AITableRecord,\n    createDefaultField,\n    createDefaultFieldName,\n    FieldOptions,\n    FieldValue,\n    getFieldValue,\n    idCreator,\n    SelectSettings,\n    UpdateFieldValueOptions\n} from '../../core';\nimport { readFromClipboard, aiTableFragmentAttribute, extractText } from '../clipboard';\nimport { FieldModelMap } from '../field/model';\nimport { processPastedValueForSelect } from '../field/model/select';\nimport { AddRecordOptions, AddFieldOptions } from '../../core';\n\nconst aiTableAttributePattern = new RegExp(`${aiTableFragmentAttribute}=\"(.+?)\"`, 'm');\n\nconst decodeClipboardJsonData = (encoded: string) => {\n    const decoded = decodeURIComponent(window.atob(encoded));\n    return JSON.parse(decoded);\n};\n\nfunction extractContentFromClipboardText(clipboardText: string): string[][] {\n    const contents = clipboardText\n        .split('\\n')\n        .map((row) => row.split('\\t'))\n        .filter((row) => row.length > 0 && row.some((cell) => cell.trim().length > 0));\n\n    return contents;\n}\n\nfunction extractContentFromClipboardHtml(clipboardHtml: string): string[][] {\n    const tablePattern = /<table[^>]*>([\\s\\S]*?)<\\/table>/i;\n    const trPattern = /<tr[^>]*>([\\s\\S]*?)<\\/tr>/gi;\n    const cellPattern = /<td[^>]*>([\\s\\S]*?)<\\/td>/gi;\n    const contents: string[][] = [];\n\n    try {\n        const tableMatch = clipboardHtml.match(tablePattern);\n        const tableContent = tableMatch ? tableMatch[1] : clipboardHtml;\n        const rows = tableContent.match(trPattern) || [];\n\n        rows.forEach((row) => {\n            const rowContent: string[] = [];\n            const cells = row.match(cellPattern) || [];\n\n            cells.forEach((cell) => {\n                const content = cell.replace(/<td>|<\\/td>/g, '').trim();\n                rowContent.push(content);\n            });\n\n            contents.push(rowContent);\n        });\n\n        return contents;\n    } catch (error) {\n        return [];\n    }\n}\n\nfunction extractAITableContentFromClipboardHtml(clipboardHtml: string): AITableContent | null {\n    const aiTableFragment = clipboardHtml.match(aiTableAttributePattern);\n    if (aiTableFragment && !!aiTableFragment.length) {\n        return decodeClipboardJsonData(aiTableFragment[1]);\n    }\n    return null;\n}\n\nconst readClipboardData = async (): Promise<{ clipboardContent: string[][]; aiTableContent: AITableContent | null }> => {\n    const clipboardData = await readFromClipboard();\n    let clipboardContent: string[][] = [];\n    let aiTableContent: AITableContent | null = null;\n\n    if (clipboardData) {\n        const clipboardHtml = clipboardData.html;\n        const clipboardText = clipboardData.text;\n\n        if (clipboardHtml) {\n            aiTableContent = extractAITableContentFromClipboardHtml(clipboardHtml);\n            clipboardContent = extractContentFromClipboardHtml(clipboardHtml);\n        }\n\n        if (!clipboardContent.length && clipboardText) {\n            clipboardContent = extractContentFromClipboardText(clipboardText);\n        }\n    }\n\n    return {\n        clipboardContent,\n        aiTableContent\n    };\n};\n\nfunction getPasteValue(\n    plainText: string,\n    aiTableContent: AITableContent | null,\n    recordIndex: number,\n    fieldIndex: number,\n    targetField: AITableField,\n    references: AITableReferences\n): {\n    value: FieldValue | null;\n    newField: AITableField | null;\n} {\n    let field: AITableField | null = null;\n    let record: Partial<AITableRecord> | null = null;\n\n    if (aiTableContent) {\n        const { fields, records } = aiTableContent;\n        field = fields[fieldIndex];\n        record = records[recordIndex];\n    }\n\n    if (targetField.type === AITableFieldType.attachment || (field && field.type === AITableFieldType.attachment)) {\n        return { value: null, newField: null };\n    }\n    if (targetField.type !== AITableFieldType.link) {\n        plainText = extractText(plainText);\n    }\n\n    let originData = field && record ? { field, cellValue: getFieldValue(record, field) } : null;\n    if (targetField.type === AITableFieldType.select) {\n        let { existOptionIds, newOptions } = processPastedValueForSelect(plainText, targetField, originData);\n\n        newOptions = newOptions.map((option) => {\n            return {\n                ...option,\n                _id: idCreator()\n            };\n        });\n        const newField = {\n            ...targetField,\n            settings: {\n                ...targetField.settings,\n                options: [...((targetField.settings as SelectSettings)?.options || []), ...newOptions]\n            }\n        };\n        const newOptionIds = newOptions.map((option) => option._id).filter((id) => !!id) as string[];\n        const selectFieldValue = [...existOptionIds, ...newOptionIds];\n        return {\n            value: selectFieldValue,\n            newField\n        };\n    }\n\n    return { value: FieldModelMap[targetField.type].toFieldValue(plainText, targetField, originData, references), newField: null };\n}\n\nexport interface AITablePasteActions {\n    updateFieldValue: (data: UpdateFieldValueOptions) => void;\n    setField: (field: AITableField) => void;\n    addRecord: (data: AddRecordOptions) => void;\n    addField: (data: AddFieldOptions) => void;\n}\n\nfunction appendRecord(aiTable: AITable, actions: AITablePasteActions) {\n    const allRecords = aiTable.records();\n    const lastRecordId = allRecords.length > 0 ? allRecords[allRecords.length - 1]._id : '';\n    actions.addRecord({\n        originId: lastRecordId\n    });\n}\n\nfunction appendField(aiTable: AITable, originField: AITableField | null, actions: AITablePasteActions) {\n    const lastFieldId = aiTable.fields().length > 0 ? aiTable.fields()[aiTable.fields().length - 1]._id : '';\n    let defaultFieldValue: Partial<AITableField>;\n    if (originField) {\n        defaultFieldValue = {\n            ...originField,\n            name: createDefaultFieldName(aiTable, FieldOptions.find((item) => item.type === originField.type)!),\n            _id: idCreator()\n        };\n    } else {\n        defaultFieldValue = createDefaultField(aiTable, AITableFieldType.text);\n    }\n\n    actions.addField({\n        originId: lastFieldId,\n        defaultValue: defaultFieldValue\n    });\n}\n\nexport const writeToAITable = async (aiTable: AITable, actions: AITablePasteActions) => {\n    const selectedCells = Array.from(aiTable.selection().selectedCells);\n    if (!selectedCells.length) {\n        return;\n    }\n    const { clipboardContent, aiTableContent } = await readClipboardData();\n    if (!clipboardContent.length) {\n        return;\n    }\n\n    const [firstCell] = selectedCells;\n    const [startRecordId, startFieldId] = firstCell.split(':');\n    const startRowIndex = aiTable.context!.visibleRowsIndexMap().get(startRecordId) ?? 0;\n    const startColIndex = aiTable.context!.visibleColumnsIndexMap().get(startFieldId) ?? 0;\n    const references = aiTable.context!.references();\n    let isPasteSuccess = false;\n\n    clipboardContent.forEach((row, i) => {\n        const targetRowIndex = startRowIndex + i;\n        if (targetRowIndex >= aiTable.context!.linearRows().length - 1) {\n            appendRecord(aiTable, actions);\n        }\n\n        row.forEach((plainText, j) => {\n            const targetColIndex = startColIndex + j;\n            if (targetColIndex >= AITable.getVisibleFields(aiTable).length) {\n                const originField = aiTableContent?.fields[j] || null;\n                appendField(aiTable, originField, actions);\n            }\n\n            const targetRecord = aiTable.context!.linearRows()[targetRowIndex];\n            const targetField = AITable.getVisibleFields(aiTable)[targetColIndex];\n            const recordIndex = i;\n            const fieldIndex = j;\n            const { value, newField } = getPasteValue(plainText, aiTableContent, recordIndex, fieldIndex, targetField, references);\n\n            if (newField) {\n                actions.setField(newField);\n            }\n\n            if (value !== null) {\n                try {\n                    actions.updateFieldValue({\n                        value,\n                        path: [targetRecord._id, targetField._id]\n                    });\n                    isPasteSuccess = true;\n                } catch (error) {}\n            }\n        });\n    });\n\n    return isPasteSuccess;\n};\n"]}
|
196
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paste.js","sourceRoot":"","sources":["../../../../../packages/grid/src/utils/clipboard/paste.ts"],"names":[],"mappings":"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","sourcesContent":["import { AITableContent, AITableReferences } from '../../types';\nimport {\n    AITable,\n    AITableField,\n    AITableFieldType,\n    AITableRecord,\n    createDefaultField,\n    createDefaultFieldName,\n    FieldOptions,\n    FieldValue,\n    getFieldValue,\n    idCreator,\n    SelectSettings,\n    UpdateFieldValueOptions\n} from '../../core';\nimport { readFromClipboard, aiTableFragmentAttribute, extractText } from '../clipboard';\nimport { FieldModelMap } from '../field/model';\nimport { processPastedValueForSelect } from '../field/model/select';\nimport { AddRecordOptions, AddFieldOptions } from '../../core';\n\nconst aiTableAttributePattern = new RegExp(`${aiTableFragmentAttribute}=\"(.+?)\"`, 'm');\n\nconst decodeClipboardJsonData = (encoded: string) => {\n    const decoded = decodeURIComponent(window.atob(encoded));\n    return JSON.parse(decoded);\n};\n\nfunction extractContentFromClipboardText(clipboardText: string): string[][] {\n    const contents = clipboardText\n        .split('\\n')\n        .map((row) => row.split('\\t'))\n        .filter((row) => row.length > 0 && row.some((cell) => cell.trim().length > 0));\n\n    return contents;\n}\n\nfunction processTableCell(cellHtml: string): string {\n    const linkPattern = /<a[^>]*?href=[\"']([^\"']+)[\"'][^>]*?>([^<]*?)<\\/a>/i;\n    const match = cellHtml.match(linkPattern);\n    const link = match ? { href: match[1], text: match[2] } : null;\n    const content = link ? cellHtml.replace(linkPattern, `[LINK:${link.text}](${link.href})`) : cellHtml;\n\n    const cleanContent = content\n        .replace(/<[^>]+>/g, '')\n        .replace(/&nbsp;/g, ' ')\n        .replace(/\\s+/g, ' ')\n        .trim();\n\n    return link ? cleanContent.replace(`[LINK:${link.text}](${link.href})`, `<a href=\"${link.href}\">${link.text}</a>`) : cleanContent;\n}\n\nfunction extractContentFromClipboardHtml(clipboardHtml: string): string[][] {\n    const tablePattern = /<table[^>]*>([\\s\\S]*?)<\\/table>/i;\n    const trPattern = /<tr[^>]*>([\\s\\S]*?)<\\/tr>/gi;\n    const tdPattern = /<td[^>]*?>([\\s\\S]*?)<\\/td>/gi;\n\n    try {\n        const tableMatch = clipboardHtml.match(tablePattern);\n        const tableContent = tableMatch ? tableMatch[1] : clipboardHtml;\n        const rows = tableContent.match(trPattern) || [];\n\n        return rows\n            .map((row) => {\n                const contents: string[] = [];\n                let tdMatch;\n\n                while ((tdMatch = tdPattern.exec(row)) !== null) {\n                    contents.push(processTableCell(tdMatch[1]));\n                }\n\n                return contents;\n            })\n            .filter((row) => row.length > 0);\n    } catch (error) {\n        console.warn('Failed to extract content from HTML:', error);\n        return [];\n    }\n}\n\nfunction extractAITableContentFromClipboardHtml(clipboardHtml: string): AITableContent | null {\n    const aiTableFragment = clipboardHtml.match(aiTableAttributePattern);\n    if (aiTableFragment && !!aiTableFragment.length) {\n        return decodeClipboardJsonData(aiTableFragment[1]);\n    }\n    return null;\n}\n\nconst readClipboardData = async (): Promise<{ clipboardContent: string[][]; aiTableContent: AITableContent | null }> => {\n    const clipboardData = await readFromClipboard();\n    let clipboardContent: string[][] = [];\n    let aiTableContent: AITableContent | null = null;\n\n    if (clipboardData) {\n        const clipboardHtml = clipboardData.html;\n        const clipboardText = clipboardData.text;\n\n        if (clipboardHtml) {\n            aiTableContent = extractAITableContentFromClipboardHtml(clipboardHtml);\n            clipboardContent = extractContentFromClipboardHtml(clipboardHtml);\n        }\n\n        if (!clipboardContent.length && clipboardText) {\n            clipboardContent = extractContentFromClipboardText(clipboardText);\n        }\n    }\n\n    return {\n        clipboardContent,\n        aiTableContent\n    };\n};\n\nfunction getPasteValue(\n    plainText: string,\n    aiTableContent: AITableContent | null,\n    recordIndex: number,\n    fieldIndex: number,\n    targetField: AITableField,\n    references: AITableReferences\n): {\n    value: FieldValue | null;\n    newField: AITableField | null;\n} {\n    let field: AITableField | null = null;\n    let record: Partial<AITableRecord> | null = null;\n\n    if (aiTableContent) {\n        const { fields, records } = aiTableContent;\n        field = fields[fieldIndex];\n        record = records[recordIndex];\n    }\n\n    if (targetField.type === AITableFieldType.attachment || (field && field.type === AITableFieldType.attachment)) {\n        return { value: null, newField: null };\n    }\n    if (targetField.type !== AITableFieldType.link) {\n        plainText = extractText(plainText);\n    }\n\n    let originData = field && record ? { field, cellValue: getFieldValue(record, field) } : null;\n    if (targetField.type === AITableFieldType.select) {\n        let { existOptionIds, newOptions } = processPastedValueForSelect(plainText, targetField, originData);\n        let newField: AITableField | null = null;\n        let newOptionIds: string[] = [];\n\n        if (newOptions.length) {\n            newOptions = newOptions.map((option) => {\n                return {\n                    ...option,\n                    _id: idCreator()\n                };\n            });\n            newField = {\n                ...targetField,\n                settings: {\n                    ...targetField.settings,\n                    options: [...((targetField.settings as SelectSettings)?.options || []), ...newOptions]\n                }\n            };\n            newOptionIds = newOptions.map((option) => option._id).filter((id) => !!id) as string[];\n        }\n\n        const selectFieldValue = newOptionIds?.length ? [...existOptionIds, ...newOptionIds] : existOptionIds;\n        return {\n            value: selectFieldValue,\n            newField\n        };\n    }\n\n    return { value: FieldModelMap[targetField.type].toFieldValue(plainText, targetField, originData, references), newField: null };\n}\n\nexport interface AITablePasteActions {\n    updateFieldValue: (data: UpdateFieldValueOptions) => void;\n    setField: (field: AITableField) => void;\n    addRecord: (data: AddRecordOptions) => void;\n    addField: (data: AddFieldOptions) => void;\n}\n\nfunction appendRecord(aiTable: AITable, actions: AITablePasteActions) {\n    const allRecords = aiTable.records();\n    const lastRecordId = allRecords.length > 0 ? allRecords[allRecords.length - 1]._id : '';\n    actions.addRecord({\n        originId: lastRecordId\n    });\n}\n\nfunction appendField(aiTable: AITable, originField: AITableField | null, actions: AITablePasteActions) {\n    const lastFieldId = aiTable.fields().length > 0 ? aiTable.fields()[aiTable.fields().length - 1]._id : '';\n    let defaultFieldValue: Partial<AITableField>;\n    if (originField) {\n        defaultFieldValue = {\n            ...originField,\n            name: createDefaultFieldName(aiTable, FieldOptions.find((item) => item.type === originField.type)!),\n            _id: idCreator()\n        };\n    } else {\n        defaultFieldValue = createDefaultField(aiTable, AITableFieldType.text);\n    }\n\n    actions.addField({\n        originId: lastFieldId,\n        defaultValue: defaultFieldValue\n    });\n}\n\nexport const writeToAITable = async (aiTable: AITable, actions: AITablePasteActions) => {\n    const selectedCells = Array.from(aiTable.selection().selectedCells);\n    if (!selectedCells.length) {\n        return;\n    }\n    const { clipboardContent, aiTableContent } = await readClipboardData();\n    if (!clipboardContent.length) {\n        return;\n    }\n\n    const [firstCell] = selectedCells;\n    const [startRecordId, startFieldId] = firstCell.split(':');\n    const startRowIndex = aiTable.context!.visibleRowsIndexMap().get(startRecordId) ?? 0;\n    const startColIndex = aiTable.context!.visibleColumnsIndexMap().get(startFieldId) ?? 0;\n    const references = aiTable.context!.references();\n    let isPasteSuccess = false;\n\n    clipboardContent.forEach((row, i) => {\n        const targetRowIndex = startRowIndex + i;\n        if (targetRowIndex >= aiTable.context!.linearRows().length - 1) {\n            appendRecord(aiTable, actions);\n        }\n\n        row.forEach((plainText, j) => {\n            const targetColIndex = startColIndex + j;\n            if (targetColIndex >= AITable.getVisibleFields(aiTable).length) {\n                const originField = aiTableContent?.fields[j] || null;\n                appendField(aiTable, originField, actions);\n            }\n\n            const targetRecord = aiTable.context!.linearRows()[targetRowIndex];\n            const targetField = AITable.getVisibleFields(aiTable)[targetColIndex];\n            const recordIndex = i;\n            const fieldIndex = j;\n            const { value, newField } = getPasteValue(plainText, aiTableContent, recordIndex, fieldIndex, targetField, references);\n\n            if (newField) {\n                actions.setField(newField);\n            }\n\n            if (value !== null) {\n                try {\n                    actions.updateFieldValue({\n                        value,\n                        path: [targetRecord._id, targetField._id]\n                    });\n                    isPasteSuccess = true;\n                } catch (error) {}\n            }\n        });\n    });\n\n    return isPasteSuccess;\n};\n"]}
|
@@ -95,13 +95,42 @@ function cellValueToSortValue(cellValue) {
|
|
95
95
|
}
|
96
96
|
function transformDateValue(text) {
|
97
97
|
const value = text.trim();
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
98
|
+
if (!value || isEmpty(value))
|
99
|
+
return null;
|
100
|
+
// 基础日期格式:支持识别 - / . 年月日 作为分隔符
|
101
|
+
const datePattern = String.raw `(?:(\d{2}|\d{4})[-/.年](\d{1,2})[-/.月](\d{1,2})日?)`;
|
102
|
+
const timePattern = String.raw `(?:\s+(\d{1,2}):(\d{1,2})(?::(\d{1,2}))?)?`;
|
103
|
+
const pattern = new RegExp(`^${datePattern}${timePattern}$`);
|
104
|
+
const match = value.match(pattern);
|
105
|
+
if (!match)
|
106
|
+
return null;
|
107
|
+
try {
|
108
|
+
let [_, year, month, day] = match;
|
109
|
+
if (year.length === 2) {
|
110
|
+
const currentYear = new Date().getFullYear();
|
111
|
+
const century = Math.floor(currentYear / 100) * 100;
|
112
|
+
const twoDigitYear = parseInt(year);
|
113
|
+
year = String(twoDigitYear > currentYear % 100 ? century - 100 + twoDigitYear : century + twoDigitYear);
|
114
|
+
}
|
115
|
+
const monthNum = parseInt(month);
|
116
|
+
const dayNum = parseInt(day);
|
117
|
+
if (monthNum < 1 || monthNum > 12) {
|
118
|
+
console.warn('Invalid month:', monthNum);
|
119
|
+
return null;
|
120
|
+
}
|
121
|
+
const maxDays = new Date(parseInt(year), monthNum, 0).getDate();
|
122
|
+
if (dayNum < 1 || dayNum > maxDays) {
|
123
|
+
console.warn('Invalid day:', dayNum);
|
124
|
+
return null;
|
125
|
+
}
|
126
|
+
const standardDate = `${year}-${String(monthNum).padStart(2, '0')}-${String(dayNum).padStart(2, '0')}`;
|
127
|
+
return {
|
128
|
+
timestamp: new TinyDate(standardDate).getUnixTime()
|
102
129
|
};
|
103
|
-
return dateValue;
|
104
130
|
}
|
105
|
-
|
131
|
+
catch (error) {
|
132
|
+
console.warn('Invalid date:', value);
|
133
|
+
return null;
|
134
|
+
}
|
106
135
|
}
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/utils/field/model/date.ts"],"names":[],"mappings":"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","sourcesContent":["import { fromUnixTime, subDays } from 'date-fns';\nimport { isArray, TinyDate } from 'ngx-tethys/util';\nimport { Field } from './field';\nimport { AITableFilterCondition, AITableFilterOperation } from '../../../types';\nimport { AITableField, AITableFieldType, DateFieldValue, FieldValue } from '../../../core';\nimport { compareNumber } from '../operate';\nimport { isEmpty } from '../../common';\n\nexport class DateField extends Field {\n    override isMeetFilter(condition: AITableFilterCondition<string>, cellValue: DateFieldValue) {\n        const [left, right] = this.getTimeRange(condition.value);\n        switch (condition.operation) {\n            case AITableFilterOperation.empty:\n                return isEmpty(cellValue.timestamp) || cellValue.timestamp === 0;\n            case AITableFilterOperation.exists:\n                return !isEmpty(cellValue.timestamp) && cellValue.timestamp !== 0;\n            case AITableFilterOperation.eq:\n                return left <= cellValue.timestamp && cellValue.timestamp < right;\n            case AITableFilterOperation.gt:\n                return cellValue.timestamp > right;\n            case AITableFilterOperation.lt:\n                return cellValue.timestamp < left;\n            case AITableFilterOperation.between:\n                return left <= cellValue.timestamp && cellValue.timestamp < right;\n            default:\n                return super.isMeetFilter(condition, cellValue);\n        }\n    }\n\n    override compare(cellValue1: DateFieldValue, cellValue2: DateFieldValue): number {\n        const value1 = cellValueToSortValue(cellValue1);\n        const value2 = cellValueToSortValue(cellValue2);\n        return compareNumber(value1, value2);\n    }\n\n    override toFieldValue(\n        plainText: string,\n        targetField: AITableField,\n        originData?: { field: AITableField; cellValue: FieldValue }\n    ): FieldValue | null {\n        return toDateFieldValue(plainText, targetField, originData);\n    }\n\n    getTimeRange(value: string | number | number[]) {\n        switch (value) {\n            case 'today':\n                return [new TinyDate(new Date()).startOfDay().getUnixTime(), new TinyDate(new Date()).endOfDay().getUnixTime()];\n            case 'current_week':\n                return [\n                    new TinyDate().startOfWeek({ weekStartsOn: 1 }).getUnixTime(),\n                    new TinyDate().endOfWeek({ weekStartsOn: 1 }).getUnixTime()\n                ];\n            case 'yesterday':\n                return [\n                    new TinyDate(subDays(new Date(), 1)).startOfDay().getUnixTime(),\n                    new TinyDate(subDays(new Date(), 1)).endOfDay().getUnixTime()\n                ];\n            case 'current_month':\n                return [new TinyDate().startOfMonth().getUnixTime(), new TinyDate().endOfMonth().getUnixTime()];\n            default:\n                if (isArray(value)) {\n                    return [\n                        new TinyDate(fromUnixTime(value[0] as number)).startOfDay().getUnixTime(),\n                        new TinyDate(fromUnixTime(value[1] as number)).endOfDay().getUnixTime()\n                    ];\n                }\n                return [\n                    new TinyDate(fromUnixTime(value as number)).startOfDay().getUnixTime(),\n                    new TinyDate(fromUnixTime(value as number)).endOfDay().getUnixTime()\n                ];\n        }\n    }\n}\n\nexport function toDateFieldValue(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue }\n): FieldValue | null {\n    if (targetField.type === AITableFieldType.createdAt || targetField.type === AITableFieldType.updatedAt) {\n        return null;\n    }\n\n    if (originData) {\n        const { field, cellValue } = originData;\n        switch (field.type) {\n            case AITableFieldType.date:\n                return cellValue;\n            case AITableFieldType.text:\n                const dateValue = transformDateValue(cellValue);\n                if (dateValue) {\n                    return dateValue;\n                }\n                break;\n            default:\n                break;\n        }\n    } else {\n        const dateValue = transformDateValue(plainText);\n        if (dateValue) {\n            return dateValue;\n        }\n    }\n\n    return null;\n}\n\nfunction cellValueToSortValue(cellValue: DateFieldValue): number {\n    return cellValue?.timestamp;\n}\n\nfunction transformDateValue(text: string): FieldValue | null {\n    const value = text.trim();\n    const pattern = /^\\d{4}-\\d{1,2}-\\d{1,2}$/;\n\n    if (value && !isEmpty(value) && pattern.test(value)) {\n        const dateValue = {\n            timestamp: new TinyDate(value).getUnixTime()\n        };\n        return dateValue;\n    }\n    return null;\n}\n"]}
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/utils/field/model/date.ts"],"names":[],"mappings":"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","sourcesContent":["import { fromUnixTime, subDays } from 'date-fns';\nimport { isArray, TinyDate } from 'ngx-tethys/util';\nimport { Field } from './field';\nimport { AITableFilterCondition, AITableFilterOperation } from '../../../types';\nimport { AITableField, AITableFieldType, DateFieldValue, FieldValue } from '../../../core';\nimport { compareNumber } from '../operate';\nimport { isEmpty } from '../../common';\n\nexport class DateField extends Field {\n    override isMeetFilter(condition: AITableFilterCondition<string>, cellValue: DateFieldValue) {\n        const [left, right] = this.getTimeRange(condition.value);\n        switch (condition.operation) {\n            case AITableFilterOperation.empty:\n                return isEmpty(cellValue.timestamp) || cellValue.timestamp === 0;\n            case AITableFilterOperation.exists:\n                return !isEmpty(cellValue.timestamp) && cellValue.timestamp !== 0;\n            case AITableFilterOperation.eq:\n                return left <= cellValue.timestamp && cellValue.timestamp < right;\n            case AITableFilterOperation.gt:\n                return cellValue.timestamp > right;\n            case AITableFilterOperation.lt:\n                return cellValue.timestamp < left;\n            case AITableFilterOperation.between:\n                return left <= cellValue.timestamp && cellValue.timestamp < right;\n            default:\n                return super.isMeetFilter(condition, cellValue);\n        }\n    }\n\n    override compare(cellValue1: DateFieldValue, cellValue2: DateFieldValue): number {\n        const value1 = cellValueToSortValue(cellValue1);\n        const value2 = cellValueToSortValue(cellValue2);\n        return compareNumber(value1, value2);\n    }\n\n    override toFieldValue(\n        plainText: string,\n        targetField: AITableField,\n        originData?: { field: AITableField; cellValue: FieldValue }\n    ): FieldValue | null {\n        return toDateFieldValue(plainText, targetField, originData);\n    }\n\n    getTimeRange(value: string | number | number[]) {\n        switch (value) {\n            case 'today':\n                return [new TinyDate(new Date()).startOfDay().getUnixTime(), new TinyDate(new Date()).endOfDay().getUnixTime()];\n            case 'current_week':\n                return [\n                    new TinyDate().startOfWeek({ weekStartsOn: 1 }).getUnixTime(),\n                    new TinyDate().endOfWeek({ weekStartsOn: 1 }).getUnixTime()\n                ];\n            case 'yesterday':\n                return [\n                    new TinyDate(subDays(new Date(), 1)).startOfDay().getUnixTime(),\n                    new TinyDate(subDays(new Date(), 1)).endOfDay().getUnixTime()\n                ];\n            case 'current_month':\n                return [new TinyDate().startOfMonth().getUnixTime(), new TinyDate().endOfMonth().getUnixTime()];\n            default:\n                if (isArray(value)) {\n                    return [\n                        new TinyDate(fromUnixTime(value[0] as number)).startOfDay().getUnixTime(),\n                        new TinyDate(fromUnixTime(value[1] as number)).endOfDay().getUnixTime()\n                    ];\n                }\n                return [\n                    new TinyDate(fromUnixTime(value as number)).startOfDay().getUnixTime(),\n                    new TinyDate(fromUnixTime(value as number)).endOfDay().getUnixTime()\n                ];\n        }\n    }\n}\n\nexport function toDateFieldValue(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue }\n): FieldValue | null {\n    if (targetField.type === AITableFieldType.createdAt || targetField.type === AITableFieldType.updatedAt) {\n        return null;\n    }\n\n    if (originData) {\n        const { field, cellValue } = originData;\n        switch (field.type) {\n            case AITableFieldType.date:\n                return cellValue;\n            case AITableFieldType.text:\n                const dateValue = transformDateValue(cellValue);\n                if (dateValue) {\n                    return dateValue;\n                }\n                break;\n            default:\n                break;\n        }\n    } else {\n        const dateValue = transformDateValue(plainText);\n        if (dateValue) {\n            return dateValue;\n        }\n    }\n\n    return null;\n}\n\nfunction cellValueToSortValue(cellValue: DateFieldValue): number {\n    return cellValue?.timestamp;\n}\n\nfunction transformDateValue(text: string): FieldValue | null {\n    const value = text.trim();\n    if (!value || isEmpty(value)) return null;\n\n    // 基础日期格式：支持识别 - / . 年月日 作为分隔符\n    const datePattern = String.raw`(?:(\\d{2}|\\d{4})[-/.年](\\d{1,2})[-/.月](\\d{1,2})日?)`;\n    const timePattern = String.raw`(?:\\s+(\\d{1,2}):(\\d{1,2})(?::(\\d{1,2}))?)?`;\n\n    const pattern = new RegExp(`^${datePattern}${timePattern}$`);\n    const match = value.match(pattern);\n\n    if (!match) return null;\n\n    try {\n        let [_, year, month, day] = match;\n\n        if (year.length === 2) {\n            const currentYear = new Date().getFullYear();\n            const century = Math.floor(currentYear / 100) * 100;\n            const twoDigitYear = parseInt(year);\n            year = String(twoDigitYear > currentYear % 100 ? century - 100 + twoDigitYear : century + twoDigitYear);\n        }\n\n        const monthNum = parseInt(month);\n        const dayNum = parseInt(day);\n\n        if (monthNum < 1 || monthNum > 12) {\n            console.warn('Invalid month:', monthNum);\n            return null;\n        }\n\n        const maxDays = new Date(parseInt(year), monthNum, 0).getDate();\n        if (dayNum < 1 || dayNum > maxDays) {\n            console.warn('Invalid day:', dayNum);\n            return null;\n        }\n\n        const standardDate = `${year}-${String(monthNum).padStart(2, '0')}-${String(dayNum).padStart(2, '0')}`;\n        return {\n            timestamp: new TinyDate(standardDate).getUnixTime()\n        };\n    } catch (error) {\n        console.warn('Invalid date:', value);\n        return null;\n    }\n}\n"]}
|
@@ -58,7 +58,7 @@ export function processPastedValueForSelect(plainText, targetField, originData)
|
|
58
58
|
if (targetOptionIds.includes(id)) {
|
59
59
|
existOptionIds.push(id);
|
60
60
|
}
|
61
|
-
else if (targetFieldOptions.some((option) => option.text === originOptionsMap[id]
|
61
|
+
else if (targetFieldOptions.some((option) => option.text === originOptionsMap[id]?.text)) {
|
62
62
|
const option = targetFieldOptions.find((option) => option.text === originOptionsMap[id].text);
|
63
63
|
existOptionIds.push(option._id);
|
64
64
|
}
|
@@ -116,4 +116,4 @@ function cellValueToSortValue(cellValue, field) {
|
|
116
116
|
}
|
117
117
|
return texts && texts.length ? texts.join(',') : null;
|
118
118
|
}
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/utils/field/model/select.ts"],"names":[],"mappings":"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","sourcesContent":["import { helpers } from 'ngx-tethys/util';\nimport { Field } from './field';\nimport { AITableFilterCondition, AITableFilterOperation } from '../../../types';\nimport { AITableField, AITableFieldType, AITableSelectOption, FieldValue, SelectFieldValue, SelectSettings } from '../../../core';\nimport { isEmpty } from '../../common';\nimport { compareString, hasIntersect } from '../operate';\n\nexport class SelectField extends Field {\n    override isMeetFilter(condition: AITableFilterCondition<string>, cellValue: SelectFieldValue) {\n        switch (condition.operation) {\n            case AITableFilterOperation.empty:\n                return isEmpty(cellValue);\n            case AITableFilterOperation.exists:\n                return !isEmpty(cellValue);\n            case AITableFilterOperation.in:\n                return Array.isArray(condition.value) && hasIntersect(cellValue, condition.value);\n            case AITableFilterOperation.nin:\n                return Array.isArray(condition.value) && !hasIntersect(cellValue, condition.value);\n            default:\n                return super.isMeetFilter(condition, cellValue);\n        }\n    }\n\n    override compare(cellValue1: FieldValue, cellValue2: FieldValue, field: AITableField): number {\n        const value1 = cellValueToSortValue(cellValue1, field);\n        const value2 = cellValueToSortValue(cellValue2, field);\n        return compareString(value1, value2);\n    }\n\n    override cellFullText(transformValue: string[], field: AITableField): string[] {\n        let fullText: string[] = [];\n        const optionsMap = helpers.keyBy((field.settings as SelectSettings).options || [], '_id');\n        if (transformValue && Array.isArray(transformValue) && transformValue.length) {\n            transformValue.forEach((optionId) => {\n                const option = optionsMap[optionId];\n                if (option && option.text) {\n                    fullText.push(option.text);\n                }\n            });\n        }\n        return fullText;\n    }\n\n    override toFieldValue(\n        plainText: string,\n        targetField: AITableField,\n        originData?: { field: AITableField; cellValue: FieldValue } | null\n    ): FieldValue | null {\n        return toSelectFieldValue(plainText, targetField, originData);\n    }\n}\n\nexport function toSelectFieldValue(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue } | null\n): FieldValue | null {\n    return null;\n}\n\nexport function processPastedValueForSelect(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue } | null\n): { existOptionIds: string[]; newOptions: Partial<AITableSelectOption>[] } {\n    const targetFieldOptions = (targetField.settings as SelectSettings)?.options || [];\n    let existOptionIds: string[] = [];\n    let newOptions: Partial<AITableSelectOption>[] = [];\n    let cellFullTexts: string[] = plainText.split(',').map((text) => text.trim());\n\n    const { field, cellValue } = originData || {};\n    if (field && field.type === AITableFieldType.select) {\n        if (cellValue && Array.isArray(cellValue) && cellValue.length) {\n            const targetOptionIds = targetFieldOptions.map((option) => option._id);\n            const originOptionsMap = helpers.keyBy((field.settings as SelectSettings)?.options || [], '_id');\n            cellValue.forEach((id) => {\n                if (targetOptionIds.includes(id)) {\n                    existOptionIds.push(id);\n                } else if (targetFieldOptions.some((option) => option.text === originOptionsMap[id].text)) {\n                    const option = targetFieldOptions.find((option: AITableSelectOption) => option.text === originOptionsMap[id].text);\n                    existOptionIds.push(option!._id);\n                } else {\n                    const originOption = originOptionsMap[id];\n                    if (originOption) {\n                        newOptions.push({\n                            text: originOption.text,\n                            icon: originOption.icon,\n                            color: originOption.color,\n                            bg_color: originOption.bg_color\n                        });\n                    }\n                }\n            });\n        }\n    } else {\n        cellFullTexts.forEach((text) => {\n            const option = targetFieldOptions.find((option) => option.text === text);\n            option ? existOptionIds.push(option._id) : newOptions.push({ text });\n        });\n    }\n\n    const isMultiple = (targetField.settings as SelectSettings)?.is_multiple;\n    if (isMultiple) {\n        return { existOptionIds, newOptions };\n    } else {\n        if (existOptionIds.length) {\n            return { existOptionIds: [existOptionIds[0]], newOptions: [] };\n        } else {\n            if (newOptions.length) {\n                return { existOptionIds: [], newOptions: [newOptions[0]] };\n            } else {\n                return { existOptionIds: [], newOptions: [] };\n            }\n        }\n    }\n}\n\nfunction cellValueToSortValue(cellValue: SelectFieldValue, field: AITableField): string | null {\n    if (!cellValue) {\n        return null;\n    }\n    const texts: string[] = [];\n    const optionsMap = helpers.keyBy((field.settings as SelectSettings).options || [], '_id');\n    if (cellValue && Array.isArray(cellValue) && cellValue.length) {\n        cellValue.forEach((optionId) => {\n            const option = optionsMap[optionId];\n            if (option && option.text) {\n                texts.push(option.text);\n            }\n        });\n    }\n    return texts && texts.length ? texts.join(',') : null;\n}\n"]}
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/utils/field/model/select.ts"],"names":[],"mappings":"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","sourcesContent":["import { helpers } from 'ngx-tethys/util';\nimport { Field } from './field';\nimport { AITableFilterCondition, AITableFilterOperation } from '../../../types';\nimport { AITableField, AITableFieldType, AITableSelectOption, FieldValue, SelectFieldValue, SelectSettings } from '../../../core';\nimport { isEmpty } from '../../common';\nimport { compareString, hasIntersect } from '../operate';\n\nexport class SelectField extends Field {\n    override isMeetFilter(condition: AITableFilterCondition<string>, cellValue: SelectFieldValue) {\n        switch (condition.operation) {\n            case AITableFilterOperation.empty:\n                return isEmpty(cellValue);\n            case AITableFilterOperation.exists:\n                return !isEmpty(cellValue);\n            case AITableFilterOperation.in:\n                return Array.isArray(condition.value) && hasIntersect(cellValue, condition.value);\n            case AITableFilterOperation.nin:\n                return Array.isArray(condition.value) && !hasIntersect(cellValue, condition.value);\n            default:\n                return super.isMeetFilter(condition, cellValue);\n        }\n    }\n\n    override compare(cellValue1: FieldValue, cellValue2: FieldValue, field: AITableField): number {\n        const value1 = cellValueToSortValue(cellValue1, field);\n        const value2 = cellValueToSortValue(cellValue2, field);\n        return compareString(value1, value2);\n    }\n\n    override cellFullText(transformValue: string[], field: AITableField): string[] {\n        let fullText: string[] = [];\n        const optionsMap = helpers.keyBy((field.settings as SelectSettings).options || [], '_id');\n        if (transformValue && Array.isArray(transformValue) && transformValue.length) {\n            transformValue.forEach((optionId) => {\n                const option = optionsMap[optionId];\n                if (option && option.text) {\n                    fullText.push(option.text);\n                }\n            });\n        }\n        return fullText;\n    }\n\n    override toFieldValue(\n        plainText: string,\n        targetField: AITableField,\n        originData?: { field: AITableField; cellValue: FieldValue } | null\n    ): FieldValue | null {\n        return toSelectFieldValue(plainText, targetField, originData);\n    }\n}\n\nexport function toSelectFieldValue(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue } | null\n): FieldValue | null {\n    return null;\n}\n\nexport function processPastedValueForSelect(\n    plainText: string,\n    targetField: AITableField,\n    originData?: { field: AITableField; cellValue: FieldValue } | null\n): { existOptionIds: string[]; newOptions: Partial<AITableSelectOption>[] } {\n    const targetFieldOptions = (targetField.settings as SelectSettings)?.options || [];\n    let existOptionIds: string[] = [];\n    let newOptions: Partial<AITableSelectOption>[] = [];\n    let cellFullTexts: string[] = plainText.split(',').map((text) => text.trim());\n\n    const { field, cellValue } = originData || {};\n    if (field && field.type === AITableFieldType.select) {\n        if (cellValue && Array.isArray(cellValue) && cellValue.length) {\n            const targetOptionIds = targetFieldOptions.map((option) => option._id);\n            const originOptionsMap = helpers.keyBy((field.settings as SelectSettings)?.options || [], '_id');\n            cellValue.forEach((id) => {\n                if (targetOptionIds.includes(id)) {\n                    existOptionIds.push(id);\n                } else if (targetFieldOptions.some((option) => option.text === originOptionsMap[id]?.text)) {\n                    const option = targetFieldOptions.find((option: AITableSelectOption) => option.text === originOptionsMap[id].text);\n                    existOptionIds.push(option!._id);\n                } else {\n                    const originOption = originOptionsMap[id];\n                    if (originOption) {\n                        newOptions.push({\n                            text: originOption.text,\n                            icon: originOption.icon,\n                            color: originOption.color,\n                            bg_color: originOption.bg_color\n                        });\n                    }\n                }\n            });\n        }\n    } else {\n        cellFullTexts.forEach((text) => {\n            const option = targetFieldOptions.find((option) => option.text === text);\n            option ? existOptionIds.push(option._id) : newOptions.push({ text });\n        });\n    }\n\n    const isMultiple = (targetField.settings as SelectSettings)?.is_multiple;\n    if (isMultiple) {\n        return { existOptionIds, newOptions };\n    } else {\n        if (existOptionIds.length) {\n            return { existOptionIds: [existOptionIds[0]], newOptions: [] };\n        } else {\n            if (newOptions.length) {\n                return { existOptionIds: [], newOptions: [newOptions[0]] };\n            } else {\n                return { existOptionIds: [], newOptions: [] };\n            }\n        }\n    }\n}\n\nfunction cellValueToSortValue(cellValue: SelectFieldValue, field: AITableField): string | null {\n    if (!cellValue) {\n        return null;\n    }\n    const texts: string[] = [];\n    const optionsMap = helpers.keyBy((field.settings as SelectSettings).options || [], '_id');\n    if (cellValue && Array.isArray(cellValue) && cellValue.length) {\n        cellValue.forEach((optionId) => {\n            const option = optionsMap[optionId];\n            if (option && option.text) {\n                texts.push(option.text);\n            }\n        });\n    }\n    return texts && texts.length ? texts.join(',') : null;\n}\n"]}
|
@@ -1089,7 +1089,7 @@ class LinkCellEditorComponent extends AbstractEditCellEditor {
|
|
1089
1089
|
}
|
1090
1090
|
updateValue() {
|
1091
1091
|
if (!this.isValidLink({ text: this.text, url: this.url ?? '' })) {
|
1092
|
-
this.notifyService.error(
|
1092
|
+
this.notifyService.error('链接格式不正确');
|
1093
1093
|
return;
|
1094
1094
|
}
|
1095
1095
|
this.modelValue = this.createLinkValue({ text: this.text, url: this.url ?? '' });
|
@@ -2434,13 +2434,24 @@ const readFromClipboard = async () => {
|
|
2434
2434
|
clipboardData.text = clipboardText;
|
2435
2435
|
}
|
2436
2436
|
else {
|
2437
|
-
const
|
2438
|
-
|
2439
|
-
|
2440
|
-
|
2441
|
-
|
2442
|
-
|
2443
|
-
|
2437
|
+
const pastePromise = new Promise((resolve) => {
|
2438
|
+
const textarea = document.createElement('textarea');
|
2439
|
+
document.body.appendChild(textarea);
|
2440
|
+
const handlePaste = (e) => {
|
2441
|
+
const text = e.clipboardData?.getData('text') || '';
|
2442
|
+
const html = e.clipboardData?.getData('text/html') || '';
|
2443
|
+
resolve({
|
2444
|
+
text,
|
2445
|
+
html: html || undefined
|
2446
|
+
});
|
2447
|
+
textarea.removeEventListener('paste', handlePaste);
|
2448
|
+
};
|
2449
|
+
textarea.addEventListener('paste', handlePaste);
|
2450
|
+
textarea.focus();
|
2451
|
+
document.execCommand('paste');
|
2452
|
+
document.body.removeChild(textarea);
|
2453
|
+
});
|
2454
|
+
clipboardData = await pastePromise;
|
2444
2455
|
}
|
2445
2456
|
return clipboardData;
|
2446
2457
|
}
|
@@ -2700,14 +2711,43 @@ function cellValueToSortValue$4(cellValue) {
|
|
2700
2711
|
}
|
2701
2712
|
function transformDateValue(text) {
|
2702
2713
|
const value = text.trim();
|
2703
|
-
|
2704
|
-
|
2705
|
-
|
2706
|
-
|
2714
|
+
if (!value || isEmpty(value))
|
2715
|
+
return null;
|
2716
|
+
// 基础日期格式:支持识别 - / . 年月日 作为分隔符
|
2717
|
+
const datePattern = String.raw `(?:(\d{2}|\d{4})[-/.年](\d{1,2})[-/.月](\d{1,2})日?)`;
|
2718
|
+
const timePattern = String.raw `(?:\s+(\d{1,2}):(\d{1,2})(?::(\d{1,2}))?)?`;
|
2719
|
+
const pattern = new RegExp(`^${datePattern}${timePattern}$`);
|
2720
|
+
const match = value.match(pattern);
|
2721
|
+
if (!match)
|
2722
|
+
return null;
|
2723
|
+
try {
|
2724
|
+
let [_, year, month, day] = match;
|
2725
|
+
if (year.length === 2) {
|
2726
|
+
const currentYear = new Date().getFullYear();
|
2727
|
+
const century = Math.floor(currentYear / 100) * 100;
|
2728
|
+
const twoDigitYear = parseInt(year);
|
2729
|
+
year = String(twoDigitYear > currentYear % 100 ? century - 100 + twoDigitYear : century + twoDigitYear);
|
2730
|
+
}
|
2731
|
+
const monthNum = parseInt(month);
|
2732
|
+
const dayNum = parseInt(day);
|
2733
|
+
if (monthNum < 1 || monthNum > 12) {
|
2734
|
+
console.warn('Invalid month:', monthNum);
|
2735
|
+
return null;
|
2736
|
+
}
|
2737
|
+
const maxDays = new Date(parseInt(year), monthNum, 0).getDate();
|
2738
|
+
if (dayNum < 1 || dayNum > maxDays) {
|
2739
|
+
console.warn('Invalid day:', dayNum);
|
2740
|
+
return null;
|
2741
|
+
}
|
2742
|
+
const standardDate = `${year}-${String(monthNum).padStart(2, '0')}-${String(dayNum).padStart(2, '0')}`;
|
2743
|
+
return {
|
2744
|
+
timestamp: new TinyDate(standardDate).getUnixTime()
|
2707
2745
|
};
|
2708
|
-
return dateValue;
|
2709
2746
|
}
|
2710
|
-
|
2747
|
+
catch (error) {
|
2748
|
+
console.warn('Invalid date:', value);
|
2749
|
+
return null;
|
2750
|
+
}
|
2711
2751
|
}
|
2712
2752
|
|
2713
2753
|
class LinkField extends Field {
|
@@ -3082,7 +3122,7 @@ function processPastedValueForSelect(plainText, targetField, originData) {
|
|
3082
3122
|
if (targetOptionIds.includes(id)) {
|
3083
3123
|
existOptionIds.push(id);
|
3084
3124
|
}
|
3085
|
-
else if (targetFieldOptions.some((option) => option.text === originOptionsMap[id]
|
3125
|
+
else if (targetFieldOptions.some((option) => option.text === originOptionsMap[id]?.text)) {
|
3086
3126
|
const option = targetFieldOptions.find((option) => option.text === originOptionsMap[id].text);
|
3087
3127
|
existOptionIds.push(option._id);
|
3088
3128
|
}
|
@@ -3288,27 +3328,39 @@ function extractContentFromClipboardText(clipboardText) {
|
|
3288
3328
|
.filter((row) => row.length > 0 && row.some((cell) => cell.trim().length > 0));
|
3289
3329
|
return contents;
|
3290
3330
|
}
|
3331
|
+
function processTableCell(cellHtml) {
|
3332
|
+
const linkPattern = /<a[^>]*?href=["']([^"']+)["'][^>]*?>([^<]*?)<\/a>/i;
|
3333
|
+
const match = cellHtml.match(linkPattern);
|
3334
|
+
const link = match ? { href: match[1], text: match[2] } : null;
|
3335
|
+
const content = link ? cellHtml.replace(linkPattern, `[LINK:${link.text}](${link.href})`) : cellHtml;
|
3336
|
+
const cleanContent = content
|
3337
|
+
.replace(/<[^>]+>/g, '')
|
3338
|
+
.replace(/ /g, ' ')
|
3339
|
+
.replace(/\s+/g, ' ')
|
3340
|
+
.trim();
|
3341
|
+
return link ? cleanContent.replace(`[LINK:${link.text}](${link.href})`, `<a href="${link.href}">${link.text}</a>`) : cleanContent;
|
3342
|
+
}
|
3291
3343
|
function extractContentFromClipboardHtml(clipboardHtml) {
|
3292
3344
|
const tablePattern = /<table[^>]*>([\s\S]*?)<\/table>/i;
|
3293
3345
|
const trPattern = /<tr[^>]*>([\s\S]*?)<\/tr>/gi;
|
3294
|
-
const
|
3295
|
-
const contents = [];
|
3346
|
+
const tdPattern = /<td[^>]*?>([\s\S]*?)<\/td>/gi;
|
3296
3347
|
try {
|
3297
3348
|
const tableMatch = clipboardHtml.match(tablePattern);
|
3298
3349
|
const tableContent = tableMatch ? tableMatch[1] : clipboardHtml;
|
3299
3350
|
const rows = tableContent.match(trPattern) || [];
|
3300
|
-
rows
|
3301
|
-
|
3302
|
-
const
|
3303
|
-
|
3304
|
-
|
3305
|
-
|
3306
|
-
}
|
3307
|
-
contents
|
3308
|
-
})
|
3309
|
-
|
3351
|
+
return rows
|
3352
|
+
.map((row) => {
|
3353
|
+
const contents = [];
|
3354
|
+
let tdMatch;
|
3355
|
+
while ((tdMatch = tdPattern.exec(row)) !== null) {
|
3356
|
+
contents.push(processTableCell(tdMatch[1]));
|
3357
|
+
}
|
3358
|
+
return contents;
|
3359
|
+
})
|
3360
|
+
.filter((row) => row.length > 0);
|
3310
3361
|
}
|
3311
3362
|
catch (error) {
|
3363
|
+
console.warn('Failed to extract content from HTML:', error);
|
3312
3364
|
return [];
|
3313
3365
|
}
|
3314
3366
|
}
|
@@ -3356,21 +3408,25 @@ function getPasteValue(plainText, aiTableContent, recordIndex, fieldIndex, targe
|
|
3356
3408
|
let originData = field && record ? { field, cellValue: getFieldValue(record, field) } : null;
|
3357
3409
|
if (targetField.type === AITableFieldType.select) {
|
3358
3410
|
let { existOptionIds, newOptions } = processPastedValueForSelect(plainText, targetField, originData);
|
3359
|
-
|
3360
|
-
|
3361
|
-
|
3362
|
-
|
3411
|
+
let newField = null;
|
3412
|
+
let newOptionIds = [];
|
3413
|
+
if (newOptions.length) {
|
3414
|
+
newOptions = newOptions.map((option) => {
|
3415
|
+
return {
|
3416
|
+
...option,
|
3417
|
+
_id: idCreator()
|
3418
|
+
};
|
3419
|
+
});
|
3420
|
+
newField = {
|
3421
|
+
...targetField,
|
3422
|
+
settings: {
|
3423
|
+
...targetField.settings,
|
3424
|
+
options: [...(targetField.settings?.options || []), ...newOptions]
|
3425
|
+
}
|
3363
3426
|
};
|
3364
|
-
|
3365
|
-
|
3366
|
-
|
3367
|
-
settings: {
|
3368
|
-
...targetField.settings,
|
3369
|
-
options: [...(targetField.settings?.options || []), ...newOptions]
|
3370
|
-
}
|
3371
|
-
};
|
3372
|
-
const newOptionIds = newOptions.map((option) => option._id).filter((id) => !!id);
|
3373
|
-
const selectFieldValue = [...existOptionIds, ...newOptionIds];
|
3427
|
+
newOptionIds = newOptions.map((option) => option._id).filter((id) => !!id);
|
3428
|
+
}
|
3429
|
+
const selectFieldValue = newOptionIds?.length ? [...existOptionIds, ...newOptionIds] : existOptionIds;
|
3374
3430
|
return {
|
3375
3431
|
value: selectFieldValue,
|
3376
3432
|
newField
|
@@ -8629,7 +8685,7 @@ class AITableDragComponent {
|
|
8629
8685
|
const coordinate = drag.coordinate;
|
8630
8686
|
switch (drag.type) {
|
8631
8687
|
case DragType.field:
|
8632
|
-
const fields = aiTable.
|
8688
|
+
const fields = aiTable.gridData().fields;
|
8633
8689
|
let width = 0;
|
8634
8690
|
fields.forEach((field, index) => {
|
8635
8691
|
if (drag.sourceIds.has(field._id)) {
|
@@ -9218,7 +9274,7 @@ class AITableGrid extends AITableGridBase {
|
|
9218
9274
|
});
|
9219
9275
|
}
|
9220
9276
|
handleFieldDragStart() {
|
9221
|
-
if (this.aiTableGridSelectionService.selectedFields.size > 0) {
|
9277
|
+
if (!this.aiReadonly() && this.aiTableGridSelectionService.selectedFields.size > 0) {
|
9222
9278
|
this.aiTableGridSelectionService.drag({
|
9223
9279
|
type: DragType.field,
|
9224
9280
|
sourceIds: this.aiTableGridSelectionService.selectedFields,
|
@@ -9237,7 +9293,7 @@ class AITableGrid extends AITableGridBase {
|
|
9237
9293
|
dragEnd(data) {
|
9238
9294
|
switch (data.type) {
|
9239
9295
|
case DragType.field:
|
9240
|
-
if (data.fieldsIndex && data.targetIndex) {
|
9296
|
+
if (data.fieldsIndex && isNumber(data.targetIndex)) {
|
9241
9297
|
for (let i = 0; i < data.fieldsIndex.length; i++) {
|
9242
9298
|
this.aiMoveField.emit({
|
9243
9299
|
path: [data.fieldsIndex[i]],
|