extraNetworks.js 8.4 KB

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