File size: 6,343 Bytes
a1de66d ce879dc a1de66d fbfdf9e a830900 a1de66d fbfdf9e b8091cf cfa921b deed607 feffd36 beb6438 ce879dc cfa921b ce879dc cfa921b 49acd1b cfa921b 49acd1b cfa921b b21a71c cfa921b a1de66d 092fa31 4da4ce9 5583fd4 feffd36 7692c5b cfa921b 0ab6607 40d6d53 feffd36 4da4ce9 f7b770e 4da4ce9 f7b770e 7692c5b ce879dc cfa921b 6f681ea |
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 |
import streamlit as st
import streamlit.components.v1 as components
import re
import os
import glob
st.set_page_config(layout="wide")
def process_line(line):
if re.search(r'\b[A-G][#b]?m?\b', line):
line = re.sub(r'\b([A-G][#b]?m?)\b', r"<img src='\1.png' style='height:20px;'>", line)
return line
def process_chord_sheet(chord_sheet):
processed_lines = []
for line in chord_sheet.split('\n'):
processed_line = process_line(line)
processed_lines.append(processed_line)
return '<br>'.join(processed_lines)
def create_search_url_wikipedia(artist_song):
base_url = "https://www.wikipedia.org/search-redirect.php?family=wikipedia&language=en&search="
return base_url + artist_song.replace(' ', '+').replace('–', '%E2%80%93').replace('&', 'and')
def create_search_url_youtube(artist_song):
base_url = "https://www.youtube.com/results?search_query="
return base_url + artist_song.replace(' ', '+').replace('–', '%E2%80%93').replace('&', 'and')
def create_search_url_chords(artist_song):
base_url = "https://www.ultimate-guitar.com/search.php?search_type=title&value="
return base_url + artist_song.replace(' ', '+').replace('–', '%E2%80%93').replace('&', 'and')
def create_search_url_lyrics(artist_song):
base_url = "https://www.google.com/search?q="
return base_url + artist_song.replace(' ', '+').replace('–', '%E2%80%93').replace('&', 'and') + '+lyrics'
def songupdate():
st.write(st.session_state.EnhancedChordSheet)
def load_song_file2(filename):
with open(filename, "r") as file:
chord_sheet = file.read()
st.session_state['chord_sheet'] = chord_sheet
processed_sheet = process_chord_sheet(chord_sheet)
st.markdown(processed_sheet, unsafe_allow_html=True)
def load_song_file(file_path):
with open(file_path, 'r', encoding='utf-8') as file:
chord_sheet = file.read()
return chord_sheet
def song_update():
if 'selected_file' in st.session_state:
song_name, artist_name = parse_filename(st.session_state.selected_file)
st.session_state.song_name = song_name
st.session_state.artist_name = artist_name
def parse_filename(filename):
base_name = os.path.splitext(filename)[0]
song_name, artist_name = base_name.split(' by ')
return song_name.replace("_", " "), artist_name.replace("_", " ")
def auto_save():
song_name = st.session_state.get('song_name', '')
artist_name = st.session_state.get('artist_name', '')
chord_sheet = st.session_state.get('chord_sheet', '')
if song_name and artist_name and chord_sheet:
filename = song_name + " by " + artist_name + ".txt"
with open(filename, "w") as file:
chord_sheet_text = st.session_state.get('chord_sheet', '')
file.write(chord_sheet_text)
st.session_state['char_count'] = len(chord_sheet)
st.success(f"Auto-saved to {filename}")
def main():
col1, col3 = st.columns([3, 5])
with col1:
st.markdown('### 🎵 📚Prompt🎥🎸Chord Sheet🎶 AI Prompt Authoring App')
with st.expander("Select Song:", expanded=True):
all_files = [f for f in glob.glob("*.txt") if ' by ' in f]
selected_file = st.selectbox("Choose: ", all_files, on_change=song_update, key='selected_file')
song_name_input = st.text_input("🎵 Song:", key='song_name', on_change=auto_save)
artist_name_input = st.text_input("🎤 Artist:", key='artist_name', on_change=auto_save)
if 'selected_file' in st.session_state and st.session_state.selected_file:
# Update the session state before creating the text area widget
st.session_state['chord_sheet'] = load_song_file(st.session_state.selected_file)
st.header("🎼 Current Song")
load_song_file(selected_file)
song_info = os.path.splitext(selected_file)[0].replace("_", " ")
st.markdown("**" + song_info + "**")
table_md = f"""
| Wikipedia | YouTube | Chords | Lyrics |
| --------- | ------- | ------ | ------ |
| [📚]({create_search_url_wikipedia(song_info)}) | [🎥]({create_search_url_youtube(song_info)}) | [🎸]({create_search_url_chords(song_info)}) | [🎶]({create_search_url_lyrics(song_info)}) |
"""
st.markdown(table_md)
st.header("🎼 Available Songs")
for file in all_files:
song_info = os.path.splitext(file)[0].replace("_", " ")
icol1, icol2 = st.columns([1, 3])
with icol1:
st.markdown("**" + song_info + "**")
load_song_file(file)
song_info = os.path.splitext(file)[0].replace("_", " ")
with icol2:
# Create a markdown table with links for each song file
table_md = f"""
| Wikipedia | YouTube | Chords | Lyrics |
| --------- | ------- | ------ | ------ |
| [📚]({create_search_url_wikipedia(song_info)}) | [🎥]({create_search_url_youtube(song_info)}) | [🎸]({create_search_url_chords(song_info)}) | [🎶]({create_search_url_lyrics(song_info)}) |
"""
st.markdown(table_md)
with col3:
subcol1, subcol2 = st.columns([1, 5])
with subcol2:
chord_sheet_area = st.text_area("Chord Sheet", value=st.session_state.get('chord_sheet', ''), height=1600, key='chord_sheet', on_change=auto_save)
with subcol1:
# Save functionality
if st.button("💾 Save", key="save_song"):
if song_name_input and artist_name_input:
filename = song_name_input + " by " + artist_name_input + ".txt"
with open(filename, "w") as file:
file.write(chord_sheet_area)
st.success("Chord sheet saved to file: " + filename)
else:
st.error("Both Song Name and Artist Name are required.")
char_count_msg = f"Character Count: {st.session_state.get('char_count', 0)}"
st.write(char_count_msg)
# Load chord sheet from selected file into the text area
if 'selected_file' in st.session_state and st.session_state.selected_file:
load_song_file(st.session_state.selected_file)
if __name__ == '__main__':
main() |