File size: 6,148 Bytes
a9af6e5
 
 
 
 
 
21edb15
 
 
 
 
 
 
 
 
 
a9af6e5
 
21edb15
 
 
 
 
 
 
3fd5d64
21edb15
 
a9af6e5
21edb15
 
 
 
 
 
a9af6e5
21edb15
 
 
 
 
 
 
 
 
 
 
 
 
 
a9af6e5
21edb15
 
 
 
 
a9af6e5
 
21edb15
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
f410994
 
21edb15
 
 
 
 
 
 
 
 
 
 
 
 
a9af6e5
21edb15
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a9af6e5
21edb15
 
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
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Student Homework Assistant</title>
    
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/cropperjs/1.6.2/cropper.min.css">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/cropperjs/1.6.2/cropper.min.js" defer></script>
    
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css">
    
    <script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>

    <link rel="stylesheet" href="/static/style.css">
    <script src="/static/script.js" defer></script>
</head>
<body>
    <div id="app-wrapper">
        <!-- Home Page - Shown initially -->
        <div id="home-page">
            <div class="home-content">
                <div class="logo"><i class="fa-solid fa-brain"></i></div>
                <h1>Flexx: Your Homework Assistant</h1>
                <p>Stuck on a problem? Need help with a subject? Just ask! You can type, upload, or snap a photo of your question.</p>
          
            </div>
        </div>

        <!-- Chat Interface - Hidden initially -->
        <div id="chat-container" class="hidden">
            <div id="chat-messages">
                <!-- Chat messages will be dynamically inserted here -->
            </div>
        </div>

        <!-- Input Area - Always Visible -->
        <div id="input-area">
            <div id="image-preview-container"></div>
            <div class="input-bar">
                <!-- Mobile Menu Button -->
                <button id="mobile-menu-btn" class="icon-btn mobile-only"><i class="fa-solid fa-paperclip"></i></button>

                <!-- Desktop Icons -->
                <div class="desktop-icons">
                    <button id="upload-btn" class="icon-btn" title="Upload Image"><i class="fa-solid fa-upload"></i></button>
                    <input type="file" id="image-upload" accept="image/*" style="display: none;">
                    <button id="camera-btn" class="icon-btn" title="Capture Photo"><i class="fa-solid fa-camera"></i></button>
                    <button id="search-toggle-btn" class="icon-btn" title="Toggle Web Search"><i class="fa-solid fa-globe"></i></button>
                    <button id="settings-btn" class="icon-btn" title="Settings"><i class="fa-solid fa-cog"></i></button>
                </div>
                
                <textarea id="message-input" placeholder="Type your message, or upload a photo..." rows="1"></textarea>
                <button id="send-btn" title="Send"><i class="fa-solid fa-arrow-up"></i></button>
            </div>
        </div>
    </div>

    <!-- Settings Modal -->
    <div id="settings-modal" class="modal-overlay">
        <div class="modal-content">
            <div class="modal-header">
                <h2>Preferences</h2>
                <button class="close-btn">&times;</button>
            </div>
            <div class="modal-body">
                <div class="setting">
                    <label for="response-language">Response Language</label>
                    <div class="custom-select">
                        <select id="response-language">
                            <option value="English">English</option>
                            <option value="Urdu">Urdu</option>
                        </select>
                    </div>
                </div>
                <div class="setting">
                    <label for="subject">Subject</label>
                    <div class="custom-select">
                        <select id="subject">
                            <option value="General">General</option>
                            <option value="English">English</option>
                            <option value="Urdu">Urdu</option>
                            <option value="Science">Science</option>
                            <option value="Maths">Maths</option>
                            <option value="Geography">Geography</option>
                            <option value="History">History</option>
                            <option value="History">Computer</option>
                            <option value="History">Islamiyat</option>
                        </select>
                    </div>
                </div>
                <div class="setting">
                    <label for="words-limit">Words Limit: <span id="words-limit-value">100</span></label>
                    <input type="range" id="words-limit" min="50" max="500" value="100" class="slider">
                </div>
            </div>
            <div class="modal-footer">
                <button id="save-settings-btn" class="modal-button">Save</button>
            </div>
        </div>
    </div>

    <!-- Camera Modal -->
    <div id="camera-modal" class="modal-overlay">
        <div class="modal-content">
            <div class="modal-header"><h2>Capture Photo</h2><button class="close-btn">&times;</button></div>
            <div class="modal-body"><video id="camera-stream" autoplay playsinline></video><canvas id="camera-canvas" style="display:none;"></canvas></div>
            <div class="modal-footer"><button id="capture-btn" class="modal-button"><i class="fa-solid fa-camera-retro"></i> Capture</button></div>
        </div>
    </div>
    
    <!-- Cropper Modal -->
    <div id="cropper-modal" class="modal-overlay">
        <div class="modal-content wide">
            <div class="modal-header"><h2>Crop Image</h2><button class="close-btn">&times;</button></div>
            <div class="modal-body"><div class="cropper-container"><img id="image-to-crop" src="" alt="Image for cropping"></div></div>
            <div class="modal-footer"><button id="crop-confirm-btn" class="modal-button"><i class="fa-solid fa-crop-simple"></i> Confirm Crop</button></div>
        </div>
    </div>
    
    <!-- Lightbox Modal -->
    <div id="lightbox-modal" class="modal-overlay lightbox">
        <span class="close-btn">&times;</span><img class="lightbox-content" id="lightbox-img">
    </div>

</body>
</html>