settings.js 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. let settingsExcludeTabsFromShowAll = {
  2. settings_tab_defaults: 1,
  3. settings_tab_sysinfo: 1,
  4. settings_tab_actions: 1,
  5. settings_tab_licenses: 1,
  6. };
  7. function settingsShowAllTabs() {
  8. gradioApp().querySelectorAll('#settings > div').forEach(function(elem) {
  9. if (settingsExcludeTabsFromShowAll[elem.id]) return;
  10. elem.style.display = "block";
  11. });
  12. }
  13. function settingsShowOneTab() {
  14. gradioApp().querySelector('#settings_show_one_page').click();
  15. }
  16. onUiLoaded(function() {
  17. var edit = gradioApp().querySelector('#settings_search');
  18. var editTextarea = gradioApp().querySelector('#settings_search > label > input');
  19. var buttonShowAllPages = gradioApp().getElementById('settings_show_all_pages');
  20. var settings_tabs = gradioApp().querySelector('#settings div');
  21. onEdit('settingsSearch', editTextarea, 250, function() {
  22. var searchText = (editTextarea.value || "").trim().toLowerCase();
  23. gradioApp().querySelectorAll('#settings > div[id^=settings_] div[id^=column_settings_] > *').forEach(function(elem) {
  24. var visible = elem.textContent.trim().toLowerCase().indexOf(searchText) != -1;
  25. elem.style.display = visible ? "" : "none";
  26. });
  27. if (searchText != "") {
  28. settingsShowAllTabs();
  29. } else {
  30. settingsShowOneTab();
  31. }
  32. });
  33. settings_tabs.insertBefore(edit, settings_tabs.firstChild);
  34. settings_tabs.appendChild(buttonShowAllPages);
  35. buttonShowAllPages.addEventListener("click", settingsShowAllTabs);
  36. });
  37. onOptionsChanged(function() {
  38. if (gradioApp().querySelector('#settings .settings-category')) return;
  39. var sectionMap = {};
  40. gradioApp().querySelectorAll('#settings > div > button').forEach(function(x) {
  41. sectionMap[x.textContent.trim()] = x;
  42. });
  43. opts._categories.forEach(function(x) {
  44. var section = localization[x[0]] ?? x[0];
  45. var category = localization[x[1]] ?? x[1];
  46. var span = document.createElement('SPAN');
  47. span.textContent = category;
  48. span.className = 'settings-category';
  49. var sectionElem = sectionMap[section];
  50. if (!sectionElem) return;
  51. sectionElem.parentElement.insertBefore(span, sectionElem);
  52. });
  53. });
  54. function downloadSysinfo() {
  55. const pad = (n) => String(n).padStart(2, '0');
  56. const now = new Date();
  57. const YY = now.getFullYear();
  58. const MM = pad(now.getMonth() + 1);
  59. const DD = pad(now.getDate());
  60. const HH = pad(now.getHours());
  61. const mm = pad(now.getMinutes());
  62. const link = document.createElement('a');
  63. link.download = `sysinfo-${YY}-${MM}-${DD}-${HH}-${mm}.json`;
  64. const sysinfo_textbox = gradioApp().querySelector('#internal-sysinfo-textbox textarea');
  65. const content = sysinfo_textbox.value;
  66. if (content.startsWith('file=')) {
  67. link.href = content;
  68. } else {
  69. const blob = new Blob([content], {type: 'application/json'});
  70. link.href = URL.createObjectURL(blob);
  71. }
  72. link.click();
  73. sysinfo_textbox.value = '';
  74. updateInput(sysinfo_textbox);
  75. }
  76. function openTabSysinfo() {
  77. const sysinfo_textbox = gradioApp().querySelector('#internal-sysinfo-textbox textarea');
  78. const content = sysinfo_textbox.value;
  79. if (content.startsWith('file=')) {
  80. window.open(content, '_blank');
  81. } else {
  82. const blob = new Blob([content], {type: 'application/json'});
  83. const url = URL.createObjectURL(blob);
  84. window.open(url, '_blank');
  85. }
  86. sysinfo_textbox.value = '';
  87. updateInput(sysinfo_textbox);
  88. }