From 72f35120e1e96da3d63a56bae94b4ee9834f18fe Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 1 Jun 2022 21:48:49 +0000 Subject: [PATCH 001/194] chore(deps): bump eventsource from 1.1.0 to 1.1.1 in /packages/noco-i18n Bumps [eventsource](https://github.com/EventSource/eventsource) from 1.1.0 to 1.1.1. - [Release notes](https://github.com/EventSource/eventsource/releases) - [Changelog](https://github.com/EventSource/eventsource/blob/master/HISTORY.md) - [Commits](https://github.com/EventSource/eventsource/compare/v1.1.0...v1.1.1) --- updated-dependencies: - dependency-name: eventsource dependency-type: indirect ... Signed-off-by: dependabot[bot] --- packages/noco-i18n/package-lock.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/noco-i18n/package-lock.json b/packages/noco-i18n/package-lock.json index 0534c88b81..84f28ed114 100644 --- a/packages/noco-i18n/package-lock.json +++ b/packages/noco-i18n/package-lock.json @@ -5058,9 +5058,9 @@ "dev": true }, "eventsource": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/eventsource/-/eventsource-1.1.0.tgz", - "integrity": "sha512-VSJjT5oCNrFvCS6igjzPAt5hBzQ2qPBFIbJ03zLI9SE0mxwZpMw6BfJrbFHm1a141AavMEB8JHmBhWAd66PfCg==", + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/eventsource/-/eventsource-1.1.1.tgz", + "integrity": "sha512-qV5ZC0h7jYIAOhArFJgSfdyz6rALJyb270714o7ZtNnw2WSJ+eexhKtE0O8LYPRsHZHf2osHKZBxGPvm3kPkCA==", "dev": true, "requires": { "original": "^1.0.0" From 68febd24fad8633a16bac21175cc32bd64e94a8a Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 20 Jul 2022 06:42:23 +0000 Subject: [PATCH 002/194] chore(deps): bump terser from 5.10.0 to 5.14.2 in /packages/nc-cli Bumps [terser](https://github.com/terser/terser) from 5.10.0 to 5.14.2. - [Release notes](https://github.com/terser/terser/releases) - [Changelog](https://github.com/terser/terser/blob/master/CHANGELOG.md) - [Commits](https://github.com/terser/terser/commits) --- updated-dependencies: - dependency-name: terser dependency-type: indirect ... Signed-off-by: dependabot[bot] --- packages/nc-cli/package-lock.json | 150 +++++++++++++++++++++++------- 1 file changed, 117 insertions(+), 33 deletions(-) diff --git a/packages/nc-cli/package-lock.json b/packages/nc-cli/package-lock.json index 7edacb0e6b..af1d5a60f1 100644 --- a/packages/nc-cli/package-lock.json +++ b/packages/nc-cli/package-lock.json @@ -797,6 +797,64 @@ "node": ">=4.0" } }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", + "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "dev": true, + "dependencies": { + "@jridgewell/set-array": "^1.0.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.9" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", + "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/source-map": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.2.tgz", + "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==", + "dev": true, + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.0", + "@jridgewell/trace-mapping": "^0.3.9" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.4.14", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", + "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", + "dev": true + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.14", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz", + "integrity": "sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ==", + "dev": true, + "dependencies": { + "@jridgewell/resolve-uri": "^3.0.3", + "@jridgewell/sourcemap-codec": "^1.4.10" + } + }, "node_modules/@nodelib/fs.scandir": { "version": "2.1.5", "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", @@ -14079,13 +14137,14 @@ } }, "node_modules/terser": { - "version": "5.10.0", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.10.0.tgz", - "integrity": "sha512-AMmF99DMfEDiRJfxfY5jj5wNH/bYO09cniSqhfoyxc8sFoYIgkJy86G04UoZU5VjlpnplVu0K6Tx6E9b5+DlHA==", + "version": "5.14.2", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.14.2.tgz", + "integrity": "sha512-oL0rGeM/WFQCUd0y2QrWxYnq7tfSuKBiqTjRPWrRgB46WD/kiwHwF8T23z78H6Q6kGCuuHcPB+KULHRdxvVGQA==", "dev": true, "dependencies": { + "@jridgewell/source-map": "^0.3.2", + "acorn": "^8.5.0", "commander": "^2.20.0", - "source-map": "~0.7.2", "source-map-support": "~0.5.20" }, "bin": { @@ -14093,14 +14152,6 @@ }, "engines": { "node": ">=10" - }, - "peerDependencies": { - "acorn": "^8.5.0" - }, - "peerDependenciesMeta": { - "acorn": { - "optional": true - } } }, "node_modules/terser-webpack-plugin": { @@ -14155,15 +14206,6 @@ "node": ">=0.10.0" } }, - "node_modules/terser/node_modules/source-map": { - "version": "0.7.3", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", - "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", - "dev": true, - "engines": { - "node": ">= 8" - } - }, "node_modules/test-exclude": { "version": "5.2.3", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-5.2.3.tgz", @@ -16803,6 +16845,55 @@ "integrity": "sha512-SxIFtV5/wlXYS7G3zLVj7CddLolX8Bm/hr68fiyNL3MyG2k4FwF9B5Z5GTpVLhw2EELYNwyoYBvFlR4gGnQPdw==", "dev": true }, + "@jridgewell/gen-mapping": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", + "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "dev": true, + "requires": { + "@jridgewell/set-array": "^1.0.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.9" + } + }, + "@jridgewell/resolve-uri": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", + "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "dev": true + }, + "@jridgewell/set-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "dev": true + }, + "@jridgewell/source-map": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.2.tgz", + "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==", + "dev": true, + "requires": { + "@jridgewell/gen-mapping": "^0.3.0", + "@jridgewell/trace-mapping": "^0.3.9" + } + }, + "@jridgewell/sourcemap-codec": { + "version": "1.4.14", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", + "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", + "dev": true + }, + "@jridgewell/trace-mapping": { + "version": "0.3.14", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz", + "integrity": "sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ==", + "dev": true, + "requires": { + "@jridgewell/resolve-uri": "^3.0.3", + "@jridgewell/sourcemap-codec": "^1.4.10" + } + }, "@nodelib/fs.scandir": { "version": "2.1.5", "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", @@ -27038,22 +27129,15 @@ "integrity": "sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg==" }, "terser": { - "version": "5.10.0", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.10.0.tgz", - "integrity": "sha512-AMmF99DMfEDiRJfxfY5jj5wNH/bYO09cniSqhfoyxc8sFoYIgkJy86G04UoZU5VjlpnplVu0K6Tx6E9b5+DlHA==", + "version": "5.14.2", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.14.2.tgz", + "integrity": "sha512-oL0rGeM/WFQCUd0y2QrWxYnq7tfSuKBiqTjRPWrRgB46WD/kiwHwF8T23z78H6Q6kGCuuHcPB+KULHRdxvVGQA==", "dev": true, "requires": { + "@jridgewell/source-map": "^0.3.2", + "acorn": "^8.5.0", "commander": "^2.20.0", - "source-map": "~0.7.2", "source-map-support": "~0.5.20" - }, - "dependencies": { - "source-map": { - "version": "0.7.3", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", - "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", - "dev": true - } } }, "terser-webpack-plugin": { From 9ca53a1f326341d96af54303b4881306f82fc527 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 20 Jul 2022 17:36:42 +0000 Subject: [PATCH 003/194] chore(deps): bump terser from 4.8.0 to 4.8.1 in /packages/noco-docs Bumps [terser](https://github.com/terser/terser) from 4.8.0 to 4.8.1. - [Release notes](https://github.com/terser/terser/releases) - [Changelog](https://github.com/terser/terser/blob/master/CHANGELOG.md) - [Commits](https://github.com/terser/terser/commits) --- updated-dependencies: - dependency-name: terser dependency-type: indirect ... Signed-off-by: dependabot[bot] --- packages/noco-docs/package-lock.json | 81 ++++++++++++++++++++++------ 1 file changed, 66 insertions(+), 15 deletions(-) diff --git a/packages/noco-docs/package-lock.json b/packages/noco-docs/package-lock.json index eea54fe2a5..a20455bb51 100644 --- a/packages/noco-docs/package-lock.json +++ b/packages/noco-docs/package-lock.json @@ -1259,6 +1259,49 @@ } } }, + "@jridgewell/gen-mapping": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", + "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "requires": { + "@jridgewell/set-array": "^1.0.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.9" + } + }, + "@jridgewell/resolve-uri": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", + "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==" + }, + "@jridgewell/set-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==" + }, + "@jridgewell/source-map": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.2.tgz", + "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==", + "requires": { + "@jridgewell/gen-mapping": "^0.3.0", + "@jridgewell/trace-mapping": "^0.3.9" + } + }, + "@jridgewell/sourcemap-codec": { + "version": "1.4.14", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", + "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" + }, + "@jridgewell/trace-mapping": { + "version": "0.3.14", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz", + "integrity": "sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ==", + "requires": { + "@jridgewell/resolve-uri": "^3.0.3", + "@jridgewell/sourcemap-codec": "^1.4.10" + } + }, "@koa/router": { "version": "9.4.0", "resolved": "https://registry.npmjs.org/@koa/router/-/router-9.4.0.tgz", @@ -11459,9 +11502,9 @@ } }, "terser": { - "version": "4.8.0", - "resolved": "https://registry.npmjs.org/terser/-/terser-4.8.0.tgz", - "integrity": "sha512-EAPipTNeWsb/3wLPeup1tVPaXfIaU68xMnVdPafIL1TV05OhASArYyIfFvnvJCNrR2NIOvDVNNTFRa+Re2MWyw==", + "version": "4.8.1", + "resolved": "https://registry.npmjs.org/terser/-/terser-4.8.1.tgz", + "integrity": "sha512-4GnLC0x667eJG0ewJTa6z/yXrbLGv80D9Ru6HIpCQmO+Q4PfEtBFi0ObSckqwL6VyQv/7ENJieXHo2ANmdQwgw==", "requires": { "commander": "^2.20.0", "source-map": "~0.6.1", @@ -11484,6 +11527,11 @@ "webpack-sources": "^1.4.3" }, "dependencies": { + "acorn": { + "version": "8.7.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz", + "integrity": "sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A==" + }, "p-limit": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", @@ -11492,21 +11540,24 @@ "yocto-queue": "^0.1.0" } }, + "source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, "terser": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.7.1.tgz", - "integrity": "sha512-b3e+d5JbHAe/JSjwsC3Zn55wsBIM7AsHLjKxT31kGCldgbpFePaFo+PiddtO6uwRZWRw7sPXmAN8dTW61xmnSg==", + "version": "5.14.2", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.14.2.tgz", + "integrity": "sha512-oL0rGeM/WFQCUd0y2QrWxYnq7tfSuKBiqTjRPWrRgB46WD/kiwHwF8T23z78H6Q6kGCuuHcPB+KULHRdxvVGQA==", "requires": { + "@jridgewell/source-map": "^0.3.2", + "acorn": "^8.5.0", "commander": "^2.20.0", - "source-map": "~0.7.2", - "source-map-support": "~0.5.19" - }, - "dependencies": { - "source-map": { - "version": "0.7.3", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", - "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==" - } + "source-map-support": "~0.5.20" } } } From 2751836458c5b2d23b5159fa28c9ced5c3485f34 Mon Sep 17 00:00:00 2001 From: mertmit Date: Wed, 20 Jul 2022 22:29:10 +0300 Subject: [PATCH 004/194] fix: allow env variables to recover missing super user Signed-off-by: mertmit --- .../lib/meta/api/userApi/initAdminFromEnv.ts | 53 +++++++++++++++++-- 1 file changed, 50 insertions(+), 3 deletions(-) diff --git a/packages/nocodb/src/lib/meta/api/userApi/initAdminFromEnv.ts b/packages/nocodb/src/lib/meta/api/userApi/initAdminFromEnv.ts index 82896ad0c3..fc8e08264e 100644 --- a/packages/nocodb/src/lib/meta/api/userApi/initAdminFromEnv.ts +++ b/packages/nocodb/src/lib/meta/api/userApi/initAdminFromEnv.ts @@ -63,11 +63,10 @@ export default async function initAdminFromEnv(_ncMeta = Noco.ncMeta) { salt ); const email_verification_token = uuidv4(); + const roles = 'user,super'; // if super admin not present if (await User.isFirst(ncMeta)) { - const roles = 'user,super'; - // roles = 'owner,creator,editor' Tele.emit('evt', { evt_type: 'project:invite', @@ -96,8 +95,56 @@ export default async function initAdminFromEnv(_ncMeta = Noco.ncMeta) { const superUser = await ncMeta.metaGet2(null, null, MetaTable.USERS, { roles: 'user,super', }); + + if (!superUser?.id) { + const existingUserWithNewEmail = await User.getByEmail(email, ncMeta); + if (existingUserWithNewEmail?.id) { + // clear cache + await NocoCache.delAll( + CacheScope.USER, + `${existingUserWithNewEmail.email}___*` + ); + await NocoCache.del( + `${CacheScope.USER}:${existingUserWithNewEmail.id}` + ); + await NocoCache.del( + `${CacheScope.USER}:${existingUserWithNewEmail.email}` + ); - if (email !== superUser.email) { + // Update email and password of super admin account + await User.update( + existingUserWithNewEmail.id, + { + salt, + email, + password, + email_verification_token, + token_version: null, + refresh_token: null, + roles, + }, + ncMeta + ); + } else { + Tele.emit('evt', { + evt_type: 'project:invite', + count: 1, + }); + + await User.insert( + { + firstname: '', + lastname: '', + email, + salt, + password, + email_verification_token, + roles, + }, + ncMeta + ); + } + } else if (email !== superUser.email) { // update admin email and password and migrate projects // if user already present and associated with some project From 03da47116c6f03d557b62f2183e29a1ef046b48a Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 6 Sep 2022 05:08:27 +0000 Subject: [PATCH 005/194] chore(deps): bump undici from 5.5.1 to 5.10.0 in /packages/nc-gui Bumps [undici](https://github.com/nodejs/undici) from 5.5.1 to 5.10.0. - [Release notes](https://github.com/nodejs/undici/releases) - [Commits](https://github.com/nodejs/undici/compare/v5.5.1...v5.10.0) --- updated-dependencies: - dependency-name: undici dependency-type: indirect ... Signed-off-by: dependabot[bot] --- packages/nc-gui/package-lock.json | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/packages/nc-gui/package-lock.json b/packages/nc-gui/package-lock.json index e1297204c7..b5b80ac6c3 100644 --- a/packages/nc-gui/package-lock.json +++ b/packages/nc-gui/package-lock.json @@ -13976,9 +13976,9 @@ } }, "node_modules/undici": { - "version": "5.5.1", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.5.1.tgz", - "integrity": "sha512-MEvryPLf18HvlCbLSzCW0U00IMftKGI5udnjrQbC5D4P0Hodwffhv+iGfWuJwg16Y/TK11ZFK8i+BPVW2z/eAw==", + "version": "5.10.0", + "resolved": "https://registry.npmjs.org/undici/-/undici-5.10.0.tgz", + "integrity": "sha512-c8HsD3IbwmjjbLvoZuRI26TZic+TSEe8FPMLLOkN1AfYRhdjnKBU6yL+IwcSCbdZiX4e5t0lfMDLDCqj4Sq70g==", "dev": true, "engines": { "node": ">=12.18" @@ -25667,9 +25667,9 @@ } }, "undici": { - "version": "5.5.1", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.5.1.tgz", - "integrity": "sha512-MEvryPLf18HvlCbLSzCW0U00IMftKGI5udnjrQbC5D4P0Hodwffhv+iGfWuJwg16Y/TK11ZFK8i+BPVW2z/eAw==", + "version": "5.10.0", + "resolved": "https://registry.npmjs.org/undici/-/undici-5.10.0.tgz", + "integrity": "sha512-c8HsD3IbwmjjbLvoZuRI26TZic+TSEe8FPMLLOkN1AfYRhdjnKBU6yL+IwcSCbdZiX4e5t0lfMDLDCqj4Sq70g==", "dev": true }, "unenv": { From 430a50ed710224b0afbda464954dd983a502f950 Mon Sep 17 00:00:00 2001 From: Wonkeun No Date: Fri, 14 Oct 2022 14:32:44 -0400 Subject: [PATCH 006/194] Add an argument to ROUND func to show decimal numbers --- packages/nc-gui/utils/formulaUtils.ts | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/packages/nc-gui/utils/formulaUtils.ts b/packages/nc-gui/utils/formulaUtils.ts index 63b89a94e2..9b084ce6b0 100644 --- a/packages/nc-gui/utils/formulaUtils.ts +++ b/packages/nc-gui/utils/formulaUtils.ts @@ -176,12 +176,12 @@ const formulas: Record = { type: formulaTypes.NUMERIC, validation: { args: { - rqd: 1, + rqd: 2, }, }, - description: 'Nearest integer to the input parameter', - syntax: 'ROUND(value)', - examples: ['ROUND(3.1415) => 3', 'ROUND({column1})'], + description: 'Rounded number to a specified number of decimal places', + syntax: 'ROUND(value, decimals)', + examples: ['ROUND(3.1415,2) => 3.14', 'ROUND({column1}, 3)'], }, MOD: { type: formulaTypes.NUMERIC, From 3c6c34adc07701a00928df023138e31ff2141ea2 Mon Sep 17 00:00:00 2001 From: Wing-Kam Wong Date: Mon, 17 Oct 2022 11:41:35 +0800 Subject: [PATCH 007/194] refactor(nc-gui): pass tableIdx instead of passing table to addNewColumnRow --- .../nc-gui/components/template/Editor.vue | 20 +++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/packages/nc-gui/components/template/Editor.vue b/packages/nc-gui/components/template/Editor.vue index 023216ec71..f6c403fb49 100644 --- a/packages/nc-gui/components/template/Editor.vue +++ b/packages/nc-gui/components/template/Editor.vue @@ -97,7 +97,7 @@ const srcDestMapping = ref[]>([]) const data = reactive<{ title: string | null name: string - tables: (TableType & { ref_table_name: string; columns: (ColumnType & { _disableSelect?: boolean })[] })[] + tables: (TableType & { ref_table_name: string; columns: (ColumnType & { key: number; _disableSelect?: boolean })[] })[] }>({ title: null, name: 'Project Name', @@ -206,15 +206,15 @@ function deleteTableColumn(tableIdx: number, columnIdx: number) { data.tables[tableIdx].columns?.splice(columnIdx, 1) } -function addNewColumnRow(table: Record, uidt?: string) { - table.columns.push({ - key: table.columns.length, - column_name: `title${table.columns.length + 1}`, +function addNewColumnRow(tableIdx: number, uidt: string) { + data.tables[tableIdx].columns.push({ + key: data.tables[tableIdx].columns.length + 1, + column_name: `title${data.tables[tableIdx].columns.length + 1}`, uidt, }) nextTick(() => { - const input = inputRefs.value[table.columns.length - 1] + const input = inputRefs.value[data.tables[tableIdx].columns.length - 1] input.focus() input.select() @@ -794,7 +794,7 @@ function isSelectDisabled(uidt: string, disableSelect = false) { Add Number Column - +
@@ -807,7 +807,7 @@ function isSelectDisabled(uidt: string, disableSelect = false) { Add SingleLineText Column - +
@@ -820,7 +820,7 @@ function isSelectDisabled(uidt: string, disableSelect = false) { Add LongText Column - +
@@ -833,7 +833,7 @@ function isSelectDisabled(uidt: string, disableSelect = false) { Add Other Column - +
From 0e2fcd5f3a0487731e2ba8952d38c6db32d1fca0 Mon Sep 17 00:00:00 2001 From: Wing-Kam Wong Date: Mon, 17 Oct 2022 11:51:31 +0800 Subject: [PATCH 008/194] fix(nc-gui): incorrect focus when adding a new column during import useTemplateRefsList will not reset the existing refs. It appends new refs everytime a new column is added. --- packages/nc-gui/components/template/Editor.vue | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/packages/nc-gui/components/template/Editor.vue b/packages/nc-gui/components/template/Editor.vue index f6c403fb49..dbf6dabfed 100644 --- a/packages/nc-gui/components/template/Editor.vue +++ b/packages/nc-gui/components/template/Editor.vue @@ -25,7 +25,6 @@ import { useNuxtApp, useProject, useTabs, - useTemplateRefsList, } from '#imports' import { TabType } from '~/lib' @@ -71,7 +70,7 @@ const expansionPanel = ref([]) const editableTn = ref([]) -const inputRefs = useTemplateRefsList() +const inputRefs = ref([]) const isImporting = ref(false) @@ -208,14 +207,13 @@ function deleteTableColumn(tableIdx: number, columnIdx: number) { function addNewColumnRow(tableIdx: number, uidt: string) { data.tables[tableIdx].columns.push({ - key: data.tables[tableIdx].columns.length + 1, + key: data.tables[tableIdx].columns.length, column_name: `title${data.tables[tableIdx].columns.length + 1}`, uidt, }) nextTick(() => { const input = inputRefs.value[data.tables[tableIdx].columns.length - 1] - input.focus() input.select() }) @@ -723,7 +721,14 @@ function isSelectDisabled(uidt: string, disableSelect = false) { diff --git a/packages/nc-gui/composables/useExpandedFormDetached/index.ts b/packages/nc-gui/composables/useExpandedFormDetached/index.ts index c2bda1c78d..2aef11da08 100644 --- a/packages/nc-gui/composables/useExpandedFormDetached/index.ts +++ b/packages/nc-gui/composables/useExpandedFormDetached/index.ts @@ -1,5 +1,5 @@ import type { TableType, ViewType } from 'nocodb-sdk' -import { ref, useInjectionState } from '#imports' +import { createEventHook, ref, useInjectionState } from '#imports' import type { Row } from '~/lib' interface UseExpandedFormDetachedProps { @@ -26,6 +26,8 @@ export function useExpandedFormDetached() { states = setup() } + const closeHook = createEventHook() + const index = ref(-1) const open = (props: UseExpandedFormDetachedProps) => { @@ -33,9 +35,10 @@ export function useExpandedFormDetached() { index.value = states.value.length - 1 } - const close = () => { - states.value.splice(index.value, 1) + const close = (i?: number) => { + states.value.splice(i || index.value, 1) + if (index.value === i || !i) closeHook.trigger() } - return { states, open, close } + return { states, open, close, onClose: closeHook.on } } From 952a32c327e902576c28cf3209bedbf91d6035d0 Mon Sep 17 00:00:00 2001 From: Wing-Kam Wong Date: Fri, 21 Oct 2022 11:59:39 +0800 Subject: [PATCH 065/194] feat(nc-gui): skip empty lines when parsing --- packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts b/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts index 723583f05e..fc42bc2b4c 100644 --- a/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts +++ b/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts @@ -205,6 +205,7 @@ export default class CSVTemplateAdapter { let steppers = 0 const tn = file.name.replace(/[` ~!@#$%^&*()_|+\-=?;:'",.<>\{\}\[\]\\\/]/g, '_').trim() parse(file.originFileObj as File, { + worker: true, skipEmptyLines: 'greedy', step(row) { steppers += 1 @@ -256,6 +257,7 @@ export default class CSVTemplateAdapter { if (this.config.importData) { parse(file.originFileObj as File, { worker: true, + skipEmptyLines: 'greedy', step(row) { steppers += 1 if (row && steppers >= +that.config.firstRowAsHeaders + 1) { From 5e412f15a5cc498b14a0808a926b23d3dffbe6c1 Mon Sep 17 00:00:00 2001 From: Wing-Kam Wong Date: Fri, 21 Oct 2022 13:54:57 +0800 Subject: [PATCH 066/194] feat(nc-gui): validate each table after pre-import --- .../nc-gui/components/template/Editor.vue | 97 +++++++++---------- 1 file changed, 47 insertions(+), 50 deletions(-) diff --git a/packages/nc-gui/components/template/Editor.vue b/packages/nc-gui/components/template/Editor.vue index f59b758dd6..3b5dafcb54 100644 --- a/packages/nc-gui/components/template/Editor.vue +++ b/packages/nc-gui/components/template/Editor.vue @@ -290,8 +290,6 @@ function fieldsValidation(record: Record) { return true } - const tableName = meta.value?.title || '' - if (!record.destCn) { message.error(`${t('msg.error.columnDescriptionNotFound')} ${record.srcCn}`) return false @@ -304,63 +302,62 @@ function fieldsValidation(record: Record) { const v = columns.value.find((c) => c.title === record.destCn) as Record - // check if the input contains null value for a required column - if (v.pk ? !v.ai && !v.cdf : !v.cdf && v.rqd) { - if ( - importData[tableName] - .slice(0, maxRowsToParse) - .some((r: Record) => r[record.srcCn] === null || r[record.srcCn] === undefined || r[record.srcCn] === '') - ) { - message.error(t('msg.error.nullValueViolatesNotNull')) - } - } - - switch (v.uidt) { - case UITypes.Number: + for (const tableName of Object.keys(importData)) { + // check if the input contains null value for a required column + if (v.pk ? !v.ai && !v.cdf : !v.cdf && v.rqd) { if ( importData[tableName] .slice(0, maxRowsToParse) - .some( - (r: Record) => r[record.sourceCn] !== null && r[record.srcCn] !== undefined && isNaN(+r[record.srcCn]), - ) + .some((r: Record) => r[record.srcCn] === null || r[record.srcCn] === undefined || r[record.srcCn] === '') ) { - message.error(t('msg.error.sourceHasInvalidNumbers')) - return false + message.error(t('msg.error.nullValueViolatesNotNull')) } + } - break - case UITypes.Checkbox: - if ( - importData[tableName].slice(0, maxRowsToParse).some((r: Record) => { - if (r[record.srcCn] !== null && r[record.srcCn] !== undefined) { - let input = r[record.srcCn] - if (typeof input === 'string') { - input = input.replace(/["']/g, '').toLowerCase().trim() - return !( - input === 'false' || - input === 'no' || - input === 'n' || - input === '0' || - input === 'true' || - input === 'yes' || - input === 'y' || - input === '1' - ) - } + switch (v.uidt) { + case UITypes.Number: + if ( + importData[tableName] + .slice(0, maxRowsToParse) + .some( + (r: Record) => r[record.sourceCn] !== null && r[record.srcCn] !== undefined && isNaN(+r[record.srcCn]), + ) + ) { + message.error(t('msg.error.sourceHasInvalidNumbers')) + return false + } - return input !== 1 && input !== 0 && input !== true && input !== false - } + break + case UITypes.Checkbox: + if ( + importData[tableName].slice(0, maxRowsToParse).some((r: Record) => { + if (r[record.srcCn] !== null && r[record.srcCn] !== undefined) { + let input = r[record.srcCn] + if (typeof input === 'string') { + input = input.replace(/["']/g, '').toLowerCase().trim() + return !( + input === 'false' || + input === 'no' || + input === 'n' || + input === '0' || + input === 'true' || + input === 'yes' || + input === 'y' || + input === '1' + ) + } + return input !== 1 && input !== 0 && input !== true && input !== false + } + return false + }) + ) { + message.error(t('msg.error.sourceHasInvalidBoolean')) return false - }) - ) { - message.error(t('msg.error.sourceHasInvalidBoolean')) - - return false - } - break + } + break + } } - return true } @@ -541,7 +538,7 @@ function mapDefaultColumns() { for (const col of importColumns[0]) { const o = { srcCn: col.column_name, destCn: '', enabled: true } if (columns.value) { - const tableColumn = columns.value.find((c: Record) => c.title === col.column_name) + const tableColumn = columns.value.find((c) => c.column_name === col.column_name) if (tableColumn) { o.destCn = tableColumn.title as string } else { From c513997014ee07beecde7ac21eb55bfacb7a3839 Mon Sep 17 00:00:00 2001 From: Wing-Kam Wong Date: Fri, 21 Oct 2022 13:55:47 +0800 Subject: [PATCH 067/194] fix(nc-gui): import to existing table issue --- .../nc-gui/components/dlg/QuickImport.vue | 5 +- .../utils/parsers/CSVTemplateAdapter.ts | 80 ++++++++++--------- 2 files changed, 44 insertions(+), 41 deletions(-) diff --git a/packages/nc-gui/components/dlg/QuickImport.vue b/packages/nc-gui/components/dlg/QuickImport.vue index 624d4e5342..b1d5ed31e4 100644 --- a/packages/nc-gui/components/dlg/QuickImport.vue +++ b/packages/nc-gui/components/dlg/QuickImport.vue @@ -169,9 +169,7 @@ async function handleImport() { message.error(t('msg.error.templateGeneratorNotFound')) return } - importLoading.value = true - importData.value = templateGenerator.getData() await templateEditorRef.value.importTemplate() } catch (e: any) { return message.error(await extractSdkResponseErrorMsg(e)) @@ -200,7 +198,8 @@ async function parseAndExtractStreamData(val: UploadFile[]) { templateData.value = templateGenerator!.getTemplate() // TODO(import): remove // templateData.value.tables[0].table_name = populateUniqueTableName() - // if (importOnly) importColumns.value = templateGenerator.getColumns() + if (importOnly) importColumns.value = templateGenerator!.getColumns() + importData.value = templateGenerator!.getData() templateEditorModal.value = true isParsingData.value = false preImportLoading.value = false diff --git a/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts b/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts index fc42bc2b4c..c2756e7b25 100644 --- a/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts +++ b/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts @@ -204,6 +204,9 @@ export default class CSVTemplateAdapter { for (const [tableIdx, file] of this.files.entries()) { let steppers = 0 const tn = file.name.replace(/[` ~!@#$%^&*()_|+\-=?;:'",.<>\{\}\[\]\\\/]/g, '_').trim() + this.data[tn] = [] + + // parse column meta parse(file.originFileObj as File, { worker: true, skipEmptyLines: 'greedy', @@ -238,53 +241,54 @@ export default class CSVTemplateAdapter { console.log('complete') console.log(`steppers: ${steppers}`) that.updateTemplate(tableIdx) - callback() + + // parse table data + if (that.config.importData) { + steppers = 0 + parse(file.originFileObj as File, { + worker: true, + skipEmptyLines: 'greedy', + step(row) { + steppers += 1 + if (row && steppers >= +that.config.firstRowAsHeaders + 1) { + const rowData: Record = {} + for (let columnIdx = 0; columnIdx < that.headers[tableIdx].length; columnIdx++) { + const column = that.project.tables[tableIdx].columns[columnIdx] + const data = (row.data as [])[columnIdx] === '' ? null : (row.data as [])[columnIdx] + if (column.uidt === UITypes.Checkbox) { + rowData[column.column_name] = getCheckboxValue(data) + rowData[column.column_name] = data + } else if (column.uidt === UITypes.SingleSelect || column.uidt === UITypes.MultiSelect) { + rowData[column.column_name] = (data || '').toString().trim() || null + } else { + // TODO(import): do parsing if necessary based on type + rowData[column.column_name] = data + } + } + that.data[tn].push(rowData) + } + }, + complete() { + console.log('getData(): complete') + console.log(`getData(): steppers: ${steppers}`) + callback() + }, + // TODO(import): add error + }) + } else { + callback() + } }, }) } } getColumns() { - // return this.columns + console.log(this.project.tables.map((t: Record) => t.columns)) + return this.project.tables.map((t: Record) => t.columns) } getData() { - const that = this - for (const [tableIdx, file] of this.files.entries()) { - let steppers = 0 - const tn = file.name.replace(/[` ~!@#$%^&*()_|+\-=?;:'",.<>\{\}\[\]\\\/]/g, '_').trim() - this.data[tn] = [] - if (this.config.importData) { - parse(file.originFileObj as File, { - worker: true, - skipEmptyLines: 'greedy', - step(row) { - steppers += 1 - if (row && steppers >= +that.config.firstRowAsHeaders + 1) { - const rowData: Record = {} - for (let columnIdx = 0; columnIdx < that.headers[tableIdx].length; columnIdx++) { - const column = that.project.tables[tableIdx].columns[columnIdx] - const data = (row.data as [])[columnIdx] === '' ? null : (row.data as [])[columnIdx] - if (column.uidt === UITypes.Checkbox) { - rowData[column.column_name] = getCheckboxValue(data) - rowData[column.column_name] = data - } else if (column.uidt === UITypes.SingleSelect || column.uidt === UITypes.MultiSelect) { - rowData[column.column_name] = (data || '').toString().trim() || null - } else { - // TODO(import): do parsing if necessary based on type - rowData[column.column_name] = data - } - } - that.data[tn].push(rowData) - } - }, - complete() { - console.log('getData(): complete') - console.log(`getData(): steppers: ${steppers}`) - }, - }) - } - } return this.data } From 2e3f843ee9a90286607faf50e3a9fa8423819dba Mon Sep 17 00:00:00 2001 From: Wing-Kam Wong Date: Fri, 21 Oct 2022 13:58:46 +0800 Subject: [PATCH 068/194] chore(nc-gui): remove console log --- packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts b/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts index c2756e7b25..70e85eab80 100644 --- a/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts +++ b/packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts @@ -284,7 +284,6 @@ export default class CSVTemplateAdapter { } getColumns() { - console.log(this.project.tables.map((t: Record) => t.columns)) return this.project.tables.map((t: Record) => t.columns) } From 7f9f60b1c542aabbd720d40f51ae44d17e83b35d Mon Sep 17 00:00:00 2001 From: Wing-Kam Wong Date: Fri, 21 Oct 2022 13:59:02 +0800 Subject: [PATCH 069/194] refactor(nc-gui): merge parseAndExtractStreamData to parseAndExtractData --- .../nc-gui/components/dlg/QuickImport.vue | 37 +++---------------- 1 file changed, 5 insertions(+), 32 deletions(-) diff --git a/packages/nc-gui/components/dlg/QuickImport.vue b/packages/nc-gui/components/dlg/QuickImport.vue index b1d5ed31e4..2b0b869c4e 100644 --- a/packages/nc-gui/components/dlg/QuickImport.vue +++ b/packages/nc-gui/components/dlg/QuickImport.vue @@ -147,7 +147,7 @@ async function handlePreImport() { if (activeKey.value === 'uploadTab') { if (isImportTypeCsv.value) { - await parseAndExtractStreamData(importState.fileList as streamImportFileList) + await parseAndExtractData(importState.fileList as streamImportFileList) } else { await parseAndExtractData((importState.fileList as importFileList)[0].data) } @@ -179,37 +179,10 @@ async function handleImport() { dialogShow.value = false } -async function parseAndExtractStreamData(val: UploadFile[]) { - try { - templateData.value = null - importData.value = null - importColumns.value = [] - - templateGenerator = getAdapter(val) - - if (!templateGenerator) { - message.error(t('msg.error.templateGeneratorNotFound')) - return - } - - await templateGenerator.init() - - templateGenerator.parse(() => { - templateData.value = templateGenerator!.getTemplate() - // TODO(import): remove - // templateData.value.tables[0].table_name = populateUniqueTableName() - if (importOnly) importColumns.value = templateGenerator!.getColumns() - importData.value = templateGenerator!.getData() - templateEditorModal.value = true - isParsingData.value = false - preImportLoading.value = false - }) - } catch (e: any) { - message.error(await extractSdkResponseErrorMsg(e)) - } -} - -async function parseAndExtractData(val: string | ArrayBuffer) { +// UploadFile[] for csv import (streaming) +// ArrayBuffer for excel import +// string for json import +async function parseAndExtractData(val: UploadFile[] | ArrayBuffer | string) { try { templateData.value = null importData.value = null From 1a29bd016640ff12f4ddae932cf18b6dac969ad3 Mon Sep 17 00:00:00 2001 From: Wing-Kam Wong Date: Fri, 21 Oct 2022 15:56:40 +0800 Subject: [PATCH 070/194] refactor(nc-gui): rename variables & props --- packages/nc-gui/components/dlg/QuickImport.vue | 12 ++++++------ .../components/smartsheet/toolbar/MoreActions.vue | 2 +- .../components/smartsheet/toolbar/ViewActions.vue | 2 +- packages/nc-gui/components/template/Editor.vue | 12 ++++++------ packages/nc-gui/utils/parsers/CSVTemplateAdapter.ts | 2 +- .../nc-gui/utils/parsers/ExcelTemplateAdapter.ts | 2 +- packages/nc-gui/utils/parsers/JSONTemplateAdapter.ts | 2 +- 7 files changed, 17 insertions(+), 17 deletions(-) diff --git a/packages/nc-gui/components/dlg/QuickImport.vue b/packages/nc-gui/components/dlg/QuickImport.vue index 2b0b869c4e..f18ed5df6a 100644 --- a/packages/nc-gui/components/dlg/QuickImport.vue +++ b/packages/nc-gui/components/dlg/QuickImport.vue @@ -27,10 +27,10 @@ import type { importFileList, streamImportFileList } from '~/lib' interface Props { modelValue: boolean importType: 'csv' | 'json' | 'excel' - importOnly?: boolean + importDataOnly?: boolean } -const { importType, importOnly = false, ...rest } = defineProps() +const { importType, importDataOnly = false, ...rest } = defineProps() const emit = defineEmits(['update:modelValue']) @@ -69,7 +69,7 @@ const importState = reactive({ normalizeNested: true, autoSelectFieldTypes: true, firstRowAsHeaders: true, - importData: true, + shouldImportData: true, }, }) @@ -199,7 +199,7 @@ async function parseAndExtractData(val: UploadFile[] | ArrayBuffer | string) { templateGenerator.parse(() => { templateData.value = templateGenerator!.getTemplate() - if (importOnly) importColumns.value = templateGenerator!.getColumns() + if (importDataOnly) importColumns.value = templateGenerator!.getColumns() importData.value = templateGenerator!.getData() templateEditorModal.value = true isParsingData.value = false @@ -342,7 +342,7 @@ const beforeUpload = (file: UploadFile) => { :project-template="templateData" :import-data="importData" :import-columns="importColumns" - :import-only="importOnly" + :import-data-only="importDataOnly" :quick-import-type="importType" :max-rows-to-parse="importState.parserConfig.maxRowsToParse" class="nc-quick-import-template-editor" @@ -448,7 +448,7 @@ const beforeUpload = (file: UploadFile) => { - {{ $t('labels.importData') }} + {{ $t('labels.importData') }} diff --git a/packages/nc-gui/components/smartsheet/toolbar/MoreActions.vue b/packages/nc-gui/components/smartsheet/toolbar/MoreActions.vue index 6ef6335d71..8a6e9eb7c0 100644 --- a/packages/nc-gui/components/smartsheet/toolbar/MoreActions.vue +++ b/packages/nc-gui/components/smartsheet/toolbar/MoreActions.vue @@ -166,7 +166,7 @@ const exportFile = async (exportType: ExportTypes) => { - + diff --git a/packages/nc-gui/components/smartsheet/toolbar/ViewActions.vue b/packages/nc-gui/components/smartsheet/toolbar/ViewActions.vue index c926a5c3d7..daa2c857f3 100644 --- a/packages/nc-gui/components/smartsheet/toolbar/ViewActions.vue +++ b/packages/nc-gui/components/smartsheet/toolbar/ViewActions.vue @@ -228,7 +228,7 @@ const { isSqlView } = useSmartsheetStoreOrThrow() - + diff --git a/packages/nc-gui/components/template/Editor.vue b/packages/nc-gui/components/template/Editor.vue index 3b5dafcb54..de802d00c2 100644 --- a/packages/nc-gui/components/template/Editor.vue +++ b/packages/nc-gui/components/template/Editor.vue @@ -28,7 +28,7 @@ import { } from '#imports' import { TabType } from '~/lib' -const { quickImportType, projectTemplate, importData, importColumns, importOnly, maxRowsToParse } = defineProps() +const { quickImportType, projectTemplate, importData, importColumns, importDataOnly, maxRowsToParse } = defineProps() const emit = defineEmits(['import']) @@ -41,7 +41,7 @@ interface Props { projectTemplate: Record importData: Record importColumns: any[] - importOnly: boolean + importDataOnly: boolean maxRowsToParse: number } @@ -123,7 +123,7 @@ const validators = computed(() => const { validate, validateInfos } = useForm(data, validators) const isValid = computed(() => { - if (importOnly) { + if (importDataOnly) { for (const record of srcDestMapping.value) { if (!fieldsValidation(record)) { return false @@ -362,7 +362,7 @@ function fieldsValidation(record: Record) { } async function importTemplate() { - if (importOnly) { + if (importDataOnly) { // validate required columns if (!missingRequiredColumnsValidation()) return @@ -555,7 +555,7 @@ defineExpose({ }) onMounted(() => { - if (importOnly) { + if (importDataOnly) { mapDefaultColumns() } }) @@ -579,7 +579,7 @@ function isSelectDisabled(uidt: string, disableSelect = false) {