Spaces:
Running
Running
File size: 4,476 Bytes
b24805e 6b8a805 b24805e 6b8a805 76c51c1 74bda91 d8ef9f9 76c51c1 1e6519e 3c6ebcd 029ff92 1e6519e 6c33d2e 2e0a307 d8ef9f9 2e0a307 d8ef9f9 2e0a307 d8ef9f9 76c51c1 6b8a805 d4b2d90 6b8a805 f8567da b24805e f8567da 6b8a805 c7fbeaf f8567da fee9904 b24805e f8567da b24805e f8567da 029ff92 f8567da 1e6519e f8567da c542f6a b24805e 9ac1f7d b24805e 6b8a805 d4b2d90 |
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 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 |
import json
import gradio as gr
from pingpong import PingPong
from pingpong.gradio import GradioAlpacaChatPPManager
STYLE = """
.custom-btn {
border: none !important;
background: none !important;
box-shadow: none !important;
}
.custom-btn:hover {
background: rgb(243 244 246) !important;
}
#prompt-txt > label > span {
display: none !important;
}
#prompt-txt > label > textarea {
border: transparent;
box-shadow: none;
}
#chatbot {
height: 800px;
overflow: auto;
box-shadow: none !important;
border: none !important;
}
#chatbot > .wrap {
max-height: 780px;
}
#left-pane {
background-color: #f9fafb;
border-radius: 15px;
padding-left: 10px;
padding-right: 10px;
}
"""
get_local_storage = """
function() {
globalThis.setStorage = (key, value)=>{
localStorage.setItem(key, JSON.stringify(value));
}
globalThis.getStorage = (key, value)=>{
return JSON.parse(localStorage.getItem(key));
}
const local_data = getStorage('local_data');
const history = [];
console.log(1);
if(local_data) {
console.log(2);
console.log(local_data);
local_data[0].pingpongs.forEach(element =>
history.push([element.ping, element.pong])
);
}
console.log(history);
return [local_data, history];
}
"""
def add_pingpong(idx, ld, ping):
res = [
GradioAlpacaChatPPManager.from_json(json.dumps(ppm))
for ppm in ld
]
ppm = res[idx]
ppm.add_pingpong(PingPong(ping, "dang!!!!!!!"))
return ppm.build_uis(), str(res)
def set_chatbot(btn, ld):
choice = 0
if btn == "1st":
choice = 0
elif btn == "2nd":
choice = 1
elif btn == "3rd":
choice = 2
elif btn == "4th":
choice = 3
elif btn == "5th":
choice = 4
res = [
GradioAlpacaChatPPManager.from_json(json.dumps(ppm_str))
for ppm_str in ld
]
return res[choice].build_uis(), choice
def initialize(local_data):
if local_data is None:
list_conv = [
GradioAlpacaChatPPManager()
for _ in range(5)
]
local_data = str(list_conv)
return local_data
def initialize_t(ld):
print(ld)
if ld == {} or id is None:
list_conv = [
GradioAlpacaChatPPManager()
for _ in range(5)
]
local_data = str(list_conv)
else:
list_conv = [
GradioAlpacaChatPPManager.from_json(json.dumps(ppm))
for ppm in ld
]
local_data = str(list_conv)
return list_conv[0].build_uis(), local_data
with gr.Blocks(css=STYLE, theme='gradio/soft') as block:
idx = gr.State(0)
ttt = gr.Textbox(visible=False)
local_data = gr.JSON(
{},
label="Local Storage",
visible=False
)
with gr.Row():
with gr.Column(scale=1, min_width=100):
gr.Markdown("GradioChat")
with gr.Column(elem_id="left-pane"):
first = gr.Button("1st", elem_classes=["custom-btn"])
second = gr.Button("2nd", elem_classes=["custom-btn"])
third = gr.Button("3rd", elem_classes=["custom-btn"])
fourth = gr.Button("4th", elem_classes=["custom-btn"])
fifth = gr.Button("5th", elem_classes=["custom-btn"])
with gr.Column(scale=10):
chatbot = gr.Chatbot(elem_id='chatbot')
instruction_txtbox = gr.Textbox(
placeholder="What do you want to say to AI?", label="",
elem_id="prompt-txt"
)
first.click(
initialize,
local_data,
local_data
).then(
set_chatbot,
[first, local_data],
[chatbot, idx]
)
second.click(
initialize,
local_data,
local_data
).then(
set_chatbot,
[second, local_data],
[chatbot, idx]
)
third.click(
initialize,
local_data,
local_data
).then(
set_chatbot,
[third, local_data],
[chatbot, idx]
)
fourth.click(
initialize,
local_data,
local_data
).then(
set_chatbot,
[fourth, local_data],
[chatbot, idx]
)
fifth.click(
initialize,
local_data,
local_data
).then(
set_chatbot,
[fifth, local_data],
[chatbot, idx]
)
instruction_txtbox.submit(
initialize,
local_data,
local_data
).then(
add_pingpong,
[idx, local_data, instruction_txtbox],
[chatbot, local_data]
).then(
None, local_data, None,
_js="(v)=>{ setStorage('local_data',v) }"
)
block.load(
None,
inputs=None,
outputs=[local_data, chatbot],
_js=get_local_storage,
)
block.queue().launch(debug=True) |