2
0

settings_tab_gradio.py 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. from typing import Any, Callable, Dict
  2. import gradio as gr
  3. from tts_webui.config.save_config_gradio import save_config_gradio
  4. def settings_tab_gradio(
  5. reload_config_and_restart_ui: Callable[[], None],
  6. gradio_interface_options: Dict[str, Any],
  7. ):
  8. with gr.Tab("Settings (Gradio)"), gr.Row(), gr.Column():
  9. # inline: whether to display in the interface inline in an iframe. Defaults to True in python notebooks; False otherwise.
  10. # inbrowser: whether to automatically launch the interface in a new tab on the default browser.
  11. # share: whether to create a publicly shareable link for the interface. Creates an SSH tunnel to make your UI accessible from anywhere. If not provided, it is set to False by default every time, except when running in Google Colab. When localhost is not accessible (e.g. Google Colab), setting share=False is not supported.
  12. # debug: if True, blocks the main thread from running. If running in Google Colab, this is needed to print the errors in the cell output.
  13. # auth: If provided, username and password (or list of username-password tuples) required to access interface. Can also provide function that takes username and password and returns True if valid login.
  14. # auth_message: If provided, HTML message provided on login page.
  15. # prevent_thread_lock: If True, the interface will block the main thread while the server is running.
  16. # show_error: If True, any errors in the interface will be displayed in an alert modal and printed in the browser console log
  17. # server_port: will start gradio app on this port (if available). Can be set by environment variable GRADIO_SERVER_PORT. If None, will search for an available port starting at 7860.
  18. # server_name: to make app accessible on local network, set this to "0.0.0.0". Can be set by environment variable GRADIO_SERVER_NAME. If None, will use "127.0.0.1".
  19. # show_tips: if True, will occasionally show tips about new Gradio features
  20. # enable_queue: DEPRECATED (use .queue() method instead.) if True, inference requests will be served through a queue instead of with parallel threads. Required for longer inference times (> 1min) to prevent timeout. The default option in HuggingFace Spaces is True. The default option elsewhere is False.
  21. # max_threads: the maximum number of total threads that the Gradio app can generate in parallel. The default is inherited from the starlette library (currently 40). Applies whether the queue is enabled or not. But if queuing is enabled, this parameter is increaseed to be at least the concurrency_count of the queue.
  22. # width: The width in pixels of the iframe element containing the interface (used if inline=True)
  23. # height: The height in pixels of the iframe element containing the interface (used if inline=True)
  24. # encrypt: DEPRECATED. Has no effect.
  25. # favicon_path: If a path to a file (.png, .gif, or .ico) is provided, it will be used as the favicon for the web page.
  26. # ssl_keyfile: If a path to a file is provided, will use this as the private key file to create a local server running on https.
  27. # ssl_certfile: If a path to a file is provided, will use this as the signed certificate for https. Needs to be provided if ssl_keyfile is provided.
  28. # ssl_keyfile_password: If a password is provided, will use this with the ssl certificate for https.
  29. # ssl_verify: If False, skips certificate validation which allows self-signed certificates to be used.
  30. # quiet: If True, suppresses most print statements.
  31. # show_api: If True, shows the api docs in the footer of the app. Default True. If the queue is enabled, then api_open parameter of .queue() will determine if the api docs are shown, independent of the value of show_api.
  32. # file_directories: List of directories that gradio is allowed to serve files from (in addition to the directory containing the gradio python file). Must be absolute paths. Warning: any files in these directories or its children are potentially accessible to all users of your app.
  33. gradio_interface_options_ui: Dict[
  34. str, gr.Checkbox | gr.Slider | gr.Textbox | gr.Number
  35. ] = {
  36. "inline": gr.Checkbox(
  37. label="inline: Display inline in an iframe",
  38. value=gradio_interface_options.get("inline", None),
  39. ),
  40. "inbrowser": gr.Checkbox(
  41. label="inbrowser: Automatically launch in a new tab",
  42. value=gradio_interface_options.get("inbrowser", None),
  43. ),
  44. "share": gr.Checkbox(
  45. label="share: Create a publicly shareable link",
  46. value=gradio_interface_options.get("share", None),
  47. ),
  48. "debug": gr.Checkbox(
  49. label="debug: Block the main thread from running",
  50. value=gradio_interface_options.get("debug", None),
  51. ),
  52. "enable_queue": gr.Checkbox(
  53. label="enable_queue: Serve inference requests through a queue",
  54. value=gradio_interface_options.get("enable_queue", None),
  55. ),
  56. "max_threads": gr.Slider(
  57. minimum=1,
  58. maximum=100,
  59. step=1,
  60. label="max_threads: Maximum number of total threads",
  61. value=gradio_interface_options.get("max_threads", None),
  62. ),
  63. "auth": gr.Textbox(
  64. label="auth: Username and password required to access interface, username:password",
  65. value=gradio_interface_options.get("auth", None),
  66. ),
  67. "auth_message": gr.Textbox(
  68. label="auth_message: HTML message provided on login page",
  69. value=gradio_interface_options.get("auth_message", None),
  70. ),
  71. "prevent_thread_lock": gr.Checkbox(
  72. label="prevent_thread_lock: Block the main thread while the server is running",
  73. value=gradio_interface_options.get("prevent_thread_lock", None),
  74. ),
  75. "show_error": gr.Checkbox(
  76. label="show_error: Display errors in an alert modal",
  77. value=gradio_interface_options.get("show_error", None),
  78. ),
  79. "server_name": gr.Textbox(
  80. label="server_name: Make app accessible on local network",
  81. value=gradio_interface_options.get("server_name", None),
  82. ),
  83. "server_port": gr.Number(
  84. label="server_port: Start gradio app on this port",
  85. value=gradio_interface_options.get("server_port", None),
  86. ),
  87. "show_tips": gr.Checkbox(
  88. label="show_tips: Show tips about new Gradio features",
  89. value=gradio_interface_options.get("show_tips", None),
  90. ),
  91. "height": gr.Slider(
  92. minimum=100,
  93. maximum=1000,
  94. step=10,
  95. label="height: Height in pixels of the iframe element",
  96. value=gradio_interface_options.get("height", None),
  97. ),
  98. "width": gr.Slider(
  99. minimum=100,
  100. maximum=1000,
  101. step=10,
  102. label="width: Width in pixels of the iframe element",
  103. value=gradio_interface_options.get("width", None),
  104. ),
  105. "favicon_path": gr.Textbox(
  106. label="favicon_path: Path to a file (.png, .gif, or .ico) to use as the favicon",
  107. value=gradio_interface_options.get("favicon_path", None),
  108. ),
  109. "ssl_keyfile": gr.Textbox(
  110. label="ssl_keyfile: Path to a file to use as the private key file to create a local server "
  111. "running on https",
  112. value=gradio_interface_options.get("ssl_keyfile", None),
  113. ),
  114. "ssl_certfile": gr.Textbox(
  115. label="ssl_certfile: Path to a file to use as the signed certificate for https",
  116. value=gradio_interface_options.get("ssl_certfile", None),
  117. ),
  118. "ssl_keyfile_password": gr.Textbox(
  119. label="ssl_keyfile_password: Password to use with the ssl certificate for https",
  120. value=gradio_interface_options.get("ssl_keyfile_password", None),
  121. ),
  122. "ssl_verify": gr.Checkbox(
  123. label="ssl_verify: Skip certificate validation",
  124. value=gradio_interface_options.get("ssl_verify", None),
  125. ),
  126. "quiet": gr.Checkbox(
  127. label="quiet: Suppress most print statements",
  128. value=gradio_interface_options.get("quiet", None),
  129. ),
  130. "show_api": gr.Checkbox(
  131. label="show_api: Show the api docs in the footer of the app",
  132. value=gradio_interface_options.get("show_api", None),
  133. ),
  134. "file_directories": gr.Textbox(
  135. label="file_directories: List of directories that gradio is allowed to serve files from",
  136. value=gradio_interface_options.get("file_directories", None),
  137. ),
  138. "_frontend": gr.Checkbox(
  139. label="_frontend: Frontend",
  140. value=gradio_interface_options.get("_frontend", None),
  141. ),
  142. }
  143. # Create an input list of all UI elements
  144. inputs = list(gradio_interface_options_ui.values())
  145. keys = list(gradio_interface_options_ui)
  146. save_beacon = gr.Markdown("")
  147. # Map over the UI elements
  148. for i in inputs:
  149. i.change(
  150. fn=lambda *input_values: save_config_gradio(keys, input_values),
  151. inputs=inputs,
  152. outputs=[save_beacon],
  153. )
  154. reload_config_and_restart_ui_button = gr.Button(
  155. # value="Reload config and restart UI",
  156. value="Apply settings and shutdown UI (Manual Restart Required)"
  157. )
  158. reload_config_and_restart_ui_button.click(fn=reload_config_and_restart_ui)