File size: 5,866 Bytes
5ed9e85
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
import gradio as gr

from modules import shared, ui, utils
from modules.prompts import count_tokens, load_prompt
from modules.text_generation import (
    generate_reply_wrapper,
    stop_everything_event
)
from modules.utils import gradio


def create_ui():
    default_text = load_prompt(shared.settings['prompt'])

    shared.gradio['interface_state'] = gr.State({k: None for k in shared.input_elements})
    shared.gradio['last_input'] = gr.State('')

    with gr.Tab("Text generation", elem_id="main"):
        with gr.Row():
            with gr.Column(scale=4):
                with gr.Tab('Raw'):
                    shared.gradio['textbox'] = gr.Textbox(value=default_text, elem_classes=['textbox', 'add_scrollbar'], lines=27)

                with gr.Tab('Markdown'):
                    shared.gradio['markdown_render'] = gr.Button('Render')
                    shared.gradio['markdown'] = gr.Markdown()

                with gr.Tab('HTML'):
                    shared.gradio['html'] = gr.HTML()

                with gr.Row():
                    shared.gradio['Generate'] = gr.Button('Generate', variant='primary', elem_classes="small-button")
                    shared.gradio['Stop'] = gr.Button('Stop', elem_classes="small-button", elem_id='stop')
                    shared.gradio['Undo'] = gr.Button('Undo', elem_classes="small-button")
                    shared.gradio['Regenerate'] = gr.Button('Regenerate', elem_classes="small-button")

            with gr.Column(scale=1):
                gr.HTML('<div style="padding-bottom: 13px"></div>')
                shared.gradio['max_new_tokens'] = gr.Slider(minimum=shared.settings['max_new_tokens_min'], maximum=shared.settings['max_new_tokens_max'], step=1, label='max_new_tokens', value=shared.settings['max_new_tokens'])
                with gr.Row():
                    shared.gradio['prompt_menu'] = gr.Dropdown(choices=utils.get_available_prompts(), value='None', label='Prompt', elem_classes='slim-dropdown')
                    ui.create_refresh_button(shared.gradio['prompt_menu'], lambda: None, lambda: {'choices': utils.get_available_prompts()}, ['refresh-button', 'refresh-button-small'])
                    shared.gradio['save_prompt'] = gr.Button('💾', elem_classes=['refresh-button', 'refresh-button-small'])
                    shared.gradio['delete_prompt'] = gr.Button('🗑️', elem_classes=['refresh-button', 'refresh-button-small'])

                shared.gradio['count_tokens'] = gr.Button('Count tokens')
                shared.gradio['status'] = gr.Markdown('')


def create_event_handlers():
    gen_events = []

    shared.input_params = gradio('textbox', 'interface_state')
    output_params = gradio('textbox', 'html')

    gen_events.append(shared.gradio['Generate'].click(
        lambda x: x, gradio('textbox'), gradio('last_input')).then(
        ui.gather_interface_values, gradio(shared.input_elements), gradio('interface_state')).then(
        generate_reply_wrapper, shared.input_params, output_params, show_progress=False).then(
        ui.gather_interface_values, gradio(shared.input_elements), gradio('interface_state')).then(
        lambda: None, None, None, _js=f"() => {{{ui.audio_notification_js}}}")
        # lambda: None, None, None, _js="() => {element = document.getElementsByTagName('textarea')[0]; element.scrollTop = element.scrollHeight}")
    )

    gen_events.append(shared.gradio['textbox'].submit(
        lambda x: x, gradio('textbox'), gradio('last_input')).then(
        ui.gather_interface_values, gradio(shared.input_elements), gradio('interface_state')).then(
        generate_reply_wrapper, shared.input_params, output_params, show_progress=False).then(
        ui.gather_interface_values, gradio(shared.input_elements), gradio('interface_state')).then(
        lambda: None, None, None, _js=f"() => {{{ui.audio_notification_js}}}")
        # lambda: None, None, None, _js="() => {element = document.getElementsByTagName('textarea')[0]; element.scrollTop = element.scrollHeight}")
    )

    shared.gradio['Undo'].click(lambda x: x, gradio('last_input'), gradio('textbox'), show_progress=False)
    shared.gradio['markdown_render'].click(lambda x: x, gradio('textbox'), gradio('markdown'), queue=False)
    gen_events.append(shared.gradio['Regenerate'].click(
        lambda x: x, gradio('last_input'), gradio('textbox'), show_progress=False).then(
        ui.gather_interface_values, gradio(shared.input_elements), gradio('interface_state')).then(
        generate_reply_wrapper, shared.input_params, output_params, show_progress=False).then(
        ui.gather_interface_values, gradio(shared.input_elements), gradio('interface_state')).then(
        lambda: None, None, None, _js=f"() => {{{ui.audio_notification_js}}}")
        # lambda: None, None, None, _js="() => {element = document.getElementsByTagName('textarea')[0]; element.scrollTop = element.scrollHeight}")
    )

    shared.gradio['Stop'].click(stop_everything_event, None, None, queue=False, cancels=gen_events if shared.args.no_stream else None)
    shared.gradio['prompt_menu'].change(load_prompt, gradio('prompt_menu'), gradio('textbox'), show_progress=False)
    shared.gradio['save_prompt'].click(
        lambda x: x, gradio('textbox'), gradio('save_contents')).then(
        lambda: 'prompts/', None, gradio('save_root')).then(
        lambda: utils.current_time() + '.txt', None, gradio('save_filename')).then(
        lambda: gr.update(visible=True), None, gradio('file_saver'))

    shared.gradio['delete_prompt'].click(
        lambda: 'prompts/', None, gradio('delete_root')).then(
        lambda x: x + '.txt', gradio('prompt_menu'), gradio('delete_filename')).then(
        lambda: gr.update(visible=True), None, gradio('file_deleter'))

    shared.gradio['count_tokens'].click(count_tokens, gradio('textbox'), gradio('status'), show_progress=False)