mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
chore: replace cell content when import from csv (#6073)
This commit is contained in:
parent
b649950d62
commit
12cb9bde39
14
frontend/appflowy_tauri/src-tauri/Cargo.lock
generated
14
frontend/appflowy_tauri/src-tauri/Cargo.lock
generated
@ -964,7 +964,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab"
|
name = "collab"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -989,7 +989,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-database"
|
name = "collab-database"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-trait",
|
"async-trait",
|
||||||
@ -1018,7 +1018,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-document"
|
name = "collab-document"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -1038,7 +1038,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-entity"
|
name = "collab-entity"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"bytes",
|
"bytes",
|
||||||
@ -1057,7 +1057,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-folder"
|
name = "collab-folder"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -1100,7 +1100,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-plugins"
|
name = "collab-plugins"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-stream",
|
"async-stream",
|
||||||
@ -1180,7 +1180,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-user"
|
name = "collab-user"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"collab",
|
"collab",
|
||||||
|
@ -116,13 +116,13 @@ custom-protocol = ["tauri/custom-protocol"]
|
|||||||
# To switch to the local path, run:
|
# To switch to the local path, run:
|
||||||
# scripts/tool/update_collab_source.sh
|
# scripts/tool/update_collab_source.sh
|
||||||
# ⚠️⚠️⚠️️
|
# ⚠️⚠️⚠️️
|
||||||
collab = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-entity = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-entity = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-folder = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-folder = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-document = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-document = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-database = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-database = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-plugins = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-plugins = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-user = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-user = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
|
|
||||||
# Working directory: frontend
|
# Working directory: frontend
|
||||||
# To update the commit ID, run:
|
# To update the commit ID, run:
|
||||||
|
14
frontend/appflowy_web_app/src-tauri/Cargo.lock
generated
14
frontend/appflowy_web_app/src-tauri/Cargo.lock
generated
@ -947,7 +947,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab"
|
name = "collab"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -972,7 +972,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-database"
|
name = "collab-database"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-trait",
|
"async-trait",
|
||||||
@ -1001,7 +1001,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-document"
|
name = "collab-document"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -1021,7 +1021,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-entity"
|
name = "collab-entity"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"bytes",
|
"bytes",
|
||||||
@ -1040,7 +1040,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-folder"
|
name = "collab-folder"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -1083,7 +1083,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-plugins"
|
name = "collab-plugins"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-stream",
|
"async-stream",
|
||||||
@ -1163,7 +1163,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-user"
|
name = "collab-user"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"collab",
|
"collab",
|
||||||
|
@ -116,13 +116,13 @@ custom-protocol = ["tauri/custom-protocol"]
|
|||||||
# To switch to the local path, run:
|
# To switch to the local path, run:
|
||||||
# scripts/tool/update_collab_source.sh
|
# scripts/tool/update_collab_source.sh
|
||||||
# ⚠️⚠️⚠️️
|
# ⚠️⚠️⚠️️
|
||||||
collab = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-entity = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-entity = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-folder = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-folder = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-document = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-document = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-database = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-database = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-plugins = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-plugins = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-user = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-user = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
|
|
||||||
# Working directory: frontend
|
# Working directory: frontend
|
||||||
# To update the commit ID, run:
|
# To update the commit ID, run:
|
||||||
|
14
frontend/rust-lib/Cargo.lock
generated
14
frontend/rust-lib/Cargo.lock
generated
@ -825,7 +825,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab"
|
name = "collab"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -850,7 +850,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-database"
|
name = "collab-database"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-trait",
|
"async-trait",
|
||||||
@ -879,7 +879,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-document"
|
name = "collab-document"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -899,7 +899,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-entity"
|
name = "collab-entity"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"bytes",
|
"bytes",
|
||||||
@ -918,7 +918,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-folder"
|
name = "collab-folder"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"arc-swap",
|
"arc-swap",
|
||||||
@ -961,7 +961,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-plugins"
|
name = "collab-plugins"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-stream",
|
"async-stream",
|
||||||
@ -1041,7 +1041,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "collab-user"
|
name = "collab-user"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d#0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Collab?rev=f747496df74b61bccfa25eaefae161a331f71f96#f747496df74b61bccfa25eaefae161a331f71f96"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"collab",
|
"collab",
|
||||||
|
@ -136,13 +136,13 @@ rocksdb = { git = "https://github.com/rust-rocksdb/rust-rocksdb", rev = "1710120
|
|||||||
# To switch to the local path, run:
|
# To switch to the local path, run:
|
||||||
# scripts/tool/update_collab_source.sh
|
# scripts/tool/update_collab_source.sh
|
||||||
# ⚠️⚠️⚠️️
|
# ⚠️⚠️⚠️️
|
||||||
collab = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-entity = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-entity = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-folder = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-folder = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-document = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-document = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-database = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-database = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-plugins = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-plugins = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
collab-user = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "0b9abf42a4888b3b1789cfa68d2d1dbe9cb7e10d" }
|
collab-user = { version = "0.2", git = "https://github.com/AppFlowy-IO/AppFlowy-Collab", rev = "f747496df74b61bccfa25eaefae161a331f71f96" }
|
||||||
|
|
||||||
# Working directory: frontend
|
# Working directory: frontend
|
||||||
# To update the commit ID, run:
|
# To update the commit ID, run:
|
||||||
|
@ -464,7 +464,7 @@ impl DatabaseEditor {
|
|||||||
new_field_type,
|
new_field_type,
|
||||||
old_type_option_data,
|
old_type_option_data,
|
||||||
new_type_option_data,
|
new_type_option_data,
|
||||||
&database,
|
&mut database,
|
||||||
)
|
)
|
||||||
.await;
|
.await;
|
||||||
|
|
||||||
@ -1362,6 +1362,21 @@ impl DatabaseEditor {
|
|||||||
let opening_database_views = self.database_views.clone();
|
let opening_database_views = self.database_views.clone();
|
||||||
tokio::spawn(async move {
|
tokio::spawn(async move {
|
||||||
const CHUNK_SIZE: usize = 10;
|
const CHUNK_SIZE: usize = 10;
|
||||||
|
let apply_filter_and_sort =
|
||||||
|
|mut loaded_rows, opening_database_views: Arc<DatabaseViews>| async move {
|
||||||
|
for database_view in opening_database_views.editors().await {
|
||||||
|
if database_view.has_filters().await {
|
||||||
|
database_view
|
||||||
|
.v_filter_rows_and_notify(&mut loaded_rows)
|
||||||
|
.await;
|
||||||
|
}
|
||||||
|
|
||||||
|
if database_view.has_sorts().await {
|
||||||
|
database_view.v_sort_rows_and_notify(&mut loaded_rows).await;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
let mut loaded_rows = vec![];
|
let mut loaded_rows = vec![];
|
||||||
for chunk_row_orders in cloned_row_orders.chunks(CHUNK_SIZE) {
|
for chunk_row_orders in cloned_row_orders.chunks(CHUNK_SIZE) {
|
||||||
match cloned_database.upgrade() {
|
match cloned_database.upgrade() {
|
||||||
@ -1382,23 +1397,15 @@ impl DatabaseEditor {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if loaded_rows.len() % 100 == 0 {
|
if loaded_rows.len() % 1000 == 0 {
|
||||||
for database_view in opening_database_views.editors().await {
|
apply_filter_and_sort(loaded_rows.clone(), opening_database_views.clone()).await;
|
||||||
let mut view_rows = loaded_rows.clone();
|
|
||||||
database_view.v_filter_rows_and_notify(&mut view_rows).await;
|
|
||||||
database_view.v_sort_rows_and_notify(&mut view_rows).await;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
tokio::task::yield_now().await;
|
tokio::task::yield_now().await;
|
||||||
}
|
}
|
||||||
|
|
||||||
for database_view in opening_database_views.editors().await {
|
apply_filter_and_sort(loaded_rows.clone(), opening_database_views).await;
|
||||||
let mut view_rows = loaded_rows.clone();
|
|
||||||
database_view.v_filter_rows_and_notify(&mut view_rows).await;
|
|
||||||
database_view.v_sort_rows_and_notify(&mut view_rows).await;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Collect database details in a single block holding the `read` lock
|
// Collect database details in a single block holding the `read` lock
|
||||||
|
@ -124,6 +124,14 @@ impl DatabaseViewEditor {
|
|||||||
self.calculations_controller.close().await;
|
self.calculations_controller.close().await;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub async fn has_filters(&self) -> bool {
|
||||||
|
self.filter_controller.has_filters().await
|
||||||
|
}
|
||||||
|
|
||||||
|
pub async fn has_sorts(&self) -> bool {
|
||||||
|
self.sort_controller.read().await.has_sorts().await
|
||||||
|
}
|
||||||
|
|
||||||
pub async fn v_get_view(&self) -> Option<DatabaseView> {
|
pub async fn v_get_view(&self) -> Option<DatabaseView> {
|
||||||
self.delegate.get_view(&self.view_id).await
|
self.delegate.get_view(&self.view_id).await
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@ pub async fn transform_type_option(
|
|||||||
new_field_type: FieldType,
|
new_field_type: FieldType,
|
||||||
old_type_option_data: Option<TypeOptionData>,
|
old_type_option_data: Option<TypeOptionData>,
|
||||||
new_type_option_data: TypeOptionData,
|
new_type_option_data: TypeOptionData,
|
||||||
database: &Database,
|
database: &mut Database,
|
||||||
) -> TypeOptionData {
|
) -> TypeOptionData {
|
||||||
if let Some(old_type_option_data) = old_type_option_data {
|
if let Some(old_type_option_data) = old_type_option_data {
|
||||||
let mut transform_handler =
|
let mut transform_handler =
|
||||||
@ -28,6 +28,7 @@ pub async fn transform_type_option(
|
|||||||
field_id,
|
field_id,
|
||||||
old_field_type,
|
old_field_type,
|
||||||
old_type_option_data,
|
old_type_option_data,
|
||||||
|
new_field_type,
|
||||||
database,
|
database,
|
||||||
)
|
)
|
||||||
.await;
|
.await;
|
||||||
@ -46,7 +47,8 @@ pub trait TypeOptionTransformHandler: Send + Sync {
|
|||||||
field_id: &str,
|
field_id: &str,
|
||||||
old_type_option_field_type: FieldType,
|
old_type_option_field_type: FieldType,
|
||||||
old_type_option_data: TypeOptionData,
|
old_type_option_data: TypeOptionData,
|
||||||
database: &Database,
|
new_type_option_field_type: FieldType,
|
||||||
|
database: &mut Database,
|
||||||
);
|
);
|
||||||
|
|
||||||
fn to_type_option_data(&self) -> TypeOptionData;
|
fn to_type_option_data(&self) -> TypeOptionData;
|
||||||
@ -63,7 +65,8 @@ where
|
|||||||
field_id: &str,
|
field_id: &str,
|
||||||
old_type_option_field_type: FieldType,
|
old_type_option_field_type: FieldType,
|
||||||
old_type_option_data: TypeOptionData,
|
old_type_option_data: TypeOptionData,
|
||||||
database: &Database,
|
new_type_option_field_type: FieldType,
|
||||||
|
database: &mut Database,
|
||||||
) {
|
) {
|
||||||
self
|
self
|
||||||
.transform_type_option(
|
.transform_type_option(
|
||||||
@ -71,6 +74,7 @@ where
|
|||||||
field_id,
|
field_id,
|
||||||
old_type_option_field_type,
|
old_type_option_field_type,
|
||||||
old_type_option_data,
|
old_type_option_data,
|
||||||
|
new_type_option_field_type,
|
||||||
database,
|
database,
|
||||||
)
|
)
|
||||||
.await
|
.await
|
||||||
|
@ -1,16 +1,17 @@
|
|||||||
use std::cmp::Ordering;
|
use async_trait::async_trait;
|
||||||
use std::str::FromStr;
|
|
||||||
|
|
||||||
use chrono::{DateTime, FixedOffset, Local, NaiveDateTime, NaiveTime, Offset, TimeZone};
|
use chrono::{DateTime, FixedOffset, Local, NaiveDateTime, NaiveTime, Offset, TimeZone};
|
||||||
use chrono_tz::Tz;
|
use chrono_tz::Tz;
|
||||||
use collab::preclude::Any;
|
use collab::preclude::Any;
|
||||||
use collab::util::AnyMapExt;
|
use collab::util::AnyMapExt;
|
||||||
|
use collab_database::database::Database;
|
||||||
use collab_database::fields::{Field, TypeOptionData, TypeOptionDataBuilder};
|
use collab_database::fields::{Field, TypeOptionData, TypeOptionDataBuilder};
|
||||||
use collab_database::rows::Cell;
|
use collab_database::rows::Cell;
|
||||||
use collab_database::template::date_parse::cast_string_to_timestamp;
|
use collab_database::template::date_parse::cast_string_to_timestamp;
|
||||||
use serde::{Deserialize, Serialize};
|
|
||||||
|
|
||||||
use flowy_error::{ErrorCode, FlowyError, FlowyResult};
|
use flowy_error::{ErrorCode, FlowyError, FlowyResult};
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
use std::cmp::Ordering;
|
||||||
|
use std::str::FromStr;
|
||||||
|
use tracing::info;
|
||||||
|
|
||||||
use crate::entities::{DateCellDataPB, DateFilterPB, FieldType};
|
use crate::entities::{DateCellDataPB, DateFilterPB, FieldType};
|
||||||
use crate::services::cell::{CellDataChangeset, CellDataDecoder};
|
use crate::services::cell::{CellDataChangeset, CellDataDecoder};
|
||||||
@ -198,7 +199,52 @@ impl DateTypeOption {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TypeOptionTransform for DateTypeOption {}
|
#[async_trait]
|
||||||
|
impl TypeOptionTransform for DateTypeOption {
|
||||||
|
async fn transform_type_option(
|
||||||
|
&mut self,
|
||||||
|
view_id: &str,
|
||||||
|
field_id: &str,
|
||||||
|
old_type_option_field_type: FieldType,
|
||||||
|
_old_type_option_data: TypeOptionData,
|
||||||
|
_new_type_option_field_type: FieldType,
|
||||||
|
database: &mut Database,
|
||||||
|
) {
|
||||||
|
match old_type_option_field_type {
|
||||||
|
FieldType::RichText => {
|
||||||
|
let rows = database
|
||||||
|
.get_cells_for_field(view_id, field_id)
|
||||||
|
.await
|
||||||
|
.into_iter()
|
||||||
|
.filter_map(|row| row.cell.map(|cell| (row.row_id, cell)))
|
||||||
|
.collect::<Vec<_>>();
|
||||||
|
|
||||||
|
info!(
|
||||||
|
"Transforming RichText to DateTypeOption, updating {} row's cell content",
|
||||||
|
rows.len()
|
||||||
|
);
|
||||||
|
for (row_id, cell_data) in rows {
|
||||||
|
if let Some(cell_data) = cell_data
|
||||||
|
.get_as::<String>(CELL_DATA)
|
||||||
|
.and_then(|s| cast_string_to_timestamp(&s))
|
||||||
|
.map(DateCellData::from_timestamp)
|
||||||
|
{
|
||||||
|
database
|
||||||
|
.update_row(row_id, |row| {
|
||||||
|
row.update_cells(|cell| {
|
||||||
|
cell.insert(field_id, Cell::from(&cell_data));
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.await;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_ => {
|
||||||
|
// do nothing
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl CellDataDecoder for DateTypeOption {
|
impl CellDataDecoder for DateTypeOption {
|
||||||
fn decode_cell(&self, cell: &Cell) -> FlowyResult<<Self as TypeOption>::CellData> {
|
fn decode_cell(&self, cell: &Cell) -> FlowyResult<<Self as TypeOption>::CellData> {
|
||||||
|
@ -1,18 +1,19 @@
|
|||||||
|
use async_trait::async_trait;
|
||||||
use collab::preclude::encoding::serde::from_any;
|
use collab::preclude::encoding::serde::from_any;
|
||||||
use collab::preclude::Any;
|
use collab::preclude::Any;
|
||||||
use collab::util::AnyMapExt;
|
use collab::util::AnyMapExt;
|
||||||
use std::cmp::Ordering;
|
use collab_database::database::Database;
|
||||||
use std::default::Default;
|
|
||||||
use std::str::FromStr;
|
|
||||||
|
|
||||||
use collab_database::fields::{Field, TypeOptionData, TypeOptionDataBuilder};
|
use collab_database::fields::{Field, TypeOptionData, TypeOptionDataBuilder};
|
||||||
use collab_database::rows::{new_cell_builder, Cell};
|
use collab_database::rows::{new_cell_builder, Cell};
|
||||||
use fancy_regex::Regex;
|
use fancy_regex::Regex;
|
||||||
|
use flowy_error::FlowyResult;
|
||||||
use lazy_static::lazy_static;
|
use lazy_static::lazy_static;
|
||||||
use rust_decimal::Decimal;
|
use rust_decimal::Decimal;
|
||||||
use serde::{Deserialize, Deserializer, Serialize};
|
use serde::{Deserialize, Deserializer, Serialize};
|
||||||
|
use std::cmp::Ordering;
|
||||||
use flowy_error::FlowyResult;
|
use std::default::Default;
|
||||||
|
use std::str::FromStr;
|
||||||
|
use tracing::info;
|
||||||
|
|
||||||
use crate::entities::{FieldType, NumberFilterPB};
|
use crate::entities::{FieldType, NumberFilterPB};
|
||||||
use crate::services::cell::{CellDataChangeset, CellDataDecoder};
|
use crate::services::cell::{CellDataChangeset, CellDataDecoder};
|
||||||
@ -180,7 +181,51 @@ impl NumberTypeOption {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TypeOptionTransform for NumberTypeOption {}
|
#[async_trait]
|
||||||
|
impl TypeOptionTransform for NumberTypeOption {
|
||||||
|
async fn transform_type_option(
|
||||||
|
&mut self,
|
||||||
|
view_id: &str,
|
||||||
|
field_id: &str,
|
||||||
|
old_type_option_field_type: FieldType,
|
||||||
|
_old_type_option_data: TypeOptionData,
|
||||||
|
_new_type_option_field_type: FieldType,
|
||||||
|
database: &mut Database,
|
||||||
|
) {
|
||||||
|
match old_type_option_field_type {
|
||||||
|
FieldType::RichText => {
|
||||||
|
let rows = database
|
||||||
|
.get_cells_for_field(view_id, field_id)
|
||||||
|
.await
|
||||||
|
.into_iter()
|
||||||
|
.filter_map(|row| row.cell.map(|cell| (row.row_id, cell)))
|
||||||
|
.collect::<Vec<_>>();
|
||||||
|
|
||||||
|
info!(
|
||||||
|
"Transforming RichText to NumberTypeOption, updating {} row's cell content",
|
||||||
|
rows.len()
|
||||||
|
);
|
||||||
|
for (row_id, cell_data) in rows {
|
||||||
|
if let Ok(num_cell) = self
|
||||||
|
.parse_cell(&cell_data)
|
||||||
|
.and_then(|num_cell_data| self.format_cell_data(num_cell_data))
|
||||||
|
{
|
||||||
|
database
|
||||||
|
.update_row(row_id, |row| {
|
||||||
|
row.update_cells(|cell| {
|
||||||
|
cell.insert(field_id, NumberCellData::from(num_cell.to_string()));
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.await;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_ => {
|
||||||
|
// do nothing
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl CellDataDecoder for NumberTypeOption {
|
impl CellDataDecoder for NumberTypeOption {
|
||||||
fn decode_cell(&self, cell: &Cell) -> FlowyResult<<Self as TypeOption>::CellData> {
|
fn decode_cell(&self, cell: &Cell) -> FlowyResult<<Self as TypeOption>::CellData> {
|
||||||
|
@ -80,7 +80,8 @@ where
|
|||||||
field_id: &str,
|
field_id: &str,
|
||||||
old_type_option_field_type: FieldType,
|
old_type_option_field_type: FieldType,
|
||||||
old_type_option_data: TypeOptionData,
|
old_type_option_data: TypeOptionData,
|
||||||
database: &Database,
|
new_type_option_field_type: FieldType,
|
||||||
|
database: &mut Database,
|
||||||
) {
|
) {
|
||||||
SelectOptionTypeOptionTransformHelper::transform_type_option(
|
SelectOptionTypeOptionTransformHelper::transform_type_option(
|
||||||
self,
|
self,
|
||||||
@ -88,6 +89,7 @@ where
|
|||||||
field_id,
|
field_id,
|
||||||
&old_type_option_field_type,
|
&old_type_option_field_type,
|
||||||
old_type_option_data,
|
old_type_option_data,
|
||||||
|
new_type_option_field_type,
|
||||||
database,
|
database,
|
||||||
)
|
)
|
||||||
.await;
|
.await;
|
||||||
|
@ -8,6 +8,7 @@ use collab_database::database::Database;
|
|||||||
use collab_database::entity::{SelectOption, SelectOptionColor};
|
use collab_database::entity::{SelectOption, SelectOptionColor};
|
||||||
use collab_database::fields::TypeOptionData;
|
use collab_database::fields::TypeOptionData;
|
||||||
use collab_database::template::option_parse::build_options_from_cells;
|
use collab_database::template::option_parse::build_options_from_cells;
|
||||||
|
use tracing::info;
|
||||||
|
|
||||||
/// Handles how to transform the cell data when switching between different field types
|
/// Handles how to transform the cell data when switching between different field types
|
||||||
pub(crate) struct SelectOptionTypeOptionTransformHelper();
|
pub(crate) struct SelectOptionTypeOptionTransformHelper();
|
||||||
@ -24,7 +25,8 @@ impl SelectOptionTypeOptionTransformHelper {
|
|||||||
field_id: &str,
|
field_id: &str,
|
||||||
old_field_type: &FieldType,
|
old_field_type: &FieldType,
|
||||||
old_type_option_data: TypeOptionData,
|
old_type_option_data: TypeOptionData,
|
||||||
database: &Database,
|
new_field_type: FieldType,
|
||||||
|
database: &mut Database,
|
||||||
) where
|
) where
|
||||||
T: SelectTypeOptionSharedAction + TypeOption<CellData = SelectOptionIds>,
|
T: SelectTypeOptionSharedAction + TypeOption<CellData = SelectOptionIds>,
|
||||||
{
|
{
|
||||||
@ -34,19 +36,44 @@ impl SelectOptionTypeOptionTransformHelper {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let text_type_option = RichTextTypeOption::from(old_type_option_data);
|
let text_type_option = RichTextTypeOption::from(old_type_option_data);
|
||||||
let cells = database
|
let rows = database
|
||||||
.get_cells_for_field(view_id, field_id)
|
.get_cells_for_field(view_id, field_id)
|
||||||
.await
|
.await
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.filter_map(|e| e.cell)
|
.filter_map(|row| row.cell.map(|cell| (row.row_id, cell)))
|
||||||
.map(|cell| {
|
.map(|(row_id, cell)| {
|
||||||
text_type_option
|
let text = text_type_option
|
||||||
.decode_cell(&cell)
|
.decode_cell(&cell)
|
||||||
.unwrap_or_default()
|
.unwrap_or_default()
|
||||||
.into_inner()
|
.into_inner();
|
||||||
|
(row_id, text)
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
let options = build_options_from_cells(&cells);
|
|
||||||
|
let options =
|
||||||
|
build_options_from_cells(&rows.iter().map(|row| row.1.clone()).collect::<Vec<_>>());
|
||||||
|
info!(
|
||||||
|
"Transforming RichText to SelectOption, updating {} row's cell content",
|
||||||
|
rows.len()
|
||||||
|
);
|
||||||
|
for (row_id, text_cell) in rows {
|
||||||
|
let mut transformed_ids = Vec::new();
|
||||||
|
if let Some(option) = options.iter().find(|option| option.name == text_cell) {
|
||||||
|
transformed_ids.push(option.id.clone());
|
||||||
|
}
|
||||||
|
|
||||||
|
database
|
||||||
|
.update_row(row_id, |row| {
|
||||||
|
row.update_cells(|cell| {
|
||||||
|
cell.insert(
|
||||||
|
field_id,
|
||||||
|
SelectOptionIds::from(transformed_ids).to_cell_data(new_field_type),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.await;
|
||||||
|
}
|
||||||
|
|
||||||
shared.mut_options().extend(options);
|
shared.mut_options().extend(options);
|
||||||
},
|
},
|
||||||
FieldType::Checkbox => {
|
FieldType::Checkbox => {
|
||||||
|
@ -112,7 +112,8 @@ pub trait TypeOptionTransform: TypeOption + Send + Sync {
|
|||||||
_field_id: &str,
|
_field_id: &str,
|
||||||
_old_type_option_field_type: FieldType,
|
_old_type_option_field_type: FieldType,
|
||||||
_old_type_option_data: TypeOptionData,
|
_old_type_option_data: TypeOptionData,
|
||||||
_database: &Database,
|
_new_type_option_field_type: FieldType,
|
||||||
|
_database: &mut Database,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,6 @@
|
|||||||
use collab::preclude::encoding::serde::from_any;
|
use collab::preclude::encoding::serde::from_any;
|
||||||
use collab::preclude::Any;
|
use collab::preclude::Any;
|
||||||
|
|
||||||
use collab_database::fields::{Field, TypeOptionData, TypeOptionDataBuilder};
|
|
||||||
use collab_database::rows::Cell;
|
|
||||||
use flowy_error::FlowyResult;
|
|
||||||
use serde::{Deserialize, Serialize};
|
|
||||||
use std::cmp::Ordering;
|
|
||||||
|
|
||||||
use crate::entities::{FieldType, TextFilterPB, URLCellDataPB};
|
use crate::entities::{FieldType, TextFilterPB, URLCellDataPB};
|
||||||
use crate::services::cell::{CellDataChangeset, CellDataDecoder};
|
use crate::services::cell::{CellDataChangeset, CellDataDecoder};
|
||||||
use crate::services::field::{
|
use crate::services::field::{
|
||||||
@ -14,6 +8,14 @@ use crate::services::field::{
|
|||||||
TypeOptionTransform, URLCellData,
|
TypeOptionTransform, URLCellData,
|
||||||
};
|
};
|
||||||
use crate::services::sort::SortCondition;
|
use crate::services::sort::SortCondition;
|
||||||
|
use async_trait::async_trait;
|
||||||
|
use collab_database::database::Database;
|
||||||
|
use collab_database::fields::{Field, TypeOptionData, TypeOptionDataBuilder};
|
||||||
|
use collab_database::rows::Cell;
|
||||||
|
use flowy_error::FlowyResult;
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
use std::cmp::Ordering;
|
||||||
|
use tracing::trace;
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, Deserialize, Default)]
|
#[derive(Debug, Clone, Serialize, Deserialize, Default)]
|
||||||
pub struct URLTypeOption {
|
pub struct URLTypeOption {
|
||||||
@ -45,7 +47,46 @@ impl From<URLTypeOption> for TypeOptionData {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TypeOptionTransform for URLTypeOption {}
|
#[async_trait]
|
||||||
|
impl TypeOptionTransform for URLTypeOption {
|
||||||
|
async fn transform_type_option(
|
||||||
|
&mut self,
|
||||||
|
view_id: &str,
|
||||||
|
field_id: &str,
|
||||||
|
old_type_option_field_type: FieldType,
|
||||||
|
_old_type_option_data: TypeOptionData,
|
||||||
|
_new_type_option_field_type: FieldType,
|
||||||
|
database: &mut Database,
|
||||||
|
) {
|
||||||
|
match old_type_option_field_type {
|
||||||
|
FieldType::RichText => {
|
||||||
|
let rows = database
|
||||||
|
.get_cells_for_field(view_id, field_id)
|
||||||
|
.await
|
||||||
|
.into_iter()
|
||||||
|
.filter_map(|row| row.cell.map(|cell| (row.row_id, cell)))
|
||||||
|
.collect::<Vec<_>>();
|
||||||
|
|
||||||
|
trace!(
|
||||||
|
"Transforming RichText to URLTypeOption, updating {} row's cell content",
|
||||||
|
rows.len()
|
||||||
|
);
|
||||||
|
for (row_id, cell_data) in rows {
|
||||||
|
database
|
||||||
|
.update_row(row_id, |row| {
|
||||||
|
row.update_cells(|cell| {
|
||||||
|
cell.insert(field_id, Self::CellData::from(&cell_data));
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.await;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
_ => {
|
||||||
|
// Do nothing
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl TypeOptionCellDataSerde for URLTypeOption {
|
impl TypeOptionCellDataSerde for URLTypeOption {
|
||||||
fn protobuf_encode(
|
fn protobuf_encode(
|
||||||
|
@ -109,6 +109,10 @@ impl FilterController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub async fn has_filters(&self) -> bool {
|
||||||
|
!self.filters.read().await.is_empty()
|
||||||
|
}
|
||||||
|
|
||||||
pub async fn close(&self) {
|
pub async fn close(&self) {
|
||||||
if let Ok(mut task_scheduler) = self.task_scheduler.try_write() {
|
if let Ok(mut task_scheduler) = self.task_scheduler.try_write() {
|
||||||
task_scheduler.unregister_handler(&self.handler_id).await;
|
task_scheduler.unregister_handler(&self.handler_id).await;
|
||||||
|
@ -84,6 +84,10 @@ impl SortController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub async fn has_sorts(&self) -> bool {
|
||||||
|
!self.sorts.is_empty()
|
||||||
|
}
|
||||||
|
|
||||||
pub async fn did_receive_row_changed(&self, row_id: RowId) {
|
pub async fn did_receive_row_changed(&self, row_id: RowId) {
|
||||||
if !self.sorts.is_empty() {
|
if !self.sorts.is_empty() {
|
||||||
self
|
self
|
||||||
|
Loading…
Reference in New Issue
Block a user