From 0f9cdca779521fde4b4d378f4b9a9a23b55c476f Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 15:19:13 +0800 Subject: [PATCH 01/10] Fix 6022 notion.Auth() bug. --- src/service/export.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/service/export.js b/src/service/export.js index d49744e2b..4bfbbff24 100644 --- a/src/service/export.js +++ b/src/service/export.js @@ -1290,6 +1290,7 @@ class Notion { /** * 读取所有收藏空间,并创建映射。 */ + if ( !result.recordMap.collection ) result.recordMap.collection = {}; const collectionMaps = {}; Object.values( result.recordMap.collection @@ -1339,7 +1340,7 @@ class Notion { if (type == 'page') { _spaceBlocks.push({ - name : '  ' + this.getBlockName( blockValue.properties.title ), + name : '  ' + this.getBlockName( blockValue.properties && blockValue.properties.title || undefined ), value: id, type : 'page', }); From 7753bf2fd50773e54267e3032fe39670f096c55e Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 15:32:31 +0800 Subject: [PATCH 02/10] Optimize notion.Auth() workflow and add notion.getBlocks(). --- src/service/export.js | 176 ++++++++++++++++++++++-------------------- 1 file changed, 92 insertions(+), 84 deletions(-) diff --git a/src/service/export.js b/src/service/export.js index 4bfbbff24..c9b16a157 100644 --- a/src/service/export.js +++ b/src/service/export.js @@ -1264,6 +1264,94 @@ class Notion { return generateUuid(); } + getBlocks( result ) { + /** + * 读取所有空间,并创建映射。 + */ + const spaceMaps = {} + Object.values( result.recordMap.space ).forEach(({ value: spaceValue, role }) => { + if (!this.hasWriteRule(role)) return; + spaceMaps[spaceValue.id] = { + name : spaceValue.name, + value : spaceValue.id, + type : 'space', + blocks: [], + } + }); + + /** + * 读取所有收藏空间,并创建映射。 + */ + if ( !result.recordMap.collection ) result.recordMap.collection = {}; + const collectionMaps = {}; + Object.values( + result.recordMap.collection + ).forEach(({ value: collectionValue, role }) => { + if (!this.hasWriteRule(role)) return; + collectionMaps[ collectionValue.parent_id ] = collectionValue; + collectionMaps[ collectionValue.id ] = collectionValue; + }) + + /** + * 遍历所有当前用户能看到的空间。 + */ + const processCollection = ( id, spaceBlocks ) => { + const collection = collectionMaps[id]; + if ( !collection ) return; + + let schemaKey; + Object.keys( collection.schema ).some( key => { + const schema = collection.schema[key]; + if ( schema.type === 'url' && schema.name === 'URL' ) { + schemaKey = key; + return true; + } + return false; + }) + + const block = { + name : '  ' + this.getBlockName( collection.name ), + value : collection.id, + type : 'collection', + }; + schemaKey && ( block.schema = schemaKey ); + spaceBlocks.push( block ); + } + Object.values( result.recordMap.block ).forEach( ({ role, value: blockValue }) => { + if ( !this.hasWriteRule( role )) return; + const { + type, + space_id, + parent_id, + id, + collection_id, + } = blockValue; + + const _space = space_id ? spaceMaps[space_id] : spaceMaps[parent_id], + _spaceBlocks = _space ? _space.blocks : this.blocks; + + if (type == 'page') { + _spaceBlocks.push({ + name : '  ' + this.getBlockName( blockValue.properties && blockValue.properties.title || undefined ), + value: id, + type : 'page', + }); + } else if ( type == 'collection_view_page' ) { + processCollection( id, _spaceBlocks ); + } else if ( type == 'collection_view' ) { + processCollection( collection_id, _spaceBlocks ); + } + }); + + Object.values( spaceMaps ).forEach( space => { + const { blocks, ...spaceAttr } = space; + if ( blocks && blocks.length > 0 ) { + this.blocks.push({ name: spaceAttr.name, type: blocks[0].type, value: blocks[0].value }); + this.blocks.push( ...blocks ); + } + }); + } + Auth( callback ) { $.ajax({ url : this.url + "api/v3/loadUserContent", @@ -1273,91 +1361,11 @@ class Notion { this.access_token = Object.values( result.recordMap.notion_user )[0].value.id; this.blocks = []; - /** - * 读取所有空间,并创建映射。 - */ - const spaceMaps = {} - Object.values( result.recordMap.space ).forEach(({ value: spaceValue, role }) => { - if (!this.hasWriteRule(role)) return; - spaceMaps[spaceValue.id] = { - name : spaceValue.name, - value : spaceValue.id, - type : 'space', - blocks: [], - } - }); - - /** - * 读取所有收藏空间,并创建映射。 - */ - if ( !result.recordMap.collection ) result.recordMap.collection = {}; - const collectionMaps = {}; - Object.values( - result.recordMap.collection - ).forEach(({ value: collectionValue, role }) => { - if (!this.hasWriteRule(role)) return; - collectionMaps[ collectionValue.parent_id ] = collectionValue; - collectionMaps[ collectionValue.id ] = collectionValue; - }) - - /** - * 遍历所有当前用户能看到的空间。 - */ - const processCollection = ( id, spaceBlocks ) => { - const collection = collectionMaps[id]; - if ( !collection ) return; - - let schemaKey; - Object.keys( collection.schema ).some( key => { - const schema = collection.schema[key]; - if ( schema.type === 'url' && schema.name === 'URL' ) { - schemaKey = key; - return true; - } - return false; - }) - - const block = { - name : '  ' + this.getBlockName( collection.name ), - value : collection.id, - type : 'collection', - }; - schemaKey && ( block.schema = schemaKey ); - spaceBlocks.push( block ); + try { + this.getBlocks( result ); + } catch ( error ) { + // TO-DO } - Object.values( result.recordMap.block ).forEach( ({ role, value: blockValue }) => { - if ( !this.hasWriteRule( role )) return; - const { - type, - space_id, - parent_id, - id, - collection_id, - } = blockValue; - - const _space = space_id ? spaceMaps[space_id] : spaceMaps[parent_id], - _spaceBlocks = _space ? _space.blocks : this.blocks; - - if (type == 'page') { - _spaceBlocks.push({ - name : '  ' + this.getBlockName( blockValue.properties && blockValue.properties.title || undefined ), - value: id, - type : 'page', - }); - } else if ( type == 'collection_view_page' ) { - processCollection( id, _spaceBlocks ); - } else if ( type == 'collection_view' ) { - processCollection( collection_id, _spaceBlocks ); - } - }); - - Object.values( spaceMaps ).forEach( space => { - const { blocks, ...spaceAttr } = space; - if ( blocks && blocks.length > 0 ) { - this.blocks.push({ name: spaceAttr.name, type: blocks[0].type, value: blocks[0].value }); - this.blocks.push( ...blocks ); - } - }); this.type = this.blocks[0].type; this.folder_id = this.blocks[0].value; From 26fef632ff11cc7b812f7528d24e466a9f80231b Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 16:07:50 +0800 Subject: [PATCH 03/10] Add notion.Auth() error get first block workflow. --- src/service/export.js | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/src/service/export.js b/src/service/export.js index c9b16a157..f47c8aa22 100644 --- a/src/service/export.js +++ b/src/service/export.js @@ -1352,6 +1352,19 @@ class Notion { }); } + getFirstBlock( result ) { + const blocks = Object.values( result.recordMap.block ); + for ( let i = 0; i < blocks.length; i++ ) { + const block = blocks[i].value, + role = blocks[i].role; + if ( [ "page", "collection_view" ].includes( block.type ) && this.hasWriteRule( role )) { + const name = block.properties && block.properties.title && block.properties.title[0][0] || "Undefined"; + this.blocks.push({ name, value: block.id, type: block.type }); + break; + } + } + } + Auth( callback ) { $.ajax({ url : this.url + "api/v3/loadUserContent", @@ -1364,7 +1377,13 @@ class Notion { try { this.getBlocks( result ); } catch ( error ) { - // TO-DO + console.warn( error ) + this.getFirstBlock( result ); + } + + if ( this.blocks.length == 0 ) { + callback( undefined, `Notion.so 并未提供 API 所以会出现授权失败的情况,如发生此问题,请提 Issues` ); + return; } this.type = this.blocks[0].type; From b319810e6c7d4ced452cb9bb756f18379f99210b Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 16:13:48 +0800 Subject: [PATCH 04/10] Add notion.Auth() success props set logic. --- src/module/authorize.jsx | 2 +- src/service/export.js | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/module/authorize.jsx b/src/module/authorize.jsx index 15480608a..f1a3a386b 100644 --- a/src/module/authorize.jsx +++ b/src/module/authorize.jsx @@ -242,7 +242,7 @@ export default class Auth extends React.Component { case "notion": notion.Auth( ( result, error ) => { if ( error ) failed( error, notion.id, notion.name ); - else success( notion.id, notion.name, { access_token: notion.access_token, folder_id: notion.folder_id }); + else success( notion.id, notion.name, { access_token: notion.access_token, folder_id: notion.folder_id, save_image: notion.save_image, type: notion.type }); }); break; case "youdao": diff --git a/src/service/export.js b/src/service/export.js index f47c8aa22..165387ecc 100644 --- a/src/service/export.js +++ b/src/service/export.js @@ -1388,6 +1388,7 @@ class Notion { this.type = this.blocks[0].type; this.folder_id = this.blocks[0].value; + this.save_image = false; callback( result, undefined ); } }).fail( ( xhr, status, error ) => { From cb45fbbe7e388b7c42c1dbf157be605edeb9c421 Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 18:29:50 +0800 Subject: [PATCH 05/10] Update version shields. --- src/module/about.jsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/module/about.jsx b/src/module/about.jsx index fe87c0eb7..2b31ac216 100644 --- a/src/module/about.jsx +++ b/src/module/about.jsx @@ -58,7 +58,7 @@ urls = { }, badges: { - version: "", + version: "", website: "", githubstar: "", changelog: "", From 304de85f5967b2eeab21b74818ac1190fc0b31ad Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 18:33:42 +0800 Subject: [PATCH 06/10] Add notion.Auth() callback warn workflow. --- src/module/authorize.jsx | 18 ++++++++++++++---- src/service/export.js | 4 +++- 2 files changed, 17 insertions(+), 5 deletions(-) diff --git a/src/module/authorize.jsx b/src/module/authorize.jsx index f1a3a386b..003e6024d 100644 --- a/src/module/authorize.jsx +++ b/src/module/authorize.jsx @@ -240,9 +240,12 @@ export default class Auth extends React.Component { }).fail( error => failed( error, yuque.id, yuque.name )); break; case "notion": - notion.Auth( ( result, error ) => { + notion.Auth( ( result, error, warn ) => { if ( error ) failed( error, notion.id, notion.name ); - else success( notion.id, notion.name, { access_token: notion.access_token, folder_id: notion.folder_id, save_image: notion.save_image, type: notion.type }); + else { + warn != "" && new Notify().Render({ type: 2, content: `请注意:授权时出现了问题导致 仅成功授权了 您的第一个 Notion Page 虽然不影响导出服务,但建议提 Issues`, state: "holdon" }); + success( notion.id, notion.name, { access_token: notion.access_token, folder_id: notion.folder_id, save_image: notion.save_image, type: notion.type }); + } }); break; case "youdao": @@ -321,8 +324,15 @@ export default class Auth extends React.Component { } notionChange() { - exp.notion.Auth( ( result, error ) => { - this.setState({ secret: storage.secret, notion: exp.notion.blocks }); + const notify = new Notify().Render({ state: "loading", content: `正在获取 Notion Page ,请稍等` }); + exp.notion.Auth( ( result, error, warn ) => { + notify.complete(); + if ( error ) new Notify().Render({ type: 2, content: `Notion.so 并未提供 API 所以会出现 获取失败的情况,如发生此问题,请提 Issues`, state: "holdon" }); + else { + warn != "" && new Notify().Render({ type: 2, content: `请注意:获取时出现了问题导致 仅成功获取了 您的第一个 Notion Page 虽然不影响导出服务,但建议提 Issues`, state: "holdon" }); + warn == "" && new Notify().Render( 1, "获取成功,请选择导出的 Notion Page" ); + this.setState({ secret: storage.secret, notion: exp.notion.blocks }); + } }); } diff --git a/src/service/export.js b/src/service/export.js index 165387ecc..12dcce91d 100644 --- a/src/service/export.js +++ b/src/service/export.js @@ -1366,6 +1366,7 @@ class Notion { } Auth( callback ) { + let warn = ""; $.ajax({ url : this.url + "api/v3/loadUserContent", type : "POST", @@ -1378,6 +1379,7 @@ class Notion { this.getBlocks( result ); } catch ( error ) { console.warn( error ) + warn = error; this.getFirstBlock( result ); } @@ -1389,7 +1391,7 @@ class Notion { this.type = this.blocks[0].type; this.folder_id = this.blocks[0].value; this.save_image = false; - callback( result, undefined ); + callback( result, undefined, warn ); } }).fail( ( xhr, status, error ) => { console.error( error, status, xhr ) From 075cefd83323e955bd0da6e91be455569304fb31 Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 18:36:21 +0800 Subject: [PATCH 07/10] Format source. --- src/service/export.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/service/export.js b/src/service/export.js index 12dcce91d..7745e3b2f 100644 --- a/src/service/export.js +++ b/src/service/export.js @@ -1384,7 +1384,7 @@ class Notion { } if ( this.blocks.length == 0 ) { - callback( undefined, `Notion.so 并未提供 API 所以会出现授权失败的情况,如发生此问题,请提 Issues` ); + callback( undefined, `Notion.so 并未提供 API 所以会出现授权失败的情况,如发生此问题,请提 Issues` ); return; } From e0dff00f2725041a90122fb3e2efc8471cc04efd Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 18:39:34 +0800 Subject: [PATCH 08/10] Format source. --- src/module/authorize.jsx | 1 + 1 file changed, 1 insertion(+) diff --git a/src/module/authorize.jsx b/src/module/authorize.jsx index 003e6024d..94a1c90c5 100644 --- a/src/module/authorize.jsx +++ b/src/module/authorize.jsx @@ -549,6 +549,7 @@ export default class Auth extends React.Component { onChange={ (s)=>this.save( "notion_save_image", s ) } /> } +
Date: Wed, 24 Jun 2020 18:47:35 +0800 Subject: [PATCH 09/10] Add notion auth notice. --- src/module/authorize.jsx | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/module/authorize.jsx b/src/module/authorize.jsx index 94a1c90c5..7cf964048 100644 --- a/src/module/authorize.jsx +++ b/src/module/authorize.jsx @@ -547,6 +547,8 @@ export default class Auth extends React.Component { label="是否使用 Notion.so 作为图床?" desc="由于 Notion 并未公开 API 所以此方式较慢。" onChange={ (s)=>this.save( "notion_save_image", s ) } /> + + 注意:由于 Notion.so 暂未提供 API 所以会出现 授权获取 Notion Page 失败的情况,如遇到此情况,请提 Issues
} From d534d7dd07f4575dc7cd22564136cdcbd398cc7b Mon Sep 17 00:00:00 2001 From: Kenshin Date: Wed, 24 Jun 2020 18:48:01 +0800 Subject: [PATCH 10/10] Update version to 1.1.4.6025. --- src/manifest.json | 2 +- src/service/version.js | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/src/manifest.json b/src/manifest.json index d1607b598..edbb471fb 100644 --- a/src/manifest.json +++ b/src/manifest.json @@ -1,7 +1,7 @@ { "name" : "__MSG_extension_name__", "default_locale" : "en", - "version" : "1.1.4.6022", + "version" : "1.1.4.6025", "short_name" : "SimpRead", "description" : "__MSG_extension_desc__", "homepage_url" : "http://ksria.com/simpread", diff --git a/src/service/version.js b/src/service/version.js index e6c3d1af7..691a0b1a1 100644 --- a/src/service/version.js +++ b/src/service/version.js @@ -38,6 +38,7 @@ const version = browser.runtime.getManifest().version.replace( /.\d{2,}/, "" ), patchs = new Map([ [ "1.1.4.6016", "修复 Notion 相关问题,并支持 Database 导出方案," ], [ "1.1.4.6022", "修复 Notion 授权问题,并支持 图床 导出方案," ], + [ "1.1.4.6025", "修复 Notion 授权问题," ], ]), tips = { "root" : value => `.version-tips[data-hits='${value}']`,