extraNetworks.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. function setupExtraNetworksForTab(tabname) {
  2. gradioApp().querySelector('#' + tabname + '_extra_tabs').classList.add('extra-networks');
  3. var tabs = gradioApp().querySelector('#' + tabname + '_extra_tabs > div');
  4. var searchDiv = gradioApp().getElementById(tabname + '_extra_search');
  5. var search = searchDiv.querySelector('textarea');
  6. var sort = gradioApp().getElementById(tabname + '_extra_sort');
  7. var sortOrder = gradioApp().getElementById(tabname + '_extra_sortorder');
  8. var refresh = gradioApp().getElementById(tabname + '_extra_refresh');
  9. sort.dataset.sortkey = 'sortDefault';
  10. tabs.appendChild(searchDiv);
  11. tabs.appendChild(sort);
  12. tabs.appendChild(sortOrder);
  13. tabs.appendChild(refresh);
  14. var applyFilter = function() {
  15. var searchTerm = search.value.toLowerCase();
  16. gradioApp().querySelectorAll('#' + tabname + '_extra_tabs div.card').forEach(function(elem) {
  17. var searchOnly = elem.querySelector('.search_only');
  18. var text = elem.querySelector('.name').textContent.toLowerCase() + " " + elem.querySelector('.search_term').textContent.toLowerCase();
  19. var visible = text.indexOf(searchTerm) != -1;
  20. if (searchOnly && searchTerm.length < 4) {
  21. visible = false;
  22. }
  23. elem.style.display = visible ? "" : "none";
  24. });
  25. };
  26. var applySort = function() {
  27. var reverse = sortOrder.classList.contains("sortReverse");
  28. var sortKey = sort.querySelector("input").value.toLowerCase().replace("sort", "").replaceAll(" ", "_").replace(/_+$/, "").trim();
  29. sortKey = sortKey ? "sort" + sortKey.charAt(0).toUpperCase() + sortKey.slice(1) : "";
  30. var sortKeyStore = sortKey ? sortKey + (reverse ? "Reverse" : "") : "";
  31. if (!sortKey || sortKeyStore == sort.dataset.sortkey) {
  32. return;
  33. }
  34. sort.dataset.sortkey = sortKeyStore;
  35. var cards = gradioApp().querySelectorAll('#' + tabname + '_extra_tabs div.card');
  36. cards.forEach(function(card) {
  37. card.originalParentElement = card.parentElement;
  38. });
  39. var sortedCards = Array.from(cards);
  40. sortedCards.sort(function(cardA, cardB) {
  41. var a = cardA.dataset[sortKey];
  42. var b = cardB.dataset[sortKey];
  43. if (!isNaN(a) && !isNaN(b)) {
  44. return parseInt(a) - parseInt(b);
  45. }
  46. return (a < b ? -1 : (a > b ? 1 : 0));
  47. });
  48. if (reverse) {
  49. sortedCards.reverse();
  50. }
  51. cards.forEach(function(card) {
  52. card.remove();
  53. });
  54. sortedCards.forEach(function(card) {
  55. card.originalParentElement.appendChild(card);
  56. });
  57. };
  58. search.addEventListener("input", applyFilter);
  59. applyFilter();
  60. ["change", "blur", "click"].forEach(function(evt) {
  61. sort.querySelector("input").addEventListener(evt, applySort);
  62. });
  63. sortOrder.addEventListener("click", function() {
  64. sortOrder.classList.toggle("sortReverse");
  65. applySort();
  66. });
  67. extraNetworksApplyFilter[tabname] = applyFilter;
  68. }
  69. function applyExtraNetworkFilter(tabname) {
  70. setTimeout(extraNetworksApplyFilter[tabname], 1);
  71. }
  72. var extraNetworksApplyFilter = {};
  73. var activePromptTextarea = {};
  74. function setupExtraNetworks() {
  75. setupExtraNetworksForTab('txt2img');
  76. setupExtraNetworksForTab('img2img');
  77. function registerPrompt(tabname, id) {
  78. var textarea = gradioApp().querySelector("#" + id + " > label > textarea");
  79. if (!activePromptTextarea[tabname]) {
  80. activePromptTextarea[tabname] = textarea;
  81. }
  82. textarea.addEventListener("focus", function() {
  83. activePromptTextarea[tabname] = textarea;
  84. });
  85. }
  86. registerPrompt('txt2img', 'txt2img_prompt');
  87. registerPrompt('txt2img', 'txt2img_neg_prompt');
  88. registerPrompt('img2img', 'img2img_prompt');
  89. registerPrompt('img2img', 'img2img_neg_prompt');
  90. }
  91. onUiLoaded(setupExtraNetworks);
  92. var re_extranet = /<([^:]+:[^:]+):[\d.]+>(.*)/;
  93. var re_extranet_g = /\s+<([^:]+:[^:]+):[\d.]+>/g;
  94. function tryToRemoveExtraNetworkFromPrompt(textarea, text) {
  95. var m = text.match(re_extranet);
  96. var replaced = false;
  97. var newTextareaText;
  98. if (m) {
  99. var extraTextAfterNet = m[2];
  100. var partToSearch = m[1];
  101. var foundAtPosition = -1;
  102. newTextareaText = textarea.value.replaceAll(re_extranet_g, function(found, net, pos) {
  103. m = found.match(re_extranet);
  104. if (m[1] == partToSearch) {
  105. replaced = true;
  106. foundAtPosition = pos;
  107. return "";
  108. }
  109. return found;
  110. });
  111. if (foundAtPosition >= 0 && newTextareaText.substr(foundAtPosition, extraTextAfterNet.length) == extraTextAfterNet) {
  112. newTextareaText = newTextareaText.substr(0, foundAtPosition) + newTextareaText.substr(foundAtPosition + extraTextAfterNet.length);
  113. }
  114. } else {
  115. newTextareaText = textarea.value.replaceAll(new RegExp(text, "g"), function(found) {
  116. if (found == text) {
  117. replaced = true;
  118. return "";
  119. }
  120. return found;
  121. });
  122. }
  123. if (replaced) {
  124. textarea.value = newTextareaText;
  125. return true;
  126. }
  127. return false;
  128. }
  129. function cardClicked(tabname, textToAdd, allowNegativePrompt) {
  130. var textarea = allowNegativePrompt ? activePromptTextarea[tabname] : gradioApp().querySelector("#" + tabname + "_prompt > label > textarea");
  131. if (!tryToRemoveExtraNetworkFromPrompt(textarea, textToAdd)) {
  132. textarea.value = textarea.value + opts.extra_networks_add_text_separator + textToAdd;
  133. }
  134. updateInput(textarea);
  135. }
  136. function saveCardPreview(event, tabname, filename) {
  137. var textarea = gradioApp().querySelector("#" + tabname + '_preview_filename > label > textarea');
  138. var button = gradioApp().getElementById(tabname + '_save_preview');
  139. textarea.value = filename;
  140. updateInput(textarea);
  141. button.click();
  142. event.stopPropagation();
  143. event.preventDefault();
  144. }
  145. function extraNetworksSearchButton(tabs_id, event) {
  146. var searchTextarea = gradioApp().querySelector("#" + tabs_id + ' > label > textarea');
  147. var button = event.target;
  148. var text = button.classList.contains("search-all") ? "" : button.textContent.trim();
  149. searchTextarea.value = text;
  150. updateInput(searchTextarea);
  151. }
  152. var globalPopup = null;
  153. var globalPopupInner = null;
  154. function closePopup() {
  155. if (!globalPopup) return;
  156. globalPopup.style.display = "none";
  157. }
  158. function popup(contents) {
  159. if (!globalPopup) {
  160. globalPopup = document.createElement('div');
  161. globalPopup.onclick = closePopup;
  162. globalPopup.classList.add('global-popup');
  163. var close = document.createElement('div');
  164. close.classList.add('global-popup-close');
  165. close.onclick = closePopup;
  166. close.title = "Close";
  167. globalPopup.appendChild(close);
  168. globalPopupInner = document.createElement('div');
  169. globalPopupInner.onclick = function(event) {
  170. event.stopPropagation(); return false;
  171. };
  172. globalPopupInner.classList.add('global-popup-inner');
  173. globalPopup.appendChild(globalPopupInner);
  174. gradioApp().querySelector('.main').appendChild(globalPopup);
  175. }
  176. globalPopupInner.innerHTML = '';
  177. globalPopupInner.appendChild(contents);
  178. globalPopup.style.display = "flex";
  179. }
  180. function extraNetworksShowMetadata(text) {
  181. var elem = document.createElement('pre');
  182. elem.classList.add('popup-metadata');
  183. elem.textContent = text;
  184. popup(elem);
  185. }
  186. function requestGet(url, data, handler, errorHandler) {
  187. var xhr = new XMLHttpRequest();
  188. var args = Object.keys(data).map(function(k) {
  189. return encodeURIComponent(k) + '=' + encodeURIComponent(data[k]);
  190. }).join('&');
  191. xhr.open("GET", url + "?" + args, true);
  192. xhr.onreadystatechange = function() {
  193. if (xhr.readyState === 4) {
  194. if (xhr.status === 200) {
  195. try {
  196. var js = JSON.parse(xhr.responseText);
  197. handler(js);
  198. } catch (error) {
  199. console.error(error);
  200. errorHandler();
  201. }
  202. } else {
  203. errorHandler();
  204. }
  205. }
  206. };
  207. var js = JSON.stringify(data);
  208. xhr.send(js);
  209. }
  210. function extraNetworksRequestMetadata(event, extraPage, cardName) {
  211. var showError = function() {
  212. extraNetworksShowMetadata("there was an error getting metadata");
  213. };
  214. requestGet("./sd_extra_networks/metadata", {page: extraPage, item: cardName}, function(data) {
  215. if (data && data.metadata) {
  216. extraNetworksShowMetadata(data.metadata);
  217. } else {
  218. showError();
  219. }
  220. }, showError);
  221. event.stopPropagation();
  222. }
  223. var extraPageUserMetadataEditors = {};
  224. function extraNetworksEditUserMetadata(event, tabname, extraPage, cardName) {
  225. var id = tabname + '_' + extraPage + '_edit_user_metadata';
  226. var editor = extraPageUserMetadataEditors[id];
  227. if (!editor) {
  228. editor = {};
  229. editor.page = gradioApp().getElementById(id);
  230. editor.nameTextarea = gradioApp().querySelector("#" + id + "_name" + ' textarea');
  231. editor.button = gradioApp().querySelector("#" + id + "_button");
  232. extraPageUserMetadataEditors[id] = editor;
  233. }
  234. editor.nameTextarea.value = cardName;
  235. updateInput(editor.nameTextarea);
  236. editor.button.click();
  237. popup(editor.page);
  238. event.stopPropagation();
  239. }
  240. function extraNetworksRefreshSingleCard(page, tabname, name) {
  241. requestGet("./sd_extra_networks/get-single-card", {page: page, tabname: tabname, name: name}, function(data) {
  242. if (data && data.html) {
  243. var card = gradioApp().querySelector('.card[data-name=' + JSON.stringify(name) + ']'); // likely using the wrong stringify function
  244. var newDiv = document.createElement('DIV');
  245. newDiv.innerHTML = data.html;
  246. var newCard = newDiv.firstElementChild;
  247. newCard.style = '';
  248. card.parentElement.insertBefore(newCard, card);
  249. card.parentElement.removeChild(card);
  250. }
  251. });
  252. }