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 \n \n \n \n \n \n
\n
\n
\n <% for (let result of results) { %>\n
\" data-path=\"<%- result.path %>\">\n \n <%- this.get_icon('right-triangle') %>\n \" draggable=\"true\">\n <%- [result.score?.toFixed(2), result.name].join(' | ') %>\n \n \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 \n \n \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 \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 <% } %>\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

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 \n \n \n \n \n \n
\n
\n
\n <% for (let result of results) { %>\n
\" data-path=\"<%- result.path.replace(/\"/g, '"') %>\">\n \n <%- this.get_icon('right-triangle') %>\n \" draggable=\"true\">\n <%- [result.score?.toFixed(2), result.name].join(' | ') %>\n \n \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 \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": {