diff --git a/build/views.json b/build/views.json
index c4c5b33a..db13baf6 100644
--- a/build/views.json
+++ b/build/views.json
@@ -5,9 +5,7 @@
"smart_chat_msg": "
\">\n
\">\n <%= content %> \n <%- this.get_icon('copy') %> \n \n \n
\n
",
"smart_chat_settings": "Current: my, I, me, mine, our, ours, us, we\"\n data-option-1=\"en|English\"\n data-option-2=\"es|Spanish\"\n data-option-3=\"fr|French\"\n data-option-4=\"de|German\"\n data-option-5=\"it|Italian\"\n data-callback=\"update_language\"\n>
\n `data-option-${i + 1}=\"${platform.key}|${platform.description}\"`).join('\\n') %>\n data-callback=\"changed_smart_chat_model\"\n>
\n<% if(chat_platform?.fetch_models) { %>\n <% if(settings[settings.chat_model_platform_key]?.api_key) { %>\n .model_name\"\n data-callback=\"changed_smart_chat_model\"\n <%- platform_chat_models.map((model, i) => `data-option-${i}=\"${model.key}|${model.model_name} (${model.description})\"`).join('\\n') %>\n >
\n <% } %>\n <% if(!platform_chat_models.length) { %>\n
\n <% } %>\n API Key\"\n data-type=\"password\"\n data-setting=\"<%= settings.chat_model_platform_key %>.api_key\"\n <% if(chat_platform.signup_url) { %>\n data-description=\"
Get API Key for <%= chat_platform.description %>.\"\n <% } else { %>\n data-description=\"API Key for <%= chat_platform.description %>.\"\n <% } %>\n data-placeholder=\"Enter an API Key\"\n data-button=\"Save\"\n data-callback=\"test_chat_api_key\"\n >
\n<% } %>\n<% if (settings.chat_model_platform_key.startsWith('custom_local')) { %>\n Custom Local Model \n
\n
\n
\n
\n
\n
\n
\n<% } else if(settings.chat_model_platform_key.startsWith('custom_api')) { %>\n Custom Server \n
\n
\n
\n
\n
\n
\n
\n<% } %>",
"smart_chat_system_msg": "\">\n
\">\n <%= content %> \n
\n
",
- "smart_connections": "\n
\">\n <%- this.notes_ct %> (<%- this.blocks_ct %>)\n
\n
<%- this.get_icon('refresh-cw') %> \n
<%- this.get_icon('fold-vertical') %> \n
<%- this.get_icon('unfold-vertical') %> \n
<%- this.get_icon('sliders-horizontal') %> \n
<%- this.get_icon('search') %> \n \n
\n
\n\n <% for (let result of results) { %>\n
\" data-path=\"<%- result.path %>\">\n \n
\n \" data-collection=\"<%= result.collection_key %>\"> \n \n
\n <% } %>\n
\n\n \" title=\"<%- current_path %>\">\n <%- current_path.split('/').pop().split('.').shift() %><%- typeof re_ranked !== 'undefined' && re_ranked ? ' (re-ranked)' : '' %>\n \n <%- this.attribution %>\n
",
- "smart_note_inspect": "Blocks \n<% if(note.blocks.length === 0) { %>\n No blocks
\n<% } %>\n<% for(let block of note.blocks) { %>\n\n <%- (await block.get_embed_input()).replace(//g, \">\").replace(/\\n/g, \" \") %>\n \n \n<% } %>\n\n",
- "smart_settings": "\n
Smart Connections \n <% if(env.smart_connections_plugin.EARLY_ACCESS && !env.smart_connections_plugin.app.plugins.enabledPlugins.has(\"smart-templates\")){ %>\n \n <% } %>\n <% if(env.smart_connections_plugin.obsidian.Platform.isMobile && !env.smart_connections_plugin.settings.enable_mobile) { %>\n
\n
\n
\n
Mobile is DISABLED.
\n
\n
\n
Toggle \"Enable mobile\" setting to activate mobile.
\n
\n
\n <% } %>\n \n
\n
\n
\n
User Agreement: By using Smart Connections you agree to share how it helps you with at least one other person 😊🌴
\n
\n
\n
\n
Supporter Community \n <% if(!env.smart_connections_plugin.EARLY_ACCESS){ %>\n
The success of Smart Connections is a direct result of our community of supporters who generously fund and evaluate new features. Their unwavering commitment to our privacy-focused, open-source software benefits all. Together, we can continue to innovate and make a positive impact on the world.
\n
Supporter benefits include:
\n
\n Early access to new & experimental features:\n \n Early access to new versions enables supporters to help ensure new features are ready for the broader community. \n Available in v2.2 (Early Access): \n 🖼️ Add images to Smart Chat (multimodal) \n Re-ranking model in the Smart Connections View \n \n Coming soon to v2.3 (Early Access): \n PDF Support in Smart Connections view \n Edit notes in Smart Chat \n New retrieval methods in Smart Chat \n Review retrieved context before sending in Smart Chat \n Audio files in Smart Connections view \n \n \n \n Access to the supporter-only private chat :\n \n Community: \n \n Ask questions and share insights with other supporters. \n \n \n Help & Support (priority): \n \n \n Feature Requests (priority): \n \n Influence the future of Smart Connections with priority feature requests in the Supporter Chat . \n \n \n Insider Updates: \n \n Learn about the latest features & improvements before they are announced. \n \n \n \n \n For a very limited time: Early access to Smart Connect: Use ChatGPT with your notes without uploading your notes to the cloud using Smart Connect - Obsidian GPT. \n \n <% } %>\n
\n
\n
\n <% if(!env.smart_connections_plugin.EARLY_ACCESS){ %>\n
\n
\n <% } %>\n
\n
Smart View & Embeddings \n
Notes about embedding models:
\n
\n IMPORTANT: make sure local BGE-micro-v2
embedding model works before trying other local models. \n Local model compatibility depends on available CPU and RAM. Try reducing the max tokens (context) if a local model if failing. \n API models are not dependent on local compute, but they require an API key and send your notes to third-party servers for processing. \n \n
Notes embeddings \n
\n
Blocks (excerpts) embeddings \n
\n
\n
\n
\n \n
Smart Chat \n
\n Additional settings available in the Smart Chat settings tab (ex. chat model and api key). \n
\n \n <% \n env.smart_connections_plugin.settings.smart_chat_folder_last = env.smart_connections_plugin.settings.smart_chat_folder;\n %>\n
. to hide it (ex. .smart-chats
).\"\n data-type=\"text\"\n data-setting=\"smart_connections_plugin.smart_chat_folder\"\n data-placeholder=\"Enter a folder name\"\n >
\n
System Prompts \n
\n
Data management \n
Included files: <%= included_files %> / Total files: <%= total_files %>
\n
\n
\n
\n
\n <%\n env.smart_connections_plugin.settings.env_data_dir_last = env.smart_connections_plugin.settings.env_data_dir; // ensure env_data_dir_last is up-to-date\n %>\n
\n
Muted Notices \n <% if(Object.keys(env.settings.smart_notices.muted).length) { %>\n <% for(const notice in env.settings.smart_notices.muted) { %>\n
\"\n data-setting=\"smart_notices.muted.<%= notice %>\"\n data-type=\"remove\"\n data-btn-text=\"Unmute\"\n >
\n <% } %>\n <% } else { %>\n
No muted notices.
\n <% } %>\n
\n
\n <% if(env.smart_connections_plugin.EARLY_ACCESS){ %>\n
\n
\n <% } %>\n
\n \n \n ",
- "smart_view_filter": "\n<% if(is_early_access) { %>\n
\n<% } %>\n<% if(is_early_access && settings.smart_view_filter?.re_rank) { %>\n
\n<% } %>\n\n
\n\n
\n\n
\n\n
\n\n",
+ "smart_connections": "\n
\">\n <%- this.notes_ct %> (<%- this.blocks_ct %>)\n
\n
<%- this.get_icon('refresh-cw') %> \n
<%- this.get_icon('fold-vertical') %> \n
<%- this.get_icon('unfold-vertical') %> \n
<%- this.get_icon('sliders-horizontal') %> \n
<%- this.get_icon('search') %> \n \n
\n
\n\n <% for (let result of results) { %>\n
\" data-path=\"<%- result.path.replace(/\"/g, '"') %>\">\n \n
\n \" data-collection=\"<%= result.collection_key %>\"> \n \n
\n <% } %>\n
\n\n \" title=\"<%- current_path %>\">\n <%- current_path.split('/').pop().split('.').shift() %><%- typeof re_ranked !== 'undefined' && re_ranked ? ' (re-ranked)' : '' %>\n \n <%- this.attribution %>\n
",
+ "smart_note_inspect": "Blocks \n<% if(note.blocks.length === 0) { %>\n No blocks
\n<% } %>\n<% for(let block of note.blocks.sort((a, b) => a.sub_key.localeCompare(b.sub_key))) { %>\n\n <%- block.sub_key.split(\"#\").join(\" > \") + \" (\" + block.size + \" chars)\" %>\n \n <%- block.should_embed ? \"should embed \" : \"embedding skipped \" %>\n
\n\n <%- (await block.read())\n .replace(//g, \">\")\n .replace(/\\n/g, \" \")\n .replace(/\\t/g, \" \")\n %>\n \n \n<% } %>\n\n",
"smart_view_search": "\n
Search Smart Connections \n
\n \n <%- this.get_icon('search') %> \n
\n
Use semantic (embeddings) search to surface relevant notes. Results are sorted by similarity to your query. Note: returns different results than lexical (keyword) search.
\n
\n\n"
}
\ No newline at end of file
diff --git a/package-lock.json b/package-lock.json
index d237d736..31c2da96 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -20,7 +20,8 @@
"smart-file-system": "file:../jsbrains/smart-fs",
"smart-instruct-model": "file:../jsbrains/smart-instruct-model",
"smart-setting": "file:../jsbrains/smart-setting",
- "smart-sources": "file:../jsbrains/smart-sources-v1",
+ "smart-settings": "file:../jsbrains/smart-settings",
+ "smart-sources": "file:../jsbrains/smart-sources",
"smart-view": "file:../jsbrains/smart-view"
},
"devDependencies": {
@@ -164,9 +165,15 @@
"version": "1.0.1",
"license": "MIT"
},
+ "../jsbrains/smart-settings": {
+ "version": "1.0.0",
+ "license": "MIT",
+ "devDependencies": {
+ "ava": "^6.0.1"
+ }
+ },
"../jsbrains/smart-sources": {
"version": "2.0.0",
- "extraneous": true,
"license": "MIT",
"dependencies": {
"smart-entities": "file:../smart-entities"
@@ -178,12 +185,17 @@
"../jsbrains/smart-sources-v1": {
"name": "smart-sources",
"version": "2.0.0",
+ "extraneous": true,
"license": "MIT",
"dependencies": {
+ "pdf-lib": "^1.17.1",
+ "sharp": "^0.33.5",
"smart-entities": "file:../smart-entities"
},
"devDependencies": {
- "ava": "^6.0.1"
+ "ava": "^6.0.1",
+ "canvas": "^2.11.2",
+ "pdfjs-dist-legacy": "^1.0.1"
}
},
"../jsbrains/smart-view": {
@@ -3572,8 +3584,12 @@
"resolved": "../jsbrains/smart-setting",
"link": true
},
+ "node_modules/smart-settings": {
+ "resolved": "../jsbrains/smart-settings",
+ "link": true
+ },
"node_modules/smart-sources": {
- "resolved": "../jsbrains/smart-sources-v1",
+ "resolved": "../jsbrains/smart-sources",
"link": true
},
"node_modules/smart-view": {