mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-11 11:58:41 +00:00
Compare commits
18 Commits
v0.11.0-ca
...
v0.11.0-ca
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8b28761a8a | ||
|
|
77d239ff81 | ||
|
|
1ce4dd0497 | ||
|
|
aa74b0617c | ||
|
|
46f824c4e9 | ||
|
|
f11ea7570a | ||
|
|
a08edfd6d9 | ||
|
|
06912c6885 | ||
|
|
ec7f73f168 | ||
|
|
cfb77e8243 | ||
|
|
aa4d42b36c | ||
|
|
9fbd9b39d6 | ||
|
|
aeec68b0d7 | ||
|
|
fb1ed90ecc | ||
|
|
cc73124259 | ||
|
|
c2db8b356c | ||
|
|
eaa62df2dd | ||
|
|
332a5c6685 |
4
.github/actions/setup-version/action.yml
vendored
4
.github/actions/setup-version/action.yml
vendored
@@ -1,5 +1,9 @@
|
||||
name: Setup Version
|
||||
description: 'Setup Version'
|
||||
outputs:
|
||||
APP_VERSION:
|
||||
description: 'App Version'
|
||||
value: ${{ steps.version.outputs.APP_VERSION }}
|
||||
runs:
|
||||
using: 'composite'
|
||||
steps:
|
||||
|
||||
4
.github/workflows/deploy-automatically.yml
vendored
4
.github/workflows/deploy-automatically.yml
vendored
@@ -1,11 +1,11 @@
|
||||
name: Deploy by tag or schedule
|
||||
name: Deploy Automatically
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- 'v[0-9]+.[0-9]+.[0-9]+-canary.[0-9]+'
|
||||
schedule:
|
||||
- cron: '0 7 * * *'
|
||||
- cron: '0 9 * * *'
|
||||
|
||||
jobs:
|
||||
dispatch-deploy:
|
||||
|
||||
5
.github/workflows/deploy.yml
vendored
5
.github/workflows/deploy.yml
vendored
@@ -23,6 +23,7 @@ jobs:
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Version
|
||||
id: version
|
||||
uses: ./.github/actions/setup-version
|
||||
- name: Setup Node.js
|
||||
uses: ./.github/actions/setup-node
|
||||
@@ -43,6 +44,7 @@ jobs:
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Version
|
||||
id: version
|
||||
uses: ./.github/actions/setup-version
|
||||
- name: Setup Node.js
|
||||
uses: ./.github/actions/setup-node
|
||||
@@ -76,6 +78,7 @@ jobs:
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Version
|
||||
id: version
|
||||
uses: ./.github/actions/setup-version
|
||||
- name: Setup Node.js
|
||||
uses: ./.github/actions/setup-node
|
||||
@@ -99,6 +102,7 @@ jobs:
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Version
|
||||
id: version
|
||||
uses: ./.github/actions/setup-version
|
||||
- name: Setup Node.js
|
||||
uses: ./.github/actions/setup-node
|
||||
@@ -220,6 +224,7 @@ jobs:
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Version
|
||||
id: version
|
||||
uses: ./.github/actions/setup-version
|
||||
- name: Deploy to ${{ github.event.inputs.flavor }}
|
||||
uses: ./.github/actions/deploy
|
||||
|
||||
258
.github/workflows/nightly-build.yml
vendored
258
.github/workflows/nightly-build.yml
vendored
@@ -1,258 +0,0 @@
|
||||
name: Build Canary Desktop App on Staging Branch
|
||||
|
||||
on:
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
channel_override:
|
||||
description: 'channel type (canary, beta, or stable)'
|
||||
type: choice
|
||||
default: beta
|
||||
options:
|
||||
- canary
|
||||
- beta
|
||||
- stable
|
||||
push:
|
||||
branches:
|
||||
# 0.6.x-staging
|
||||
- v[0-9]+.[0-9]+.x-staging
|
||||
# 0.6.1-staging
|
||||
- v[0-9]+.[0-9]+.[0-9]+-staging
|
||||
paths-ignore:
|
||||
- README.md
|
||||
- .github/**
|
||||
- '!.github/workflows/nightly-build.yml'
|
||||
- '!.github/actions/build-rust/action.yml'
|
||||
- '!.github/actions/setup-node/action.yml'
|
||||
|
||||
permissions:
|
||||
actions: write
|
||||
contents: write
|
||||
security-events: write
|
||||
|
||||
concurrency:
|
||||
# The concurrency group contains the workflow name and the branch name for
|
||||
# pull requests or the commit hash for any other events.
|
||||
group: ${{ github.workflow }}-${{ github.event_name == 'pull_request' && github.head_ref || github.sha }}
|
||||
cancel-in-progress: true
|
||||
|
||||
env:
|
||||
# BUILD_TYPE => app icon, app name, etc
|
||||
BUILD_TYPE: internal
|
||||
# BUILD_TYPE_OVERRIDE => channel type (canary, beta, or stable) - get the channel type (the api configs)
|
||||
BUILD_TYPE_OVERRIDE: ${{ github.event.inputs.channel_override || 'beta' }}
|
||||
|
||||
jobs:
|
||||
set-build-version:
|
||||
runs-on: ubuntu-latest
|
||||
outputs:
|
||||
version: 0.0.0-internal.${{ steps.version.outputs.version }}
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: toeverything/set-build-version@latest
|
||||
- id: version
|
||||
run: echo ::set-output name=version::${{ env.BUILD_VERSION }}
|
||||
|
||||
before-make:
|
||||
runs-on: ubuntu-latest
|
||||
needs:
|
||||
- set-build-version
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Node.js
|
||||
uses: ./.github/actions/setup-node
|
||||
- name: Setup @sentry/cli
|
||||
uses: ./.github/actions/setup-sentry
|
||||
- name: Replace Version
|
||||
run: ./scripts/set-version.sh ${{ needs.set-build-version.outputs.version }}
|
||||
- name: generate-assets
|
||||
run: yarn workspace @affine/electron generate-assets
|
||||
env:
|
||||
SENTRY_ORG: ${{ secrets.SENTRY_ORG }}
|
||||
SENTRY_PROJECT: ${{ secrets.SENTRY_PROJECT }}
|
||||
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }}
|
||||
SENTRY_DSN: ${{ secrets.SENTRY_DSN }}
|
||||
RELEASE_VERSION: ${{ needs.set-build-version.outputs.version }}
|
||||
SKIP_PLUGIN_BUILD: 'true'
|
||||
SKIP_NX_CACHE: 'true'
|
||||
|
||||
- name: Upload core artifact
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: core
|
||||
path: packages/frontend/electron/resources/web-static
|
||||
|
||||
make-distribution:
|
||||
strategy:
|
||||
# all combinations: macos-latest x64, macos-latest arm64, ubuntu-latest x64
|
||||
# For windows, we need a separate approach
|
||||
matrix:
|
||||
spec:
|
||||
- runner: macos-latest
|
||||
platform: darwin
|
||||
arch: x64
|
||||
target: x86_64-apple-darwin
|
||||
- runner: macos-latest
|
||||
platform: darwin
|
||||
arch: arm64
|
||||
target: aarch64-apple-darwin
|
||||
- runner: ubuntu-latest
|
||||
platform: linux
|
||||
arch: x64
|
||||
target: x86_64-unknown-linux-gnu
|
||||
- runner: windows-latest
|
||||
platform: win32
|
||||
arch: x64
|
||||
target: x86_64-pc-windows-msvc
|
||||
runs-on: ${{ matrix.spec.runner }}
|
||||
needs:
|
||||
- before-make
|
||||
- set-build-version
|
||||
env:
|
||||
APPLE_ID: ${{ secrets.APPLE_ID }}
|
||||
APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }}
|
||||
APPLE_TEAM_ID: ${{ secrets.APPLE_TEAM_ID }}
|
||||
SKIP_GENERATE_ASSETS: 1
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Node.js
|
||||
timeout-minutes: 10
|
||||
if: ${{ matrix.spec.platform == 'darwin' }}
|
||||
uses: ./.github/actions/setup-node
|
||||
with:
|
||||
extra-flags: workspaces focus @affine/electron @affine/monorepo
|
||||
hard-link-nm: false
|
||||
build-plugins: false
|
||||
nmHoistingLimits: workspaces
|
||||
enableScripts: false
|
||||
- name: Setup Node.js
|
||||
timeout-minutes: 10
|
||||
if: ${{ matrix.spec.platform != 'darwin' }}
|
||||
uses: ./.github/actions/setup-node
|
||||
with:
|
||||
extra-flags: workspaces focus @affine/electron @affine/monorepo
|
||||
hard-link-nm: false
|
||||
build-plugins: false
|
||||
nmHoistingLimits: workspaces
|
||||
- name: Build AFFiNE native
|
||||
uses: ./.github/actions/build-rust
|
||||
with:
|
||||
target: ${{ matrix.spec.target }}
|
||||
package: '@affine/native'
|
||||
nx_token: ${{ secrets.NX_CLOUD_ACCESS_TOKEN }}
|
||||
- name: Replace Version
|
||||
run: ./scripts/set-version.sh ${{ needs.set-build-version.outputs.version }}
|
||||
- uses: actions/download-artifact@v3
|
||||
with:
|
||||
name: core
|
||||
path: packages/frontend/electron/resources/web-static
|
||||
|
||||
- name: Build Plugins
|
||||
run: yarn run build:plugins
|
||||
|
||||
- name: Build Desktop Layers
|
||||
run: yarn workspace @affine/electron build
|
||||
|
||||
- name: Signing By Apple Developer ID
|
||||
if: ${{ matrix.spec.platform == 'darwin' }}
|
||||
uses: apple-actions/import-codesign-certs@v2
|
||||
with:
|
||||
p12-file-base64: ${{ secrets.CERTIFICATES_P12 }}
|
||||
p12-password: ${{ secrets.CERTIFICATES_P12_PASSWORD }}
|
||||
|
||||
- name: make
|
||||
run: yarn workspace @affine/electron make --platform=${{ matrix.spec.platform }} --arch=${{ matrix.spec.arch }}
|
||||
env:
|
||||
SKIP_PLUGIN_BUILD: 1
|
||||
SKIP_WEB_BUILD: 1
|
||||
HOIST_NODE_MODULES: 1
|
||||
|
||||
- name: Save artifacts (mac)
|
||||
if: ${{ matrix.spec.platform == 'darwin' }}
|
||||
run: |
|
||||
mkdir -p builds
|
||||
mv packages/frontend/electron/out/*/make/*.dmg ./builds/affine-${{ env.BUILD_TYPE }}-macos-${{ matrix.spec.arch }}.dmg
|
||||
mv packages/frontend/electron/out/*/make/zip/darwin/${{ matrix.spec.arch }}/*.zip ./builds/affine-${{ env.BUILD_TYPE }}-macos-${{ matrix.spec.arch }}.zip
|
||||
- name: Save artifacts (windows)
|
||||
if: ${{ matrix.spec.platform == 'win32' }}
|
||||
run: |
|
||||
mkdir -p builds
|
||||
mv packages/frontend/electron/out/*/make/zip/win32/x64/AFFiNE*-win32-x64-*.zip ./builds/affine-${{ env.BUILD_TYPE }}-windows-x64.zip
|
||||
mv packages/frontend/electron/out/*/make/squirrel.windows/x64/*.exe ./builds/affine-${{ env.BUILD_TYPE }}-windows-x64.exe
|
||||
mv packages/frontend/electron/out/*/make/squirrel.windows/x64/*.msi ./builds/affine-${{ env.BUILD_TYPE }}-windows-x64.msi
|
||||
mv packages/frontend/electron/out/*/make/squirrel.windows/x64/*.nupkg ./builds/affine-${{ env.BUILD_TYPE }}-windows-x64.nupkg
|
||||
|
||||
- name: Save artifacts (linux)
|
||||
if: ${{ matrix.spec.platform == 'linux' }}
|
||||
run: |
|
||||
mkdir -p builds
|
||||
mv packages/frontend/electron/out/*/make/zip/linux/x64/*.zip ./builds/affine-${{ env.BUILD_TYPE }}-linux-x64.zip
|
||||
mv packages/frontend/electron/out/*/make/AppImage/x64/*.AppImage ./builds/affine-${{ env.BUILD_TYPE }}-linux-x64.AppImage
|
||||
|
||||
- name: Upload Artifact
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: affine-${{ matrix.spec.platform }}-${{ matrix.spec.arch }}-builds
|
||||
path: builds
|
||||
|
||||
release:
|
||||
needs:
|
||||
- make-distribution
|
||||
- set-build-version
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Download Artifacts (macos-x64)
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
name: affine-darwin-x64-builds
|
||||
path: ./
|
||||
- name: Download Artifacts (macos-arm64)
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
name: affine-darwin-arm64-builds
|
||||
path: ./
|
||||
- name: Download Artifacts (windows-x64)
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
name: affine-win32-x64-builds
|
||||
path: ./
|
||||
- name: Download Artifacts (linux-x64)
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
name: affine-linux-x64-builds
|
||||
path: ./
|
||||
- name: Setup Node.js
|
||||
uses: actions/setup-node@v4
|
||||
with:
|
||||
node-version: 18
|
||||
- name: Generate Release yml
|
||||
run: |
|
||||
node ./packages/frontend/electron/scripts/generate-yml.js
|
||||
env:
|
||||
RELEASE_VERSION: ${{ needs.set-build-version.outputs.version }}
|
||||
- name: Generate SHA512 checksums
|
||||
run: |
|
||||
sha512sum *-linux-* > SHA512SUMS.txt
|
||||
sha512sum *-macos-* >> SHA512SUMS.txt
|
||||
sha512sum *-windows-* >> SHA512SUMS.txt
|
||||
- name: Create Release Draft
|
||||
uses: softprops/action-gh-release@v1
|
||||
env:
|
||||
GITHUB_TOKEN: ${{ secrets.RELEASE_TOKEN }}
|
||||
with:
|
||||
repository: 'toeverything/AFFiNE-Releases'
|
||||
name: ${{ needs.set-build-version.outputs.version }}
|
||||
tag_name: ${{ needs.set-build-version.outputs.version }}
|
||||
prerelease: true
|
||||
files: |
|
||||
./SHA512SUMS.txt
|
||||
./VERSION
|
||||
./*.zip
|
||||
./*.dmg
|
||||
./*.exe
|
||||
./*.nupkg
|
||||
./RELEASES
|
||||
./*.AppImage
|
||||
./*.apk
|
||||
./*.yml
|
||||
@@ -1,11 +1,11 @@
|
||||
name: Release Desktop by tag or schedule
|
||||
name: Release Desktop Automatically
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- 'v[0-9]+.[0-9]+.[0-9]+-canary.[0-9]+'
|
||||
schedule:
|
||||
- cron: '0 7 * * *'
|
||||
- cron: '0 9 * * *'
|
||||
|
||||
jobs:
|
||||
dispatch-release-desktop:
|
||||
@@ -17,11 +17,11 @@ jobs:
|
||||
uses: benc-uk/workflow-dispatch@v1
|
||||
with:
|
||||
workflow: release-desktop.yml
|
||||
inputs: '{ "build-type": "canary", "is-draft": true, "is-pre-release": true }'
|
||||
inputs: '{ "build-type": "canary", "is-draft": false, "is-pre-release": true }'
|
||||
- name: dispatch desktop release by schedule
|
||||
if: ${{ github.event_name == 'schedule' }}
|
||||
uses: benc-uk/workflow-dispatch@v1
|
||||
with:
|
||||
workflow: release-desktop.yml
|
||||
inputs: '{ "build-type": "canary", "is-draft": true, "is-pre-release": true }'
|
||||
inputs: '{ "build-type": "canary", "is-draft": false, "is-pre-release": true }'
|
||||
ref: canary
|
||||
|
||||
11
.github/workflows/release-desktop.yml
vendored
11
.github/workflows/release-desktop.yml
vendored
@@ -43,6 +43,7 @@ jobs:
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Version
|
||||
id: version
|
||||
uses: ./.github/actions/setup-version
|
||||
- name: Setup Node.js
|
||||
uses: ./.github/actions/setup-node
|
||||
@@ -92,6 +93,9 @@ jobs:
|
||||
SKIP_GENERATE_ASSETS: 1
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Version
|
||||
id: version
|
||||
uses: ./.github/actions/setup-version
|
||||
- name: Setup Node.js
|
||||
timeout-minutes: 10
|
||||
uses: ./.github/actions/setup-node
|
||||
@@ -166,6 +170,9 @@ jobs:
|
||||
SKIP_GENERATE_ASSETS: 1
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Setup Version
|
||||
id: version
|
||||
uses: ./.github/actions/setup-version
|
||||
- name: Setup Node.js
|
||||
timeout-minutes: 10
|
||||
uses: ./.github/actions/setup-node
|
||||
@@ -355,8 +362,8 @@ jobs:
|
||||
with:
|
||||
name: ${{ needs.before-make.outputs.RELEASE_VERSION }}
|
||||
body: ''
|
||||
draft: ${{ github.event.inputs.is-draft || true }}
|
||||
prerelease: ${{ github.event.inputs.is-pre-release || true }}
|
||||
draft: ${{ github.event.inputs.is-draft }}
|
||||
prerelease: ${{ github.event.inputs.is-pre-release }}
|
||||
files: |
|
||||
./VERSION
|
||||
./*.zip
|
||||
|
||||
@@ -88,7 +88,7 @@
|
||||
"eslint-plugin-react-hooks": "^4.6.0",
|
||||
"eslint-plugin-simple-import-sort": "^10.0.0",
|
||||
"eslint-plugin-sonarjs": "^0.23.0",
|
||||
"eslint-plugin-unicorn": "^49.0.0",
|
||||
"eslint-plugin-unicorn": "^50.0.0",
|
||||
"eslint-plugin-unused-imports": "^3.0.0",
|
||||
"eslint-plugin-vue": "^9.18.1",
|
||||
"fake-indexeddb": "5.0.1",
|
||||
|
||||
@@ -10,6 +10,9 @@ export class ServerConfigType {
|
||||
|
||||
@Field({ description: 'server flavor' })
|
||||
flavor!: string;
|
||||
|
||||
@Field({ description: 'server base url' })
|
||||
baseUrl!: string;
|
||||
}
|
||||
|
||||
export class ServerConfigResolver {
|
||||
@@ -20,6 +23,7 @@ export class ServerConfigResolver {
|
||||
return {
|
||||
version: AFFiNE.version,
|
||||
flavor: SERVER_FLAVOR,
|
||||
baseUrl: AFFiNE.baseUrl,
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
@@ -8,6 +8,9 @@ type ServerConfigType {
|
||||
|
||||
"""server flavor"""
|
||||
flavor: String!
|
||||
|
||||
"""server base url"""
|
||||
baseUrl: String!
|
||||
}
|
||||
|
||||
type UserQuotaHumanReadable {
|
||||
|
||||
4
packages/common/env/package.json
vendored
4
packages/common/env/package.json
vendored
@@ -3,8 +3,8 @@
|
||||
"private": true,
|
||||
"type": "module",
|
||||
"devDependencies": {
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"react": "18.2.0",
|
||||
"react-dom": "18.2.0",
|
||||
"vitest": "1.0.4",
|
||||
|
||||
@@ -62,9 +62,9 @@
|
||||
"@affine/debug": "workspace:*",
|
||||
"@affine/env": "workspace:*",
|
||||
"@affine/sdk": "workspace:*",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"jotai": "^2.5.1",
|
||||
"jotai-effect": "^0.2.3",
|
||||
"tinykeys": "^2.1.0",
|
||||
@@ -73,8 +73,8 @@
|
||||
"devDependencies": {
|
||||
"@affine-test/fixtures": "workspace:*",
|
||||
"@affine/templates": "workspace:*",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@testing-library/react": "^14.0.0",
|
||||
"async-call-rpc": "^6.3.1",
|
||||
"electron": "link:../../frontend/electron/node_modules/electron",
|
||||
|
||||
@@ -28,7 +28,12 @@ export async function migratePages(
|
||||
const oldVersions = versions?.toJSON() ?? {};
|
||||
|
||||
spaces.forEach((space: YDoc) => {
|
||||
schema.upgradePage(0, oldVersions, space);
|
||||
try {
|
||||
// Catch page upgrade error to avoid blocking the whole workspace migration.
|
||||
schema.upgradePage(0, oldVersions, space);
|
||||
} catch (e) {
|
||||
console.error(e);
|
||||
}
|
||||
});
|
||||
schema.upgradeWorkspace(rootDoc);
|
||||
|
||||
|
||||
@@ -11,7 +11,8 @@ export enum MigrationPoint {
|
||||
}
|
||||
|
||||
export function checkWorkspaceCompatibility(
|
||||
workspace: Workspace
|
||||
workspace: Workspace,
|
||||
isCloud: boolean
|
||||
): MigrationPoint | null {
|
||||
// check if there is any key starts with 'space:' on root doc
|
||||
const spaceMetaObj = workspace.doc.share.get('space:meta') as
|
||||
@@ -20,7 +21,9 @@ export function checkWorkspaceCompatibility(
|
||||
const docKeys = Array.from(workspace.doc.share.keys());
|
||||
const haveSpaceMeta = !!spaceMetaObj && spaceMetaObj.size > 0;
|
||||
const haveLegacySpace = docKeys.some(key => key.startsWith('space:'));
|
||||
if (haveSpaceMeta || haveLegacySpace) {
|
||||
|
||||
// DON'T UPGRADE SUBDOC ON CLOUD
|
||||
if (!isCloud && (haveSpaceMeta || haveLegacySpace)) {
|
||||
return MigrationPoint.SubDoc;
|
||||
}
|
||||
|
||||
|
||||
@@ -22,11 +22,11 @@
|
||||
"dist"
|
||||
],
|
||||
"dependencies": {
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"jotai": "^2.5.1",
|
||||
"zod": "^3.22.4"
|
||||
},
|
||||
|
||||
@@ -37,8 +37,8 @@
|
||||
"y-provider": "workspace:*"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"fake-indexeddb": "^5.0.0",
|
||||
"vite": "^5.0.6",
|
||||
"vite-plugin-dts": "3.6.0",
|
||||
|
||||
@@ -24,7 +24,7 @@
|
||||
"build": "vite build"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"vite": "^5.0.6",
|
||||
"vite-plugin-dts": "3.6.0",
|
||||
"vitest": "1.0.4",
|
||||
|
||||
@@ -72,12 +72,12 @@
|
||||
"uuid": "^9.0.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/icons": "2.1.36",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@storybook/addon-actions": "^7.5.3",
|
||||
"@storybook/addon-essentials": "^7.5.3",
|
||||
"@storybook/addon-interactions": "^7.5.3",
|
||||
|
||||
@@ -21,6 +21,7 @@ interface ExportMenuItemProps<T> {
|
||||
|
||||
interface ExportProps {
|
||||
exportHandler: (type: 'pdf' | 'html' | 'png' | 'markdown') => Promise<void>;
|
||||
pageMode?: 'page' | 'edgeless';
|
||||
className?: string;
|
||||
}
|
||||
|
||||
@@ -47,6 +48,7 @@ export function ExportMenuItem<T>({
|
||||
export const ExportMenuItems = ({
|
||||
exportHandler,
|
||||
className = transitionStyle,
|
||||
pageMode = 'page',
|
||||
}: ExportProps) => {
|
||||
const t = useAFFiNEI18N();
|
||||
const itemMap = useMemo(
|
||||
@@ -94,16 +96,23 @@ export const ExportMenuItems = ({
|
||||
],
|
||||
[className, exportHandler, t]
|
||||
);
|
||||
const items = itemMap.map(({ component: Component, props }) => (
|
||||
<Component key={props.label} {...props} />
|
||||
));
|
||||
const items = itemMap.map(({ component: Component, props }) =>
|
||||
pageMode === 'edgeless' &&
|
||||
(props.type === 'pdf' || props.type === 'png') ? null : (
|
||||
<Component key={props.label} {...props} />
|
||||
)
|
||||
);
|
||||
return items;
|
||||
};
|
||||
|
||||
export const Export = ({ exportHandler, className }: ExportProps) => {
|
||||
export const Export = ({ exportHandler, className, pageMode }: ExportProps) => {
|
||||
const t = useAFFiNEI18N();
|
||||
const items = (
|
||||
<ExportMenuItems exportHandler={exportHandler} className={className} />
|
||||
<ExportMenuItems
|
||||
exportHandler={exportHandler}
|
||||
className={className}
|
||||
pageMode={pageMode}
|
||||
/>
|
||||
);
|
||||
return (
|
||||
<MenuSub
|
||||
|
||||
@@ -1,6 +0,0 @@
|
||||
import { style } from '@vanilla-extract/css';
|
||||
|
||||
export const input = style({
|
||||
height: '34px',
|
||||
width: '220px',
|
||||
});
|
||||
@@ -2,7 +2,6 @@ import { useCallback, useState } from 'react';
|
||||
|
||||
import Input from '../../ui/input';
|
||||
import { Menu } from '../../ui/menu';
|
||||
import * as styles from './index.css';
|
||||
|
||||
export const RenameModal = ({
|
||||
onRename,
|
||||
@@ -33,12 +32,12 @@ export const RenameModal = ({
|
||||
}}
|
||||
items={
|
||||
<Input
|
||||
className={styles.input}
|
||||
autoFocus
|
||||
defaultValue={value}
|
||||
onChange={setValue}
|
||||
onEnter={handleRename}
|
||||
data-testid="rename-modal-input"
|
||||
style={{ width: 220, height: 34 }}
|
||||
/>
|
||||
}
|
||||
>
|
||||
|
||||
@@ -391,7 +391,6 @@ export const createConfiguration: (
|
||||
proxy: {
|
||||
'/api/worker/': {
|
||||
target: 'https://affine-worker.toeverything.workers.dev',
|
||||
pathRewrite: { '^/api/worker/': '/api/' },
|
||||
changeOrigin: true,
|
||||
secure: false,
|
||||
},
|
||||
|
||||
@@ -33,7 +33,7 @@ export function getRuntimeConfig(buildFlags: BuildFlags): RuntimeConfig {
|
||||
enablePayment: true,
|
||||
enablePageHistory: false,
|
||||
enableCopilot: false,
|
||||
serverUrlPrefix: 'https://insider.affine.pro', // Let insider be stable environment temporarily.
|
||||
serverUrlPrefix: 'https://app.affine.pro',
|
||||
editorFlags,
|
||||
appVersion: packageJson.version,
|
||||
editorVersion: packageJson.dependencies['@blocksuite/presets'],
|
||||
|
||||
@@ -25,14 +25,14 @@
|
||||
"@affine/i18n": "workspace:*",
|
||||
"@affine/templates": "workspace:*",
|
||||
"@affine/workspace": "workspace:*",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/icons": "2.1.36",
|
||||
"@blocksuite/inline": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/inline": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@dnd-kit/core": "^6.0.8",
|
||||
"@dnd-kit/sortable": "^8.0.0",
|
||||
"@emotion/cache": "^11.11.0",
|
||||
@@ -44,7 +44,7 @@
|
||||
"@radix-ui/react-dialog": "^1.0.4",
|
||||
"@radix-ui/react-scroll-area": "^1.0.5",
|
||||
"@radix-ui/react-select": "^2.0.0",
|
||||
"@react-hookz/web": "^23.1.0",
|
||||
"@react-hookz/web": "^24.0.0",
|
||||
"@sentry/integrations": "^7.83.0",
|
||||
"@sentry/react": "^7.83.0",
|
||||
"@toeverything/theme": "^0.7.20",
|
||||
|
||||
@@ -8,7 +8,7 @@ import { useAFFiNEI18N } from '@affine/i18n/hooks';
|
||||
import { useWorkspace } from '@toeverything/hooks/use-workspace';
|
||||
import { useWorkspaceInfo } from '@toeverything/hooks/use-workspace-info';
|
||||
|
||||
import { useSelfHosted } from '../../../hooks/affine/use-server-flavor';
|
||||
import { useSelfHosted } from '../../../hooks/affine/use-server-config';
|
||||
import { DeleteLeaveWorkspace } from './delete-leave-workspace';
|
||||
import { EnableCloudPanel } from './enable-cloud';
|
||||
import { ExportPanel } from './export';
|
||||
|
||||
@@ -14,7 +14,6 @@ import { useSetAtom } from 'jotai';
|
||||
import {
|
||||
type KeyboardEvent,
|
||||
type MouseEvent,
|
||||
startTransition,
|
||||
useCallback,
|
||||
useEffect,
|
||||
useState,
|
||||
@@ -119,9 +118,7 @@ export const ProfilePanel = ({ isOwner, workspace }: ProfilePanelProps) => {
|
||||
);
|
||||
|
||||
const handleSetInput = useCallback((value: string) => {
|
||||
startTransition(() => {
|
||||
setInput(value);
|
||||
});
|
||||
setInput(value);
|
||||
}, []);
|
||||
|
||||
const handleKeyUp = useCallback(
|
||||
@@ -203,7 +200,7 @@ export const ProfilePanel = ({ isOwner, workspace }: ProfilePanelProps) => {
|
||||
<Input
|
||||
disabled={workspaceIsLoading || !isOwner}
|
||||
value={input}
|
||||
className={styles.workspaceNameInput}
|
||||
style={{ width: 280, height: 32 }}
|
||||
data-testid="workspace-name-input"
|
||||
placeholder={t['Workspace Name']()}
|
||||
maxLength={64}
|
||||
|
||||
@@ -201,8 +201,3 @@ export const arrowRight = style({
|
||||
color: 'var(--affine-text-emphasis-color)',
|
||||
cursor: 'pointer',
|
||||
});
|
||||
|
||||
export const workspaceNameInput = style({
|
||||
height: '32px',
|
||||
width: '280px',
|
||||
});
|
||||
|
||||
@@ -2,7 +2,15 @@ import { Button } from '@affine/component';
|
||||
|
||||
import * as styles from './animate-in-tooltip.css';
|
||||
|
||||
export const AnimateInTooltip = ({ onNext }: { onNext: () => void }) => {
|
||||
interface AnimateInTooltipProps {
|
||||
onNext: () => void;
|
||||
visible?: boolean;
|
||||
}
|
||||
|
||||
export const AnimateInTooltip = ({
|
||||
onNext,
|
||||
visible,
|
||||
}: AnimateInTooltipProps) => {
|
||||
return (
|
||||
<>
|
||||
<div className={styles.tooltip}>
|
||||
@@ -10,9 +18,11 @@ export const AnimateInTooltip = ({ onNext }: { onNext: () => void }) => {
|
||||
whiteboards and databases
|
||||
</div>
|
||||
<div className={styles.next}>
|
||||
<Button type="primary" size="extraLarge" onClick={onNext}>
|
||||
Next
|
||||
</Button>
|
||||
{visible ? (
|
||||
<Button type="primary" size="extraLarge" onClick={onNext}>
|
||||
Next
|
||||
</Button>
|
||||
) : null}
|
||||
</div>
|
||||
</>
|
||||
);
|
||||
|
||||
@@ -23,7 +23,27 @@ export const segment = style({
|
||||
position: 'absolute',
|
||||
top: `calc(var(--segments-up) / var(--segments) * 100%)`,
|
||||
|
||||
// add a thin line behind to hide the gap between segments
|
||||
'::before': {
|
||||
content: '""',
|
||||
position: 'absolute',
|
||||
transform: `translateZ(-1px)`,
|
||||
width: '100%',
|
||||
height: '2px',
|
||||
background: onboardingVars.paper.bg,
|
||||
},
|
||||
|
||||
selectors: {
|
||||
['&[data-root="true"]::before']: {
|
||||
content: 'none',
|
||||
},
|
||||
['&[data-direction="up"]::before']: {
|
||||
bottom: -1,
|
||||
},
|
||||
['&[data-direction="down"]::before']: {
|
||||
top: -1,
|
||||
},
|
||||
|
||||
['&[data-root="true"]']: {
|
||||
height: `calc(1 / var(--segments) * 100%)`,
|
||||
},
|
||||
|
||||
@@ -34,6 +34,11 @@ export const Onboarding = ({ onOpenApp }: OnboardingProps) => {
|
||||
});
|
||||
}, []);
|
||||
|
||||
const onTooltipNext = useCallback(() => {
|
||||
if (status.activeId) return;
|
||||
setStatus({ activeId: null, unfoldingId: '4' });
|
||||
}, [status.activeId]);
|
||||
|
||||
return (
|
||||
<div
|
||||
className={styles.onboarding}
|
||||
@@ -80,9 +85,7 @@ export const Onboarding = ({ onOpenApp }: OnboardingProps) => {
|
||||
)}
|
||||
|
||||
<div className={styles.tipsWrapper} data-visible={!status.activeId}>
|
||||
<AnimateInTooltip
|
||||
onNext={() => setStatus({ activeId: null, unfoldingId: '4' })}
|
||||
/>
|
||||
<AnimateInTooltip onNext={onTooltipNext} visible={!status.activeId} />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
@@ -100,8 +100,7 @@ export const onboarding = style([
|
||||
animation: `${fadeIn} 0.8s linear`,
|
||||
// content: 'unset',
|
||||
background:
|
||||
// 'linear-gradient(180deg, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0) 99.58%)',
|
||||
'linear-gradient(180deg, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0) 80%)',
|
||||
'linear-gradient(180deg, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0) 99.58%)',
|
||||
},
|
||||
'&[data-is-window="true"][data-is-desktop="true"]::after': {
|
||||
opacity: 0,
|
||||
|
||||
@@ -34,7 +34,7 @@ import {
|
||||
openSignOutModalAtom,
|
||||
} from '../../../../atoms';
|
||||
import { useCurrentUser } from '../../../../hooks/affine/use-current-user';
|
||||
import { useSelfHosted } from '../../../../hooks/affine/use-server-flavor';
|
||||
import { useSelfHosted } from '../../../../hooks/affine/use-server-config';
|
||||
import { useUserSubscription } from '../../../../hooks/use-subscription';
|
||||
import { validateAndReduceImage } from '../../../../utils/reduce-image';
|
||||
import { Upload } from '../../../pure/file-upload';
|
||||
@@ -137,12 +137,12 @@ export const AvatarAndName = () => {
|
||||
<label>{t['com.affine.settings.profile.name']()}</label>
|
||||
<FlexWrapper alignItems="center">
|
||||
<Input
|
||||
className={styles.userNameInput}
|
||||
defaultValue={input}
|
||||
data-testid="user-name-input"
|
||||
placeholder={t['com.affine.settings.profile.placeholder']()}
|
||||
maxLength={64}
|
||||
minLength={0}
|
||||
style={{ width: 280, height: 32 }}
|
||||
onChange={setInput}
|
||||
onEnter={handleUpdateUserName}
|
||||
/>
|
||||
|
||||
@@ -43,8 +43,3 @@ globalStyle(`${avatarWrapper} .camera-icon-wrapper`, {
|
||||
export const button = style({
|
||||
padding: '4px 12px',
|
||||
});
|
||||
|
||||
export const userNameInput = style({
|
||||
height: '32px',
|
||||
width: '280px',
|
||||
});
|
||||
|
||||
@@ -8,7 +8,7 @@ import {
|
||||
import type { ReactElement, SVGProps } from 'react';
|
||||
|
||||
import { useCurrentLoginStatus } from '../../../../hooks/affine/use-current-login-status';
|
||||
import { useSelfHosted } from '../../../../hooks/affine/use-server-flavor';
|
||||
import { useSelfHosted } from '../../../../hooks/affine/use-server-config';
|
||||
import { AboutAffine } from './about';
|
||||
import { AppearanceSettings } from './appearance';
|
||||
import { BillingSettings } from './billing';
|
||||
|
||||
@@ -4,7 +4,9 @@ import { Divider } from '@affine/component/ui/divider';
|
||||
import { WorkspaceFlavour } from '@affine/env/workspace';
|
||||
import { useAFFiNEI18N } from '@affine/i18n/hooks';
|
||||
import { LinkIcon } from '@blocksuite/icons';
|
||||
import { useAtomValue } from 'jotai';
|
||||
|
||||
import { currentModeAtom } from '../../../../atoms/mode';
|
||||
import { useExportPage } from '../../../../hooks/affine/use-export-page';
|
||||
import * as styles from './index.css';
|
||||
import type { ShareMenuProps } from './share-menu';
|
||||
@@ -17,12 +19,13 @@ export const ShareExport = ({
|
||||
const t = useAFFiNEI18N();
|
||||
const workspaceId = workspace.id;
|
||||
const pageId = currentPage.id;
|
||||
const { onClickCopyLink } = useSharingUrl({
|
||||
const { sharingUrl, onClickCopyLink } = useSharingUrl({
|
||||
workspaceId,
|
||||
pageId,
|
||||
urlType: 'workspace',
|
||||
});
|
||||
const exportHandler = useExportPage(currentPage);
|
||||
const currentMode = useAtomValue(currentModeAtom);
|
||||
|
||||
return (
|
||||
<>
|
||||
@@ -36,6 +39,7 @@ export const ShareExport = ({
|
||||
<ExportMenuItems
|
||||
exportHandler={exportHandler}
|
||||
className={styles.menuItemStyle}
|
||||
pageMode={currentMode}
|
||||
/>
|
||||
</div>
|
||||
{workspace.flavour !== WorkspaceFlavour.LOCAL ? (
|
||||
@@ -53,6 +57,7 @@ export const ShareExport = ({
|
||||
onClick={onClickCopyLink}
|
||||
icon={<LinkIcon />}
|
||||
type="plain"
|
||||
disabled={!sharingUrl}
|
||||
>
|
||||
{t['com.affine.share-menu.copy-private-link']()}
|
||||
</Button>
|
||||
|
||||
@@ -18,6 +18,7 @@ import { useCallback } from 'react';
|
||||
import type { PageMode } from '../../../../atoms';
|
||||
import { currentModeAtom } from '../../../../atoms/mode';
|
||||
import { useIsSharedPage } from '../../../../hooks/affine/use-is-shared-page';
|
||||
import { useServerBaseUrl } from '../../../../hooks/affine/use-server-config';
|
||||
import * as styles from './index.css';
|
||||
import type { ShareMenuProps } from './share-menu';
|
||||
import { useSharingUrl } from './use-share-url';
|
||||
@@ -98,6 +99,7 @@ export const AffineSharePage = (props: ShareMenuProps) => {
|
||||
pageId,
|
||||
urlType: 'share',
|
||||
});
|
||||
const baseUrl = useServerBaseUrl();
|
||||
const t = useAFFiNEI18N();
|
||||
|
||||
const onClickCreateLink = useCallback(() => {
|
||||
@@ -140,9 +142,13 @@ export const AffineSharePage = (props: ShareMenuProps) => {
|
||||
lineHeight: '20px',
|
||||
}}
|
||||
value={
|
||||
isSharedPage
|
||||
? sharingUrl
|
||||
: `${location.protocol}//${location.hostname}/...`
|
||||
(isSharedPage && sharingUrl) ||
|
||||
`${
|
||||
baseUrl ||
|
||||
`${location.protocol}${
|
||||
location.port ? `:${location.port}` : ''
|
||||
}//${location.hostname}`
|
||||
}/...`
|
||||
}
|
||||
readOnly
|
||||
/>
|
||||
@@ -151,6 +157,7 @@ export const AffineSharePage = (props: ShareMenuProps) => {
|
||||
onClick={onClickCopyLink}
|
||||
data-testid="share-menu-copy-link-button"
|
||||
style={{ padding: '4px 12px', whiteSpace: 'nowrap' }}
|
||||
disabled={!sharingUrl}
|
||||
>
|
||||
{t.Copy()}
|
||||
</Button>
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
import { toast } from '@affine/component';
|
||||
import { useServerBaseUrl } from '@affine/core/hooks/affine/use-server-config';
|
||||
import { useAFFiNEI18N } from '@affine/i18n/hooks';
|
||||
import { useCallback, useMemo } from 'react';
|
||||
|
||||
@@ -10,22 +11,27 @@ type UseSharingUrl = {
|
||||
urlType: UrlType;
|
||||
};
|
||||
|
||||
export const generateUrl = ({
|
||||
workspaceId,
|
||||
pageId,
|
||||
urlType,
|
||||
}: UseSharingUrl) => {
|
||||
// to generate a private url like https://affine.app/workspace/123/456
|
||||
// to generate a public url like https://affine.app/share/123/456
|
||||
// or https://affine.app/share/123/456?mode=edgeless
|
||||
const useGenerateUrl = ({ workspaceId, pageId, urlType }: UseSharingUrl) => {
|
||||
// to generate a private url like https://app.affine.app/workspace/123/456
|
||||
// to generate a public url like https://app.affine.app/share/123/456
|
||||
// or https://app.affine.app/share/123/456?mode=edgeless
|
||||
|
||||
const { protocol, hostname, port } = window.location;
|
||||
const url = new URL(
|
||||
`${protocol}//${hostname}${
|
||||
port ? `:${port}` : ''
|
||||
}/${urlType}/${workspaceId}/${pageId}`
|
||||
);
|
||||
return url.toString();
|
||||
const baseUrl = useServerBaseUrl();
|
||||
|
||||
const url = useMemo(() => {
|
||||
// baseUrl is null when running in electron and without network
|
||||
if (!baseUrl) return null;
|
||||
|
||||
try {
|
||||
return new URL(
|
||||
`${baseUrl}/${urlType}/${workspaceId}/${pageId}`
|
||||
).toString();
|
||||
} catch (e) {
|
||||
return null;
|
||||
}
|
||||
}, [baseUrl, pageId, urlType, workspaceId]);
|
||||
|
||||
return url;
|
||||
};
|
||||
|
||||
export const useSharingUrl = ({
|
||||
@@ -34,20 +40,21 @@ export const useSharingUrl = ({
|
||||
urlType,
|
||||
}: UseSharingUrl) => {
|
||||
const t = useAFFiNEI18N();
|
||||
const sharingUrl = useMemo(
|
||||
() => generateUrl({ workspaceId, pageId, urlType }),
|
||||
[workspaceId, pageId, urlType]
|
||||
);
|
||||
const sharingUrl = useGenerateUrl({ workspaceId, pageId, urlType });
|
||||
|
||||
const onClickCopyLink = useCallback(() => {
|
||||
navigator.clipboard
|
||||
.writeText(sharingUrl)
|
||||
.then(() => {
|
||||
toast(t['Copied link to clipboard']());
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
if (sharingUrl) {
|
||||
navigator.clipboard
|
||||
.writeText(sharingUrl)
|
||||
.then(() => {
|
||||
toast(t['Copied link to clipboard']());
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
} else {
|
||||
toast('Network not available');
|
||||
}
|
||||
}, [sharingUrl, t]);
|
||||
|
||||
return {
|
||||
|
||||
@@ -182,7 +182,7 @@ export const PageHeaderMenuButton = ({ rename, pageId }: PageMenuProps) => {
|
||||
>
|
||||
{t['Import']()}
|
||||
</MenuItem>
|
||||
<Export exportHandler={exportHandler} />
|
||||
<Export exportHandler={exportHandler} pageMode={currentMode} />
|
||||
|
||||
{workspace.flavour === WorkspaceFlavour.AFFINE_CLOUD &&
|
||||
runtimeConfig.enablePageHistory ? (
|
||||
|
||||
@@ -97,9 +97,16 @@ const useSyncEngineSyncProgress = () => {
|
||||
useEffect(() => {
|
||||
setSyncEngineStatus(currentWorkspace.engine.sync.status);
|
||||
const disposable = currentWorkspace.engine.sync.onStatusChange.on(
|
||||
debounce(status => {
|
||||
setSyncEngineStatus(status);
|
||||
}, 500)
|
||||
debounce(
|
||||
status => {
|
||||
setSyncEngineStatus(status);
|
||||
},
|
||||
300,
|
||||
{
|
||||
maxWait: 500,
|
||||
trailing: true,
|
||||
}
|
||||
)
|
||||
);
|
||||
return () => {
|
||||
disposable?.dispose();
|
||||
|
||||
@@ -141,7 +141,7 @@ export function useRegisterBlocksuiteEditorCommands(
|
||||
unsubs.push(
|
||||
registerAffineCommand({
|
||||
id: `editor:${mode}-export-to-pdf`,
|
||||
preconditionStrategy,
|
||||
preconditionStrategy: () => mode === 'page' && !trash,
|
||||
category: `editor:${mode}`,
|
||||
icon: mode === 'page' ? <PageIcon /> : <EdgelessIcon />,
|
||||
label: t['Export to PDF'](),
|
||||
@@ -167,7 +167,7 @@ export function useRegisterBlocksuiteEditorCommands(
|
||||
unsubs.push(
|
||||
registerAffineCommand({
|
||||
id: `editor:${mode}-export-to-png`,
|
||||
preconditionStrategy,
|
||||
preconditionStrategy: () => mode === 'page' && !trash,
|
||||
category: `editor:${mode}`,
|
||||
icon: mode === 'page' ? <PageIcon /> : <EdgelessIcon />,
|
||||
label: t['Export to PNG'](),
|
||||
|
||||
@@ -9,7 +9,7 @@ const errorHandler: Middleware = useSWRNext => (key, fetcher, config) => {
|
||||
return useSWRNext(key, wrappedFetcher.bind(null, fetcher), config);
|
||||
};
|
||||
|
||||
export const useServerFlavor = () => {
|
||||
const useServerConfig = () => {
|
||||
const { data: config, error } = useQueryImmutable(
|
||||
{ query: serverConfigQuery },
|
||||
{
|
||||
@@ -18,10 +18,20 @@ export const useServerFlavor = () => {
|
||||
);
|
||||
|
||||
if (error || !config) {
|
||||
return null;
|
||||
}
|
||||
|
||||
return config.serverConfig;
|
||||
};
|
||||
|
||||
export const useServerFlavor = () => {
|
||||
const config = useServerConfig();
|
||||
|
||||
if (!config) {
|
||||
return 'local';
|
||||
}
|
||||
|
||||
return config.serverConfig.flavor;
|
||||
return config.flavor;
|
||||
};
|
||||
|
||||
export const useSelfHosted = () => {
|
||||
@@ -29,3 +39,18 @@ export const useSelfHosted = () => {
|
||||
|
||||
return ['local', 'selfhosted'].includes(serverFlavor);
|
||||
};
|
||||
|
||||
export const useServerBaseUrl = () => {
|
||||
const config = useServerConfig();
|
||||
|
||||
if (!config) {
|
||||
if (environment.isDesktop) {
|
||||
// don't use window.location in electron
|
||||
return null;
|
||||
}
|
||||
const { protocol, hostname, port } = window.location;
|
||||
return `${protocol}//${hostname}${port ? `:${port}` : ''}`;
|
||||
}
|
||||
|
||||
return config.baseUrl;
|
||||
};
|
||||
@@ -1,15 +0,0 @@
|
||||
'use client';
|
||||
import { useMemo } from 'react';
|
||||
|
||||
export function useShareLink(workspaceId: string): string {
|
||||
return useMemo(() => {
|
||||
if (environment.isServer) {
|
||||
throw new Error('useShareLink is not available on server side');
|
||||
}
|
||||
if (environment.isDesktop) {
|
||||
return '???';
|
||||
} else {
|
||||
return origin + '/share/' + workspaceId;
|
||||
}
|
||||
}, [workspaceId]);
|
||||
}
|
||||
@@ -2,7 +2,7 @@ import { type SubscriptionQuery, subscriptionQuery } from '@affine/graphql';
|
||||
import { useQuery } from '@affine/workspace/affine/gql';
|
||||
import { useAsyncCallback } from '@toeverything/hooks/affine-async-hooks';
|
||||
|
||||
import { useSelfHosted } from './affine/use-server-flavor';
|
||||
import { useSelfHosted } from './affine/use-server-config';
|
||||
|
||||
export type Subscription = NonNullable<
|
||||
NonNullable<SubscriptionQuery['currentUser']>['subscription']
|
||||
|
||||
@@ -32,10 +32,10 @@
|
||||
"@affine/sdk": "workspace:*",
|
||||
"@affine/templates": "workspace:*",
|
||||
"@affine/vue-hello-world-plugin": "workspace:*",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@electron-forge/cli": "^7.2.0",
|
||||
"@electron-forge/core": "^7.2.0",
|
||||
"@electron-forge/core-utils": "^7.2.0",
|
||||
|
||||
@@ -17,13 +17,14 @@ const affineCoreOutDir = path.join(affineCoreDir, 'dist');
|
||||
const publicAffineOutDir = path.join(publicDistDir, `web-static`);
|
||||
const releaseVersionEnv = process.env.RELEASE_VERSION || '';
|
||||
|
||||
console.log('build with following dir', {
|
||||
console.log('build with following variables', {
|
||||
repoRootDir,
|
||||
electronRootDir,
|
||||
publicDistDir,
|
||||
affineSrcDir: affineCoreDir,
|
||||
affineSrcOutDir: affineCoreOutDir,
|
||||
publicAffineOutDir,
|
||||
releaseVersionEnv,
|
||||
});
|
||||
|
||||
// step 0: check version match
|
||||
|
||||
@@ -1,10 +1,16 @@
|
||||
import { BrowserWindow, screen } from 'electron';
|
||||
import { BrowserWindow, type Display, screen } from 'electron';
|
||||
import { join } from 'path';
|
||||
|
||||
import { isMacOS } from '../shared/utils';
|
||||
import { mainWindowOrigin } from './constants';
|
||||
// import { getExposedMeta } from './exposed';
|
||||
import { logger } from './logger';
|
||||
|
||||
const getScreenSize = (display: Display) => {
|
||||
const { width, height } = isMacOS() ? display.bounds : display.workArea;
|
||||
return { width, height };
|
||||
};
|
||||
|
||||
// todo: not all window need all of the exposed meta
|
||||
const getWindowAdditionalArguments = async () => {
|
||||
const { getExposedMeta } = await import('./exposed');
|
||||
@@ -15,11 +21,24 @@ const getWindowAdditionalArguments = async () => {
|
||||
];
|
||||
};
|
||||
|
||||
function fullscreenAndCenter(browserWindow: BrowserWindow) {
|
||||
const position = browserWindow.getPosition();
|
||||
const size = browserWindow.getSize();
|
||||
const currentDisplay = screen.getDisplayNearestPoint({
|
||||
x: position[0] + size[0] / 2,
|
||||
y: position[1] + size[1] / 2,
|
||||
});
|
||||
if (!currentDisplay) return;
|
||||
const { width, height } = getScreenSize(currentDisplay);
|
||||
browserWindow.setSize(width, height);
|
||||
browserWindow.center();
|
||||
}
|
||||
|
||||
async function createOnboardingWindow(additionalArguments: string[]) {
|
||||
logger.info('creating onboarding window');
|
||||
|
||||
// get user's screen size
|
||||
const { width, height } = screen.getPrimaryDisplay().workAreaSize;
|
||||
const { width, height } = getScreenSize(screen.getPrimaryDisplay());
|
||||
|
||||
const browserWindow = new BrowserWindow({
|
||||
width,
|
||||
@@ -36,6 +55,7 @@ async function createOnboardingWindow(additionalArguments: string[]) {
|
||||
// skipTaskbar: true,
|
||||
transparent: true,
|
||||
hasShadow: false,
|
||||
roundedCorners: false,
|
||||
webPreferences: {
|
||||
webgl: true,
|
||||
preload: join(__dirname, './preload.js'),
|
||||
@@ -56,12 +76,18 @@ async function createOnboardingWindow(additionalArguments: string[]) {
|
||||
browserWindow.on('ready-to-show', () => {
|
||||
// forcing zoom factor to 1 to avoid onboarding display issues
|
||||
browserWindow.webContents.setZoomFactor(1);
|
||||
fullscreenAndCenter(browserWindow);
|
||||
// TODO: add a timeout to avoid flickering, window is ready, but dom is not ready
|
||||
setTimeout(() => {
|
||||
browserWindow.show();
|
||||
}, 300);
|
||||
});
|
||||
|
||||
// When moved to another screen, resize to fit the screen
|
||||
browserWindow.on('moved', () => {
|
||||
fullscreenAndCenter(browserWindow);
|
||||
});
|
||||
|
||||
await browserWindow.loadURL(
|
||||
`${mainWindowOrigin}${mainWindowOrigin.endsWith('/') ? '' : '/'}onboarding`
|
||||
);
|
||||
|
||||
@@ -655,6 +655,7 @@ query serverConfig {
|
||||
serverConfig {
|
||||
version
|
||||
flavor
|
||||
baseUrl
|
||||
}
|
||||
}`,
|
||||
};
|
||||
|
||||
@@ -2,5 +2,6 @@ query serverConfig {
|
||||
serverConfig {
|
||||
version
|
||||
flavor
|
||||
baseUrl
|
||||
}
|
||||
}
|
||||
|
||||
@@ -632,6 +632,7 @@ export type ServerConfigQuery = {
|
||||
__typename?: 'ServerConfigType';
|
||||
version: string;
|
||||
flavor: string;
|
||||
baseUrl: string;
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
@@ -20,12 +20,12 @@
|
||||
"@affine/debug": "workspace:*",
|
||||
"@affine/env": "workspace:*",
|
||||
"@affine/workspace": "workspace:*",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@testing-library/react": "^14.0.0",
|
||||
"@toeverything/infra": "workspace:*",
|
||||
"@types/image-blob-reduce": "^4.1.3",
|
||||
|
||||
@@ -92,7 +92,7 @@ export class SyncEngine {
|
||||
}
|
||||
|
||||
canGracefulStop() {
|
||||
return !!this.status.local && this.status.local.pendingPushUpdates > 0;
|
||||
return !!this.status.local && this.status.local.pendingPushUpdates === 0;
|
||||
}
|
||||
|
||||
async waitForGracefulStop(abort?: AbortSignal) {
|
||||
|
||||
@@ -76,6 +76,11 @@ export function createCloudAwarenessProvider(
|
||||
removeAwarenessStates(awareness, [awareness.clientID], 'window unload');
|
||||
};
|
||||
|
||||
function handleConnect() {
|
||||
socket.emit('client-handshake-awareness', workspaceId);
|
||||
socket.emit('awareness-init', workspaceId);
|
||||
}
|
||||
|
||||
return {
|
||||
connect: () => {
|
||||
socket.on('server-awareness-broadcast', awarenessBroadcast);
|
||||
@@ -86,16 +91,19 @@ export function createCloudAwarenessProvider(
|
||||
|
||||
socket.connect();
|
||||
|
||||
socket.on('connect', handleConnect);
|
||||
|
||||
socket.emit('client-handshake-awareness', workspaceId);
|
||||
socket.emit('awareness-init', workspaceId);
|
||||
},
|
||||
disconnect: () => {
|
||||
removeAwarenessStates(awareness, [awareness.clientID], 'disconnect');
|
||||
awareness.off('update', awarenessUpdate);
|
||||
socket.emit('client-leave-awareness', workspaceId);
|
||||
socket.off('server-awareness-broadcast', awarenessBroadcast);
|
||||
socket.off('new-client-awareness-init', newClientAwarenessInitHandler);
|
||||
socket.off('connect', handleConnect);
|
||||
window.removeEventListener('unload', windowBeforeUnloadHandler);
|
||||
socket.disconnect();
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
@@ -51,8 +51,7 @@ export function createAffineStorage(
|
||||
});
|
||||
});
|
||||
|
||||
// TODO: handle error
|
||||
socket.on('connect', () => {
|
||||
function handleConnect() {
|
||||
socket.emit(
|
||||
'client-handshake-sync',
|
||||
workspaceId,
|
||||
@@ -62,10 +61,22 @@ export function createAffineStorage(
|
||||
}
|
||||
}
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
socket.on('connect', handleConnect);
|
||||
|
||||
socket.connect();
|
||||
|
||||
socket.emit(
|
||||
'client-handshake-sync',
|
||||
workspaceId,
|
||||
(response: { error?: any }) => {
|
||||
if (!response.error) {
|
||||
syncSender.start();
|
||||
}
|
||||
}
|
||||
);
|
||||
|
||||
return {
|
||||
name: 'affine-cloud',
|
||||
async pull(docId, state) {
|
||||
@@ -124,14 +135,6 @@ export function createAffineStorage(
|
||||
await syncSender.send(docId, update);
|
||||
},
|
||||
async subscribe(cb, disconnect) {
|
||||
const response: { error?: any } = await socket
|
||||
.timeout(10000)
|
||||
.emitWithAck('client-handshake-sync', workspaceId);
|
||||
|
||||
if (response.error) {
|
||||
throw new Error('client-handshake error, ' + response.error);
|
||||
}
|
||||
|
||||
const handleUpdate = async (message: {
|
||||
workspaceId: string;
|
||||
guid: string;
|
||||
@@ -157,7 +160,7 @@ export function createAffineStorage(
|
||||
disconnect() {
|
||||
syncSender.stop();
|
||||
socket.emit('client-leave-sync', workspaceId);
|
||||
socket.disconnect();
|
||||
socket.off('connect', handleConnect);
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
@@ -49,7 +49,8 @@ export class WorkspaceUpgradeController {
|
||||
|
||||
checkIfNeedUpgrade() {
|
||||
const needUpgrade = !!checkWorkspaceCompatibility(
|
||||
this.workspace.blockSuiteWorkspace
|
||||
this.workspace.blockSuiteWorkspace,
|
||||
this.workspace.flavour === WorkspaceFlavour.AFFINE_CLOUD
|
||||
);
|
||||
this.status = {
|
||||
...this.status,
|
||||
@@ -69,7 +70,8 @@ export class WorkspaceUpgradeController {
|
||||
await this.workspace.engine.sync.waitForSynced();
|
||||
|
||||
const step = checkWorkspaceCompatibility(
|
||||
this.workspace.blockSuiteWorkspace
|
||||
this.workspace.blockSuiteWorkspace,
|
||||
this.workspace.flavour === WorkspaceFlavour.AFFINE_CLOUD
|
||||
);
|
||||
|
||||
if (!step) {
|
||||
|
||||
@@ -2,21 +2,25 @@ import { Manager } from 'socket.io-client';
|
||||
|
||||
let ioManager: Manager | null = null;
|
||||
|
||||
function getBaseUrl(): string {
|
||||
if (environment.isDesktop) {
|
||||
return runtimeConfig.serverUrlPrefix;
|
||||
}
|
||||
const { protocol, hostname, port } = window.location;
|
||||
return `${protocol === 'https:' ? 'wss' : 'ws'}://${hostname}${
|
||||
port ? `:${port}` : ''
|
||||
}`;
|
||||
}
|
||||
|
||||
// use lazy initialization socket.io io manager
|
||||
export function getIoManager(): Manager {
|
||||
if (ioManager) {
|
||||
return ioManager;
|
||||
}
|
||||
const { protocol, hostname, port } = window.location;
|
||||
ioManager = new Manager(
|
||||
`${protocol === 'https:' ? 'wss' : 'ws'}://${hostname}${
|
||||
port ? `:${port}` : ''
|
||||
}/`,
|
||||
{
|
||||
autoConnect: false,
|
||||
transports: ['websocket'],
|
||||
secure: location.protocol === 'https:',
|
||||
}
|
||||
);
|
||||
ioManager = new Manager(`${getBaseUrl()}/`, {
|
||||
autoConnect: false,
|
||||
transports: ['websocket'],
|
||||
secure: location.protocol === 'https:',
|
||||
});
|
||||
return ioManager;
|
||||
}
|
||||
|
||||
@@ -5,7 +5,6 @@ import { type ReactElement, useCallback } from 'react';
|
||||
|
||||
import { openAIApiKeyAtom } from '../core/hooks';
|
||||
import { conversationHistoryDBName } from '../core/langchain/message-history';
|
||||
import * as styles from './index.css';
|
||||
|
||||
export const DebugContent = (): ReactElement => {
|
||||
const [key, setKey] = useAtom(openAIApiKeyAtom);
|
||||
@@ -13,7 +12,7 @@ export const DebugContent = (): ReactElement => {
|
||||
<div>
|
||||
<FlexWrapper justifyContent="space-between">
|
||||
<Input
|
||||
className={styles.debugContentInput}
|
||||
style={{ width: 280 }}
|
||||
defaultValue={key ?? undefined}
|
||||
onChange={useCallback(
|
||||
(newValue: string) => {
|
||||
|
||||
@@ -41,7 +41,3 @@ export const sendButtonStyle = style({
|
||||
backgroundColor: 'transparent',
|
||||
},
|
||||
});
|
||||
|
||||
export const debugContentInput = style({
|
||||
width: '280px',
|
||||
});
|
||||
|
||||
@@ -9,10 +9,10 @@
|
||||
"devDependencies": {
|
||||
"@affine-test/fixtures": "workspace:*",
|
||||
"@affine-test/kit": "workspace:*",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@playwright/test": "^1.39.0",
|
||||
"express": "^4.18.2",
|
||||
"http-proxy-middleware": "^3.0.0-beta.1",
|
||||
|
||||
@@ -9,10 +9,10 @@
|
||||
"devDependencies": {
|
||||
"@affine-test/fixtures": "workspace:*",
|
||||
"@affine-test/kit": "workspace:*",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@playwright/test": "^1.39.0",
|
||||
"express": "^4.18.2",
|
||||
"http-proxy-middleware": "^3.0.0-beta.1",
|
||||
|
||||
@@ -9,10 +9,10 @@
|
||||
"devDependencies": {
|
||||
"@affine-test/fixtures": "workspace:*",
|
||||
"@affine-test/kit": "workspace:*",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@playwright/test": "^1.39.0",
|
||||
"express": "^4.18.2",
|
||||
"http-proxy-middleware": "^3.0.0-beta.1",
|
||||
|
||||
@@ -9,10 +9,10 @@
|
||||
"devDependencies": {
|
||||
"@affine-test/fixtures": "workspace:*",
|
||||
"@affine-test/kit": "workspace:*",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@playwright/test": "^1.39.0",
|
||||
"express": "^4.18.2",
|
||||
"http-proxy-middleware": "^3.0.0-beta.1",
|
||||
|
||||
@@ -7,10 +7,10 @@
|
||||
"devDependencies": {
|
||||
"@affine-test/fixtures": "workspace:*",
|
||||
"@affine-test/kit": "workspace:*",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@playwright/test": "^1.39.0"
|
||||
},
|
||||
"version": "0.11.0"
|
||||
|
||||
@@ -31,14 +31,14 @@
|
||||
"wait-on": "^7.2.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/block-std": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/blocks": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/global": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/icons": "2.1.36",
|
||||
"@blocksuite/inline": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312210105-edfa58e",
|
||||
"@blocksuite/inline": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/lit": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/presets": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@blocksuite/store": "0.11.0-nightly-202312212326-e2b48df",
|
||||
"@dnd-kit/sortable": "^8.0.0",
|
||||
"@tomfreudenberg/next-auth-mock": "^0.5.6",
|
||||
"chromatic": "^9.1.0",
|
||||
|
||||
312
yarn.lock
312
yarn.lock
@@ -25,10 +25,10 @@ __metadata:
|
||||
dependencies:
|
||||
"@affine-test/fixtures": "workspace:*"
|
||||
"@affine-test/kit": "workspace:*"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@playwright/test": "npm:^1.39.0"
|
||||
express: "npm:^4.18.2"
|
||||
http-proxy-middleware: "npm:^3.0.0-beta.1"
|
||||
@@ -42,10 +42,10 @@ __metadata:
|
||||
dependencies:
|
||||
"@affine-test/fixtures": "workspace:*"
|
||||
"@affine-test/kit": "workspace:*"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@playwright/test": "npm:^1.39.0"
|
||||
express: "npm:^4.18.2"
|
||||
http-proxy-middleware: "npm:^3.0.0-beta.1"
|
||||
@@ -59,10 +59,10 @@ __metadata:
|
||||
dependencies:
|
||||
"@affine-test/fixtures": "workspace:*"
|
||||
"@affine-test/kit": "workspace:*"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@playwright/test": "npm:^1.39.0"
|
||||
express: "npm:^4.18.2"
|
||||
http-proxy-middleware: "npm:^3.0.0-beta.1"
|
||||
@@ -76,10 +76,10 @@ __metadata:
|
||||
dependencies:
|
||||
"@affine-test/fixtures": "workspace:*"
|
||||
"@affine-test/kit": "workspace:*"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@playwright/test": "npm:^1.39.0"
|
||||
express: "npm:^4.18.2"
|
||||
http-proxy-middleware: "npm:^3.0.0-beta.1"
|
||||
@@ -138,10 +138,10 @@ __metadata:
|
||||
dependencies:
|
||||
"@affine-test/fixtures": "workspace:*"
|
||||
"@affine-test/kit": "workspace:*"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@playwright/test": "npm:^1.39.0"
|
||||
languageName: unknown
|
||||
linkType: soft
|
||||
@@ -222,12 +222,12 @@ __metadata:
|
||||
"@affine/graphql": "workspace:*"
|
||||
"@affine/i18n": "workspace:*"
|
||||
"@affine/workspace": "workspace:*"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/icons": "npm:2.1.36"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@dnd-kit/core": "npm:^6.0.8"
|
||||
"@dnd-kit/modifiers": "npm:^7.0.0"
|
||||
"@dnd-kit/sortable": "npm:^8.0.0"
|
||||
@@ -351,14 +351,14 @@ __metadata:
|
||||
"@affine/templates": "workspace:*"
|
||||
"@affine/workspace": "workspace:*"
|
||||
"@aws-sdk/client-s3": "npm:3.433.0"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/icons": "npm:2.1.36"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@dnd-kit/core": "npm:^6.0.8"
|
||||
"@dnd-kit/sortable": "npm:^8.0.0"
|
||||
"@emotion/cache": "npm:^11.11.0"
|
||||
@@ -372,7 +372,7 @@ __metadata:
|
||||
"@radix-ui/react-dialog": "npm:^1.0.4"
|
||||
"@radix-ui/react-scroll-area": "npm:^1.0.5"
|
||||
"@radix-ui/react-select": "npm:^2.0.0"
|
||||
"@react-hookz/web": "npm:^23.1.0"
|
||||
"@react-hookz/web": "npm:^24.0.0"
|
||||
"@sentry/integrations": "npm:^7.83.0"
|
||||
"@sentry/react": "npm:^7.83.0"
|
||||
"@sentry/webpack-plugin": "npm:^2.8.0"
|
||||
@@ -468,10 +468,10 @@ __metadata:
|
||||
"@affine/sdk": "workspace:*"
|
||||
"@affine/templates": "workspace:*"
|
||||
"@affine/vue-hello-world-plugin": "workspace:*"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@electron-forge/cli": "npm:^7.2.0"
|
||||
"@electron-forge/core": "npm:^7.2.0"
|
||||
"@electron-forge/core-utils": "npm:^7.2.0"
|
||||
@@ -520,8 +520,8 @@ __metadata:
|
||||
version: 0.0.0-use.local
|
||||
resolution: "@affine/env@workspace:packages/common/env"
|
||||
dependencies:
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
lit: "npm:^3.0.2"
|
||||
react: "npm:18.2.0"
|
||||
react-dom: "npm:18.2.0"
|
||||
@@ -628,7 +628,7 @@ __metadata:
|
||||
eslint-plugin-react-hooks: "npm:^4.6.0"
|
||||
eslint-plugin-simple-import-sort: "npm:^10.0.0"
|
||||
eslint-plugin-sonarjs: "npm:^0.23.0"
|
||||
eslint-plugin-unicorn: "npm:^49.0.0"
|
||||
eslint-plugin-unicorn: "npm:^50.0.0"
|
||||
eslint-plugin-unused-imports: "npm:^3.0.0"
|
||||
eslint-plugin-vue: "npm:^9.18.1"
|
||||
fake-indexeddb: "npm:5.0.1"
|
||||
@@ -711,11 +711,11 @@ __metadata:
|
||||
version: 0.0.0-use.local
|
||||
resolution: "@affine/sdk@workspace:packages/common/sdk"
|
||||
dependencies:
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
jotai: "npm:^2.5.1"
|
||||
vite: "npm:^5.0.6"
|
||||
vite-plugin-dts: "npm:3.6.0"
|
||||
@@ -840,14 +840,14 @@ __metadata:
|
||||
dependencies:
|
||||
"@affine/component": "workspace:*"
|
||||
"@affine/i18n": "workspace:*"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/icons": "npm:2.1.36"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@dnd-kit/sortable": "npm:^8.0.0"
|
||||
"@storybook/addon-actions": "npm:^7.5.3"
|
||||
"@storybook/addon-essentials": "npm:^7.5.3"
|
||||
@@ -4077,29 +4077,29 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@blocksuite/block-std@npm:0.11.0-nightly-202312210105-edfa58e":
|
||||
version: 0.11.0-nightly-202312210105-edfa58e
|
||||
resolution: "@blocksuite/block-std@npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std@npm:0.11.0-nightly-202312212326-e2b48df":
|
||||
version: 0.11.0-nightly-202312212326-e2b48df
|
||||
resolution: "@blocksuite/block-std@npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
dependencies:
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
lz-string: "npm:^1.5.0"
|
||||
w3c-keyname: "npm:^2.2.8"
|
||||
zod: "npm:^3.22.4"
|
||||
peerDependencies:
|
||||
"@blocksuite/store": 0.11.0-nightly-202312210105-edfa58e
|
||||
checksum: eb20c1b8a497562676c3d91b9470add50fdb01e4ec68243dc2349fa7cb943cd77f013b2d38db8d61de03caba8ca04de21ce84bb7d56cb6991d9e8b7901a05d41
|
||||
"@blocksuite/store": 0.11.0-nightly-202312212326-e2b48df
|
||||
checksum: 43302954cd31c745a887d0a4faada527c3b584747b908d07ac98cccbc82ccd31b5ca7e92ee97e2b15aefac095133e6534383b848a686ac33878c4406043e9215
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@blocksuite/blocks@npm:0.11.0-nightly-202312210105-edfa58e":
|
||||
version: 0.11.0-nightly-202312210105-edfa58e
|
||||
resolution: "@blocksuite/blocks@npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks@npm:0.11.0-nightly-202312212326-e2b48df":
|
||||
version: 0.11.0-nightly-202312212326-e2b48df
|
||||
resolution: "@blocksuite/blocks@npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
dependencies:
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@floating-ui/dom": "npm:^1.5.3"
|
||||
"@toeverything/theme": "npm:^0.7.27"
|
||||
"@types/hast": "npm:^3.0.3"
|
||||
@@ -4133,16 +4133,16 @@ __metadata:
|
||||
unified: "npm:^11.0.4"
|
||||
webfontloader: "npm:^1.6.28"
|
||||
zod: "npm:^3.22.4"
|
||||
checksum: fc4fecfb2dd3bfdf0e91fd91bda40d7ba9c02533f6e5f2de17b32265288d0b44dbb64402c6f6a1b8adb469046df14d89beb15d1ba24e0724b9145495c2f0174d
|
||||
checksum: 48cd02a389317477c866618c898a2d4839fbb4466752c2de295159fd6c073bde903a1fc46ae2ffcf823ce2e0e01cbb49db406ae728c53f27f14ef5e4159b3078
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@blocksuite/global@npm:0.11.0-nightly-202312210105-edfa58e":
|
||||
version: 0.11.0-nightly-202312210105-edfa58e
|
||||
resolution: "@blocksuite/global@npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global@npm:0.11.0-nightly-202312212326-e2b48df":
|
||||
version: 0.11.0-nightly-202312212326-e2b48df
|
||||
resolution: "@blocksuite/global@npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
dependencies:
|
||||
zod: "npm:^3.22.4"
|
||||
checksum: f1943b1e456197d7e90775cdeda8bab01361f81c665cdcf025efe39c7d1e3f8e370873c80d5fcb02427410b4457a92deb3334d9e7401a47b276bd46714fbcf1a
|
||||
checksum: 3121af8a225e012b836b94c40923227a9d0b999d7c2f68b7eabcaf15fed77788f662a38d87bba664231d591ac363e9cd48b6f234625b938ae674ca4c372d908f
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
@@ -4156,55 +4156,56 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@blocksuite/inline@npm:0.11.0-nightly-202312210105-edfa58e":
|
||||
version: 0.11.0-nightly-202312210105-edfa58e
|
||||
resolution: "@blocksuite/inline@npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/inline@npm:0.11.0-nightly-202312212326-e2b48df":
|
||||
version: 0.11.0-nightly-202312212326-e2b48df
|
||||
resolution: "@blocksuite/inline@npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
dependencies:
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
zod: "npm:^3.22.4"
|
||||
peerDependencies:
|
||||
lit: ^3.0.2
|
||||
yjs: ^13
|
||||
checksum: 066a2141351acbcb0d8a73244057e6d6d900681572cd9cc65226b7e4fba8ad5e4b0ff25aa9a9eade04c2a003d7d9794ce21fd55fade6eac7356c9e4b3fd8be4d
|
||||
checksum: 3ccc79d45731ae1d326d79d9dbc5c3c4583c9b6bd7c67b03565eaca3378242df26351283b0b3ced7ba0c9ccc7e343be3413c1490f71e5e9784017db57f5bde92
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@blocksuite/lit@npm:0.11.0-nightly-202312210105-edfa58e":
|
||||
version: 0.11.0-nightly-202312210105-edfa58e
|
||||
resolution: "@blocksuite/lit@npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit@npm:0.11.0-nightly-202312212326-e2b48df":
|
||||
version: 0.11.0-nightly-202312212326-e2b48df
|
||||
resolution: "@blocksuite/lit@npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
dependencies:
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
lit: "npm:^3.1.0"
|
||||
peerDependencies:
|
||||
"@blocksuite/block-std": 0.11.0-nightly-202312210105-edfa58e
|
||||
"@blocksuite/store": 0.11.0-nightly-202312210105-edfa58e
|
||||
checksum: a736fbd9b8bcbb9e0341943c4a033a526ee6270049db4ba1eef3bfe937283f786b397cc6e086123b1b9d8f6b3f4d94d442722864a2f0ca3f1c6bcdfe9ad08db9
|
||||
"@blocksuite/block-std": 0.11.0-nightly-202312212326-e2b48df
|
||||
"@blocksuite/store": 0.11.0-nightly-202312212326-e2b48df
|
||||
checksum: 53d9b672de67a4d2108d132faa76b74f68e6ae926ce6c4e8de9f13f82d34fe19f619a93c1a347ea69833293c3f365d66684b5cdfe5c0ab066d1f9d5e24959512
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@blocksuite/presets@npm:0.11.0-nightly-202312210105-edfa58e":
|
||||
version: 0.11.0-nightly-202312210105-edfa58e
|
||||
resolution: "@blocksuite/presets@npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/presets@npm:0.11.0-nightly-202312212326-e2b48df":
|
||||
version: 0.11.0-nightly-202312212326-e2b48df
|
||||
resolution: "@blocksuite/presets@npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
dependencies:
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@toeverything/theme": "npm:^0.7.27"
|
||||
lit: "npm:^3.1.0"
|
||||
openai: "npm:^4.20.1"
|
||||
checksum: 471e5f4748dc695cff7bdba939e3cc9f8d9e302442d7b366b03c8a207280c2c2532c3abdd767f041a47a644e23faa7a2860c8a0b28b4530e0b194f076562acbe
|
||||
checksum: 21d3a8e569b8beb6a3a446a814b2aa131eb2f9315dc436943b58ce702a1d6ffdfcfd6371c0de54b7c45e9821d121002820918ce617a0077c9d495f535bf8345e
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@blocksuite/store@npm:0.11.0-nightly-202312210105-edfa58e":
|
||||
version: 0.11.0-nightly-202312210105-edfa58e
|
||||
resolution: "@blocksuite/store@npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store@npm:0.11.0-nightly-202312212326-e2b48df":
|
||||
version: 0.11.0-nightly-202312212326-e2b48df
|
||||
resolution: "@blocksuite/store@npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
dependencies:
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/inline": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@types/flexsearch": "npm:^0.7.3"
|
||||
flexsearch: "npm:0.7.21"
|
||||
idb-keyval: "npm:^6.2.1"
|
||||
@@ -4217,7 +4218,7 @@ __metadata:
|
||||
peerDependencies:
|
||||
async-call-rpc: ^6
|
||||
yjs: ^13
|
||||
checksum: afd08bbb37060102de1cf5d0ce6f14a7197cd7b9f8e8cd306246de61e11122dabe01713e570ee7d4f38c8deed5090a0077bb628ed3421552d7c583da58ca5670
|
||||
checksum: 3666801967eb301ca9df5f605bcb27d6e780e8883af5f9bc964898056c4558d5bbdfe12d24c61eb1ea6d3156ab9687ab28f2b9905dc50d7b54b7fbd9d71029a3
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
@@ -5863,6 +5864,23 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@eslint/eslintrc@npm:^2.1.4":
|
||||
version: 2.1.4
|
||||
resolution: "@eslint/eslintrc@npm:2.1.4"
|
||||
dependencies:
|
||||
ajv: "npm:^6.12.4"
|
||||
debug: "npm:^4.3.2"
|
||||
espree: "npm:^9.6.0"
|
||||
globals: "npm:^13.19.0"
|
||||
ignore: "npm:^5.2.0"
|
||||
import-fresh: "npm:^3.2.1"
|
||||
js-yaml: "npm:^4.1.0"
|
||||
minimatch: "npm:^3.1.2"
|
||||
strip-json-comments: "npm:^3.1.1"
|
||||
checksum: 7a3b14f4b40fc1a22624c3f84d9f467a3d9ea1ca6e9a372116cb92507e485260359465b58e25bcb6c9981b155416b98c9973ad9b796053fd7b3f776a6946bce8
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@eslint/js@npm:8.54.0":
|
||||
version: 8.54.0
|
||||
resolution: "@eslint/js@npm:8.54.0"
|
||||
@@ -11221,9 +11239,9 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@react-hookz/web@npm:^23.1.0":
|
||||
version: 23.1.0
|
||||
resolution: "@react-hookz/web@npm:23.1.0"
|
||||
"@react-hookz/web@npm:^24.0.0":
|
||||
version: 24.0.0
|
||||
resolution: "@react-hookz/web@npm:24.0.0"
|
||||
dependencies:
|
||||
"@react-hookz/deep-equal": "npm:^1.0.4"
|
||||
peerDependencies:
|
||||
@@ -11233,7 +11251,7 @@ __metadata:
|
||||
peerDependenciesMeta:
|
||||
js-cookie:
|
||||
optional: true
|
||||
checksum: 7f345fc286ee3bae74b76b909898213a589250856783805d0356d8ef9ca0e3d1638e7499d8b77ae1dff6350dec230fda468e0e4c8fc05a9997902569d3d81b49
|
||||
checksum: 85ec7ebecf3a69f098fecb89c1515ffd8c119f29a74521277df34af637059320669cf8ff6273063cec6a4c86cee4849e24fa8772191d08f81b2b88de69749670
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
@@ -13726,12 +13744,12 @@ __metadata:
|
||||
"@affine/debug": "workspace:*"
|
||||
"@affine/env": "workspace:*"
|
||||
"@affine/workspace": "workspace:*"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/block-std": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@testing-library/react": "npm:^14.0.0"
|
||||
"@toeverything/infra": "workspace:*"
|
||||
"@types/image-blob-reduce": "npm:^4.1.3"
|
||||
@@ -13782,11 +13800,11 @@ __metadata:
|
||||
"@affine/env": "workspace:*"
|
||||
"@affine/sdk": "workspace:*"
|
||||
"@affine/templates": "workspace:*"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/global": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/lit": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/presets": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@testing-library/react": "npm:^14.0.0"
|
||||
async-call-rpc: "npm:^6.3.1"
|
||||
electron: "link:../../frontend/electron/node_modules/electron"
|
||||
@@ -13835,8 +13853,8 @@ __metadata:
|
||||
version: 0.0.0-use.local
|
||||
resolution: "@toeverything/y-indexeddb@workspace:packages/common/y-indexeddb"
|
||||
dependencies:
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/blocks": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
fake-indexeddb: "npm:^5.0.0"
|
||||
idb: "npm:^8.0.0"
|
||||
nanoid: "npm:^5.0.3"
|
||||
@@ -17329,6 +17347,20 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"browserslist@npm:^4.22.2":
|
||||
version: 4.22.2
|
||||
resolution: "browserslist@npm:4.22.2"
|
||||
dependencies:
|
||||
caniuse-lite: "npm:^1.0.30001565"
|
||||
electron-to-chromium: "npm:^1.4.601"
|
||||
node-releases: "npm:^2.0.14"
|
||||
update-browserslist-db: "npm:^1.0.13"
|
||||
bin:
|
||||
browserslist: cli.js
|
||||
checksum: e3590793db7f66ad3a50817e7b7f195ce61e029bd7187200244db664bfbe0ac832f784e4f6b9c958aef8ea4abe001ae7880b7522682df521f4bc0a5b67660b5e
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"bser@npm:2.1.1":
|
||||
version: 2.1.1
|
||||
resolution: "bser@npm:2.1.1"
|
||||
@@ -17646,6 +17678,13 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"caniuse-lite@npm:^1.0.30001565":
|
||||
version: 1.0.30001570
|
||||
resolution: "caniuse-lite@npm:1.0.30001570"
|
||||
checksum: a9b939e003dd70580cc18bce54627af84f298af7c774415c8d6c99871e7cee13bd8278b67955a979cd338369c73e8821a10b37e607d1fff2fbc8ff92fc489653
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"capital-case@npm:^1.0.4":
|
||||
version: 1.0.4
|
||||
resolution: "capital-case@npm:1.0.4"
|
||||
@@ -17971,7 +18010,7 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"ci-info@npm:^3.2.0, ci-info@npm:^3.8.0":
|
||||
"ci-info@npm:^3.2.0":
|
||||
version: 3.9.0
|
||||
resolution: "ci-info@npm:3.9.0"
|
||||
checksum: 75bc67902b4d1c7b435497adeb91598f6d52a3389398e44294f6601b20cfef32cf2176f7be0eb961d9e085bb333a8a5cae121cb22f81cf238ae7f58eb80e9397
|
||||
@@ -18787,6 +18826,15 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"core-js-compat@npm:^3.34.0":
|
||||
version: 3.34.0
|
||||
resolution: "core-js-compat@npm:3.34.0"
|
||||
dependencies:
|
||||
browserslist: "npm:^4.22.2"
|
||||
checksum: e29571cc524b4966e331b5876567f13c2b82ed48ac9b02784f3156b29ee1cd82fe3e60052d78b017c429eb61969fd238c22684bb29180908d335266179a29155
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"core-js-pure@npm:^3.23.3":
|
||||
version: 3.33.3
|
||||
resolution: "core-js-pure@npm:3.33.3"
|
||||
@@ -20095,6 +20143,13 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"electron-to-chromium@npm:^1.4.601":
|
||||
version: 1.4.615
|
||||
resolution: "electron-to-chromium@npm:1.4.615"
|
||||
checksum: dbf9deb234cbd381a91f41f6c6729cc8b4bed9b1580d6aea589d689d5f2a8aadf88837ef6887e761c143a1e1015f5eb3ae1bd2728a3068fa6a235c16c0fd76ae
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"electron-updater@npm:^6.1.5":
|
||||
version: 6.1.7
|
||||
resolution: "electron-updater@npm:6.1.7"
|
||||
@@ -20916,14 +20971,16 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"eslint-plugin-unicorn@npm:^49.0.0":
|
||||
version: 49.0.0
|
||||
resolution: "eslint-plugin-unicorn@npm:49.0.0"
|
||||
"eslint-plugin-unicorn@npm:^50.0.0":
|
||||
version: 50.0.0
|
||||
resolution: "eslint-plugin-unicorn@npm:50.0.0"
|
||||
dependencies:
|
||||
"@babel/helper-validator-identifier": "npm:^7.22.20"
|
||||
"@eslint-community/eslint-utils": "npm:^4.4.0"
|
||||
ci-info: "npm:^3.8.0"
|
||||
"@eslint/eslintrc": "npm:^2.1.4"
|
||||
ci-info: "npm:^4.0.0"
|
||||
clean-regexp: "npm:^1.0.0"
|
||||
core-js-compat: "npm:^3.34.0"
|
||||
esquery: "npm:^1.5.0"
|
||||
indent-string: "npm:^4.0.0"
|
||||
is-builtin-module: "npm:^3.2.1"
|
||||
@@ -20935,8 +20992,8 @@ __metadata:
|
||||
semver: "npm:^7.5.4"
|
||||
strip-indent: "npm:^3.0.0"
|
||||
peerDependencies:
|
||||
eslint: ">=8.52.0"
|
||||
checksum: 7f73f41356cdf720675998c558ab13872d76302dde3a49661df0b5219fd328627e3d7e418aaa3e94cf8764d1ef8b606f7ea01f019eccc0bf0522def8e6769caa
|
||||
eslint: ">=8.56.0"
|
||||
checksum: 09d069bac3d4c7d3d3d4ddf8a9992718cd1acc6bbba99cfcb0fb581d9dd0d64378c55d6cc5579aadf23d199c53b539a4351446e0855b363c95e8926be15c95e6
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
@@ -29033,6 +29090,13 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"node-releases@npm:^2.0.14":
|
||||
version: 2.0.14
|
||||
resolution: "node-releases@npm:2.0.14"
|
||||
checksum: 0f7607ec7db5ef1dc616899a5f24ae90c869b6a54c2d4f36ff6d84a282ab9343c7ff3ca3670fe4669171bb1e8a9b3e286e1ef1c131f09a83d70554f855d54f24
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"nodemailer@npm:^6.9.7":
|
||||
version: 6.9.7
|
||||
resolution: "nodemailer@npm:6.9.7"
|
||||
@@ -36954,7 +37018,7 @@ __metadata:
|
||||
version: 0.0.0-use.local
|
||||
resolution: "y-provider@workspace:packages/common/y-provider"
|
||||
dependencies:
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312210105-edfa58e"
|
||||
"@blocksuite/store": "npm:0.11.0-nightly-202312212326-e2b48df"
|
||||
vite: "npm:^5.0.6"
|
||||
vite-plugin-dts: "npm:3.6.0"
|
||||
vitest: "npm:1.0.4"
|
||||
|
||||
Reference in New Issue
Block a user