@ai-table/grid 0.0.42 → 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/grid.component.mjs +2 -2
- package/esm2022/utils/clipboard/paste.mjs +25 -13
- package/esm2022/utils/field/model/date.mjs +36 -7
- package/fesm2022/ai-table-grid.mjs +61 -20
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/package.json +1 -1
- package/utils/clipboard/paste.d.ts.map +1 -1
@@ -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":"AAAA,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AACjD,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAA0B,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AAChF,OAAO,EAAgB,gBAAgB,EAA8B,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,MAAM,OAAO,SAAU,SAAQ,KAAK;IACvB,YAAY,CAAC,SAAyC,EAAE,SAAyB;QACtF,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACzD,QAAQ,SAAS,CAAC,SAAS,EAAE,CAAC;YAC1B,KAAK,sBAAsB,CAAC,KAAK;gBAC7B,OAAO,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,SAAS,KAAK,CAAC,CAAC;YACrE,KAAK,sBAAsB,CAAC,MAAM;gBAC9B,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,SAAS,KAAK,CAAC,CAAC;YACtE,KAAK,sBAAsB,CAAC,EAAE;gBAC1B,OAAO,IAAI,IAAI,SAAS,CAAC,SAAS,IAAI,SAAS,CAAC,SAAS,GAAG,KAAK,CAAC;YACtE,KAAK,sBAAsB,CAAC,EAAE;gBAC1B,OAAO,SAAS,CAAC,SAAS,GAAG,KAAK,CAAC;YACvC,KAAK,sBAAsB,CAAC,EAAE;gBAC1B,OAAO,SAAS,CAAC,SAAS,GAAG,IAAI,CAAC;YACtC,KAAK,sBAAsB,CAAC,OAAO;gBAC/B,OAAO,IAAI,IAAI,SAAS,CAAC,SAAS,IAAI,SAAS,CAAC,SAAS,GAAG,KAAK,CAAC;YACtE;gBACI,OAAO,KAAK,CAAC,YAAY,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACxD,CAAC;IACL,CAAC;IAEQ,OAAO,CAAC,UAA0B,EAAE,UAA0B;QACnE,MAAM,MAAM,GAAG,oBAAoB,CAAC,UAAU,CAAC,CAAC;QAChD,MAAM,MAAM,GAAG,oBAAoB,CAAC,UAAU,CAAC,CAAC;QAChD,OAAO,aAAa,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzC,CAAC;IAEQ,YAAY,CACjB,SAAiB,EACjB,WAAyB,EACzB,UAA2D;QAE3D,OAAO,gBAAgB,CAAC,SAAS,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;IAChE,CAAC;IAED,YAAY,CAAC,KAAiC;QAC1C,QAAQ,KAAK,EAAE,CAAC;YACZ,KAAK,OAAO;gBACR,OAAO,CAAC,IAAI,QAAQ,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,WAAW,EAAE,EAAE,IAAI,QAAQ,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;YACpH,KAAK,cAAc;gBACf,OAAO;oBACH,IAAI,QAAQ,EAAE,CAAC,WAAW,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE;oBAC7D,IAAI,QAAQ,EAAE,CAAC,SAAS,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE;iBAC9D,CAAC;YACN,KAAK,WAAW;gBACZ,OAAO;oBACH,IAAI,QAAQ,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,WAAW,EAAE;oBAC/D,IAAI,QAAQ,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE;iBAChE,CAAC;YACN,KAAK,eAAe;gBAChB,OAAO,CAAC,IAAI,QAAQ,EAAE,CAAC,YAAY,EAAE,CAAC,WAAW,EAAE,EAAE,IAAI,QAAQ,EAAE,CAAC,UAAU,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;YACpG;gBACI,IAAI,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;oBACjB,OAAO;wBACH,IAAI,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAW,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,WAAW,EAAE;wBACzE,IAAI,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAW,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE;qBAC1E,CAAC;gBACN,CAAC;gBACD,OAAO;oBACH,IAAI,QAAQ,CAAC,YAAY,CAAC,KAAe,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,WAAW,EAAE;oBACtE,IAAI,QAAQ,CAAC,YAAY,CAAC,KAAe,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE;iBACvE,CAAC;QACV,CAAC;IACL,CAAC;CACJ;AAED,MAAM,UAAU,gBAAgB,CAC5B,SAAiB,EACjB,WAAyB,EACzB,UAA2D;IAE3D,IAAI,WAAW,CAAC,IAAI,KAAK,gBAAgB,CAAC,SAAS,IAAI,WAAW,CAAC,IAAI,KAAK,gBAAgB,CAAC,SAAS,EAAE,CAAC;QACrG,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,UAAU,EAAE,CAAC;QACb,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,UAAU,CAAC;QACxC,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC;YACjB,KAAK,gBAAgB,CAAC,IAAI;gBACtB,OAAO,SAAS,CAAC;YACrB,KAAK,gBAAgB,CAAC,IAAI;gBACtB,MAAM,SAAS,GAAG,kBAAkB,CAAC,SAAS,CAAC,CAAC;gBAChD,IAAI,SAAS,EAAE,CAAC;oBACZ,OAAO,SAAS,CAAC;gBACrB,CAAC;gBACD,MAAM;YACV;gBACI,MAAM;QACd,CAAC;IACL,CAAC;SAAM,CAAC;QACJ,MAAM,SAAS,GAAG,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAChD,IAAI,SAAS,EAAE,CAAC;YACZ,OAAO,SAAS,CAAC;QACrB,CAAC;IACL,CAAC;IAED,OAAO,IAAI,CAAC;AAChB,CAAC;AAED,SAAS,oBAAoB,CAAC,SAAyB;IACnD,OAAO,SAAS,EAAE,SAAS,CAAC;AAChC,CAAC;AAED,SAAS,kBAAkB,CAAC,IAAY;IACpC,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;IAC1B,MAAM,OAAO,GAAG,yBAAyB,CAAC;IAE1C,IAAI,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QAClD,MAAM,SAAS,GAAG;YACd,SAAS,EAAE,IAAI,QAAQ,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE;SAC/C,CAAC;QACF,OAAO,SAAS,CAAC;IACrB,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC","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"]}
|
@@ -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 ?? '' });
|
@@ -2711,14 +2711,43 @@ function cellValueToSortValue$4(cellValue) {
|
|
2711
2711
|
}
|
2712
2712
|
function transformDateValue(text) {
|
2713
2713
|
const value = text.trim();
|
2714
|
-
|
2715
|
-
|
2716
|
-
|
2717
|
-
|
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()
|
2718
2745
|
};
|
2719
|
-
return dateValue;
|
2720
2746
|
}
|
2721
|
-
|
2747
|
+
catch (error) {
|
2748
|
+
console.warn('Invalid date:', value);
|
2749
|
+
return null;
|
2750
|
+
}
|
2722
2751
|
}
|
2723
2752
|
|
2724
2753
|
class LinkField extends Field {
|
@@ -3299,27 +3328,39 @@ function extractContentFromClipboardText(clipboardText) {
|
|
3299
3328
|
.filter((row) => row.length > 0 && row.some((cell) => cell.trim().length > 0));
|
3300
3329
|
return contents;
|
3301
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
|
+
}
|
3302
3343
|
function extractContentFromClipboardHtml(clipboardHtml) {
|
3303
3344
|
const tablePattern = /<table[^>]*>([\s\S]*?)<\/table>/i;
|
3304
3345
|
const trPattern = /<tr[^>]*>([\s\S]*?)<\/tr>/gi;
|
3305
|
-
const
|
3306
|
-
const contents = [];
|
3346
|
+
const tdPattern = /<td[^>]*?>([\s\S]*?)<\/td>/gi;
|
3307
3347
|
try {
|
3308
3348
|
const tableMatch = clipboardHtml.match(tablePattern);
|
3309
3349
|
const tableContent = tableMatch ? tableMatch[1] : clipboardHtml;
|
3310
3350
|
const rows = tableContent.match(trPattern) || [];
|
3311
|
-
rows
|
3312
|
-
|
3313
|
-
const
|
3314
|
-
|
3315
|
-
|
3316
|
-
|
3317
|
-
}
|
3318
|
-
contents
|
3319
|
-
})
|
3320
|
-
|
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);
|
3321
3361
|
}
|
3322
3362
|
catch (error) {
|
3363
|
+
console.warn('Failed to extract content from HTML:', error);
|
3323
3364
|
return [];
|
3324
3365
|
}
|
3325
3366
|
}
|
@@ -9233,7 +9274,7 @@ class AITableGrid extends AITableGridBase {
|
|
9233
9274
|
});
|
9234
9275
|
}
|
9235
9276
|
handleFieldDragStart() {
|
9236
|
-
if (this.aiTableGridSelectionService.selectedFields.size > 0) {
|
9277
|
+
if (!this.aiReadonly() && this.aiTableGridSelectionService.selectedFields.size > 0) {
|
9237
9278
|
this.aiTableGridSelectionService.drag({
|
9238
9279
|
type: DragType.field,
|
9239
9280
|
sourceIds: this.aiTableGridSelectionService.selectedFields,
|