-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathstreamlit_app.py
126 lines (107 loc) · 4.12 KB
/
streamlit_app.py
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
import streamlit as st
import json
import jq
import os
from jaiqu import validate_schema, translate_schema
# Set page layout to wide
st.set_page_config(layout="wide", page_title="Jaiqu: AI JSON Schema to JQ Query Generator")
# Custom styles for Streamlit elements
st.markdown(
"""
<style>
.stTextArea {
border: 2px solid #4CAF50;
border-radius: 5px;
padding: 10px; /* Increased padding */
box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2);
}
</style>
""",
unsafe_allow_html=True
)
# Title of the app with custom color
st.markdown("<h1 style='text-align: center; color: #4CAF50; padding: 0 1rem;'>Jaiqu: AI Schema to JQ Query Generator</h1>",
unsafe_allow_html=True) # Added horizontal padding to the title
st.header('Desired data format')
col1, col2 = st.columns(2)
with col1:
schema_json = st.text_area('Enter the desired JSON schema', value=json.dumps({
"$schema": "http://json-schema.org/draft-07/schema#",
"type": "object",
"properties": {
"id": {
"type": ["string", "null"],
"description": "A unique identifier for the record."
},
"date": {
"type": "string",
"description": "A string describing the date."
},
"model": {
"type": "string",
"description": "A text field representing the model used."
}
},
"required": [
"id",
"date"
]
}, indent=2), height=200)
with col2:
input_json_str = st.text_area('Enter the input JSON', value=json.dumps({
"call.id": "123",
"datetime": "2022-01-01",
"timestamp": 1640995200,
"Address": "123 Main St",
"user": {
"name": "John Doe",
"age": 30,
"contact": "[email protected]"
}
}, indent=2), height=200)
with col1:
schema = json.loads(schema_json)
st.json(schema, expanded=False)
with col2:
input_json = json.loads(input_json_str)
st.json(input_json, expanded=False)
st.markdown("<hr style='border-top: 3px solid #bbb; border-radius: 5px; margin: 0 1rem;'/>", # Added horizontal margin to the horizontal line
unsafe_allow_html=True)
st.header('Optional Inputs')
opt_col1, opt_col2 = st.columns(2)
with opt_col1:
key_hints = st.text_area('Enter any hints for key mapping',
value="We are processing outputs of an containing an id and a date of a user.", height=100)
with opt_col2:
max_retries = st.number_input('Set maximum retries for translation', min_value=1,
value=20, format="%d")
openai_api_key = st.text_input('Enter your OpenAI API key', type="password")
# Validate schema
if st.button('Validate Schema', key="validate_schema"):
if not openai_api_key:
st.error("Please provide your OpenAI API key to validate the schema.")
st.stop()
with st.spinner('Validating schema...'):
schema_properties, valid = validate_schema(input_json, schema,
openai_api_key=openai_api_key, key_hints=key_hints)
st.write('Schema is valid:', valid)
st.json(schema_properties, expanded=False)
# Translate schema
if st.button('Translate Schema', key="translate_schema"):
with st.spinner('Translating schema...'):
if not openai_api_key:
st.error("Please provide your OpenAI API key to translate the schema.")
st.stop()
jq_query = translate_schema(input_json, schema,
openai_api_key=openai_api_key,
key_hints=key_hints, max_retries=int(max_retries))
st.text('Finalized jq query')
st.code(jq_query, language="jq")
with st.spinner('Checking the jq query results...'):
# Check the jq query results
st.text('JQ query results')
try:
result = jq.compile(jq_query).input(input_json).all()[0]
st.write(result)
except Exception as e:
st.error(f"Error: {e}")