mirror of
				https://github.com/SillyTavern/SillyTavern.git
				synced 2025-06-05 21:59:27 +02:00 
			
		
		
		
	Merge branch 'staging' into vectors
This commit is contained in:
		| @@ -3233,9 +3233,16 @@ | |||||||
|                             <h2></h2> |                             <h2></h2> | ||||||
|                         </div> |                         </div> | ||||||
|                         <div id="result_info" class="flex-container" style="display: none;"> |                         <div id="result_info" class="flex-container" style="display: none;"> | ||||||
|                             <span id="result_info_text" title="Token counts may be inaccurate and provided just for reference." data-i18n="[title]Token counts may be inaccurate and provided just for reference."> |                             <div id="result_info_text" title="Token counts may be inaccurate and provided just for reference." data-i18n="[title]Token counts may be inaccurate and provided just for reference."> | ||||||
|                                 <strong id="result_info_total_tokens">Calculating...</strong> Total Tokens |                                 <div> | ||||||
|                             </span> |                                     <strong id="result_info_total_tokens" title="Total tokens">Calculating...</strong> <span data-i18n="Tokens">Tokens</span> | ||||||
|  |                                 </div> | ||||||
|  |                                 <div> | ||||||
|  |                                     <small title="Permanent tokens"> | ||||||
|  |                                         (<span id="result_info_permanent_tokens"></span> <span data-i18n="Permanent">Permanent</span>) | ||||||
|  |                                     </small> | ||||||
|  |                                 </div> | ||||||
|  |                             </div> | ||||||
|                             <a id="chartokenwarning" class="right_menu_button fa-solid fa-triangle-exclamation" href="https://docs.sillytavern.app/usage/core-concepts/characterdesign/#character-tokens" target="_blank" title="About Token 'Limits'"></a> |                             <a id="chartokenwarning" class="right_menu_button fa-solid fa-triangle-exclamation" href="https://docs.sillytavern.app/usage/core-concepts/characterdesign/#character-tokens" target="_blank" title="About Token 'Limits'"></a> | ||||||
|                             <i title="Click for stats!" class="fa-solid fa-ranking-star right_menu_button rm_stats_button"></i> |                             <i title="Click for stats!" class="fa-solid fa-ranking-star right_menu_button rm_stats_button"></i> | ||||||
|                             <i title="Toggle character info panel" id="hideCharPanelAvatarButton" class="fa-solid fa-eye right_menu_button"></i> |                             <i title="Toggle character info panel" id="hideCharPanelAvatarButton" class="fa-solid fa-eye right_menu_button"></i> | ||||||
| @@ -3251,7 +3258,7 @@ | |||||||
|                             <div id="name_div"> |                             <div id="name_div"> | ||||||
|                                 <input id="character_name_pole" name="ch_name" class="text_pole" data-i18n="[placeholder]Name this character" placeholder="Name this character" maxlength="50" value="" autocomplete="off"> |                                 <input id="character_name_pole" name="ch_name" class="text_pole" data-i18n="[placeholder]Name this character" placeholder="Name this character" maxlength="50" value="" autocomplete="off"> | ||||||
|                                 <div class="extension_token_counter"> |                                 <div class="extension_token_counter"> | ||||||
|                                     Tokens: <span data-token-counter="character_name_pole">counting...</span> |                                     Tokens: <span data-token-counter="character_name_pole" data-token-permanent="true">counting...</span> | ||||||
|                                 </div> |                                 </div> | ||||||
|                             </div> |                             </div> | ||||||
|  |  | ||||||
| @@ -3333,7 +3340,7 @@ | |||||||
|  |  | ||||||
|                         <textarea id="description_textarea" data-i18n="[placeholder]Describe your character's physical and mental traits here." placeholder="Describe your character's physical and mental traits here." class="marginBot5" name="description" placeholder=""></textarea> |                         <textarea id="description_textarea" data-i18n="[placeholder]Describe your character's physical and mental traits here." placeholder="Describe your character's physical and mental traits here." class="marginBot5" name="description" placeholder=""></textarea> | ||||||
|                         <div class="extension_token_counter"> |                         <div class="extension_token_counter"> | ||||||
|                             Tokens: <span data-token-counter="description_textarea">counting...</span> |                             Tokens: <span data-token-counter="description_textarea" data-token-permanent="true">counting...</span> | ||||||
|                         </div> |                         </div> | ||||||
|  |  | ||||||
|                         <div id="first_message_div" class="marginBot5 title_restorable"> |                         <div id="first_message_div" class="marginBot5 title_restorable"> | ||||||
| @@ -3617,7 +3624,7 @@ | |||||||
|             </h4> |             </h4> | ||||||
|             <textarea id="personality_textarea" name="personality" data-i18n="[placeholder](A brief description of the personality)" placeholder="(A brief description of the personality)" form="form_create" class="text_pole" autocomplete="off" rows="1" maxlength="20000"></textarea> |             <textarea id="personality_textarea" name="personality" data-i18n="[placeholder](A brief description of the personality)" placeholder="(A brief description of the personality)" form="form_create" class="text_pole" autocomplete="off" rows="1" maxlength="20000"></textarea> | ||||||
|             <div class="extension_token_counter"> |             <div class="extension_token_counter"> | ||||||
|                 Tokens: <span data-token-counter="personality_textarea">counting...</span> |                 Tokens: <span data-token-counter="personality_textarea" data-token-permanent="true">counting...</span> | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|  |  | ||||||
| @@ -3630,7 +3637,7 @@ | |||||||
|             </h4> |             </h4> | ||||||
|             <textarea id="scenario_pole" name="scenario" data-i18n="[placeholder](Circumstances and context of the interaction)" placeholder="(Circumstances and context of the interaction)" class="text_pole" maxlength="20000" value="" autocomplete="off" form="form_create" rows="1"></textarea> |             <textarea id="scenario_pole" name="scenario" data-i18n="[placeholder](Circumstances and context of the interaction)" placeholder="(Circumstances and context of the interaction)" class="text_pole" maxlength="20000" value="" autocomplete="off" form="form_create" rows="1"></textarea> | ||||||
|             <div class="extension_token_counter"> |             <div class="extension_token_counter"> | ||||||
|                 Tokens: <span data-token-counter="scenario_pole">counting...</span> |                 Tokens: <span data-token-counter="scenario_pole" data-token-permanent="true">counting...</span> | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3418,7 +3418,7 @@ function parseTokenCounts(counts, thisPromptBits) { | |||||||
|  |  | ||||||
| function addChatsPreamble(mesSendString) { | function addChatsPreamble(mesSendString) { | ||||||
|     return main_api === 'novel' |     return main_api === 'novel' | ||||||
|         ? nai_settings.preamble + '\n' + mesSendString |         ? substituteParams(nai_settings.preamble) + '\n' + mesSendString | ||||||
|         : mesSendString; |         : mesSendString; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -8478,6 +8478,7 @@ jQuery(async function () { | |||||||
|             '#world_popup', |             '#world_popup', | ||||||
|             '.ui-widget', |             '.ui-widget', | ||||||
|             '.text_pole', |             '.text_pole', | ||||||
|  |             '#toast-container', | ||||||
|         ]; |         ]; | ||||||
|         for (const id of forbiddenTargets) { |         for (const id of forbiddenTargets) { | ||||||
|             if (clickTarget.closest(id).length > 0) { |             if (clickTarget.closest(id).length > 0) { | ||||||
|   | |||||||
| @@ -210,10 +210,12 @@ $("#character_popup").on("input", function () { countTokensDebounced(); }); | |||||||
| //function: | //function: | ||||||
| export function RA_CountCharTokens() { | export function RA_CountCharTokens() { | ||||||
|     let total_tokens = 0; |     let total_tokens = 0; | ||||||
|  |     let permanent_tokens = 0; | ||||||
|  |  | ||||||
|     $('[data-token-counter]').each(function () { |     $('[data-token-counter]').each(function () { | ||||||
|         const counter = $(this); |         const counter = $(this); | ||||||
|         const input = $(document.getElementById(counter.data('token-counter'))); |         const input = $(document.getElementById(counter.data('token-counter'))); | ||||||
|  |         const isPermanent = counter.data('token-permanent') === true; | ||||||
|         const value = String(input.val()); |         const value = String(input.val()); | ||||||
|  |  | ||||||
|         if (input.length === 0) { |         if (input.length === 0) { | ||||||
| @@ -230,10 +232,12 @@ export function RA_CountCharTokens() { | |||||||
|  |  | ||||||
|         if (input.data('last-value-hash') === valueHash) { |         if (input.data('last-value-hash') === valueHash) { | ||||||
|             total_tokens += Number(counter.text()); |             total_tokens += Number(counter.text()); | ||||||
|  |             permanent_tokens += isPermanent ? Number(counter.text()) : 0; | ||||||
|         } else { |         } else { | ||||||
|             const tokens = getTokenCount(value); |             const tokens = getTokenCount(value); | ||||||
|             counter.text(tokens); |             counter.text(tokens); | ||||||
|             total_tokens += tokens; |             total_tokens += tokens; | ||||||
|  |             permanent_tokens += isPermanent ? tokens : 0; | ||||||
|             input.data('last-value-hash', valueHash); |             input.data('last-value-hash', valueHash); | ||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
| @@ -242,6 +246,7 @@ export function RA_CountCharTokens() { | |||||||
|     const tokenLimit = Math.max(((main_api !== 'openai' ? max_context : oai_settings.openai_max_context) / 2), 1024); |     const tokenLimit = Math.max(((main_api !== 'openai' ? max_context : oai_settings.openai_max_context) / 2), 1024); | ||||||
|     const showWarning = (total_tokens > tokenLimit); |     const showWarning = (total_tokens > tokenLimit); | ||||||
|     $('#result_info_total_tokens').text(total_tokens); |     $('#result_info_total_tokens').text(total_tokens); | ||||||
|  |     $('#result_info_permanent_tokens').text(permanent_tokens); | ||||||
|     $('#result_info_text').toggleClass('neutral_warning', showWarning); |     $('#result_info_text').toggleClass('neutral_warning', showWarning); | ||||||
|     $('#chartokenwarning').toggle(showWarning); |     $('#chartokenwarning').toggle(showWarning); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1172,7 +1172,7 @@ input[type="file"] { | |||||||
| #rm_ch_create_block { | #rm_ch_create_block { | ||||||
|     display: none; |     display: none; | ||||||
|     overflow-y: auto; |     overflow-y: auto; | ||||||
|     padding: 0 5px; |     padding: 5px; | ||||||
|     height: 100%; |     height: 100%; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1768,10 +1768,17 @@ grammarly-extension { | |||||||
| #result_info { | #result_info { | ||||||
|     font-size: calc(var(--mainFontSize) * 0.9); |     font-size: calc(var(--mainFontSize) * 0.9); | ||||||
|     display: flex; |     display: flex; | ||||||
|     align-items: baseline; |     align-items: center; | ||||||
|     gap: 10px; |     gap: 10px; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #result_info_text { | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; | ||||||
|  |     line-height: 1; | ||||||
|  |     text-align: right; | ||||||
|  | } | ||||||
|  |  | ||||||
| .rm_stats_button { | .rm_stats_button { | ||||||
|     cursor: pointer; |     cursor: pointer; | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user