File size: 3,794 Bytes
e5a51ad
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Upload Files</title>
    <style>
        body {
            background-image: url('/Wav2Lip-master/images/wav_img.jpg');
            background-size: cover; /* Make the background cover the entire screen */
            background-position: center; /* Center the background image */
            background-repeat: no-repeat; /* Prevent repeating the image */
            font-family: Arial, sans-serif;
            margin: 0;
            padding: 20px;
            display: flex;
            flex-direction: column;
            align-items: center;
            height: 100vh; /* Ensure the body takes full height of the viewport */
        }


        h1 {
            color: #333;
        }

        form {
            background: white;
            padding: 20px;
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
            display: flex;
            flex-direction: column;
            gap: 10px;
            width: 300px;
        }

        input[type="file"] {
            border: 2px solid #007BFF;
            padding: 10px;
            border-radius: 4px;
            transition: border-color 0.3s;
        }

        input[type="file"]:focus {
            border-color: #0056b3;
            outline: none;
        }

        button {
            background-color: #007BFF;
            color: white;
            border: none;
            padding: 10px;
            border-radius: 4px;
            cursor: pointer;
            transition: background-color 0.3s;
        }

        button:hover {
            background-color: #0056b3;
        }

        #videoContainer {
            margin-top: 20px;
            max-width: 100%;
            display: flex;
            justify-content: center;
        }

        video {
            max-width: 100%;
            border: 2px solid #007BFF;
            border-radius: 8px;
        }
    </style>
</head>
<body>
    <h1>Upload Files</h1>
    <form id="uploadForm">
        <input type="file" name="file1" accept=".mp3, .mp4, .wav" required>
        <input type="file" name="file2" accept=".mp3, .mp4, .wav" required>
        <button type="submit">Upload</button>
    </form>
    <div id="videoContainer"></div>

    <script>
        document.getElementById('uploadForm').onsubmit = function(event) {
            event.preventDefault();
            console.log('Form submitted');
            const formData = new FormData(event.target);

            fetch('/', {
                method: 'POST',
                body: formData
            })
            .then(response => response.json())
            .then(data => {
                if (data.output_video) {
                    // Construct the URL to the video
                    const videoUrl = `/output/${data.output_video}`;
                    
                    // Create a video element
                    const videoElement = document.createElement('video');
                    videoElement.src = videoUrl;
                    videoElement.controls = true; // Add controls to the video player
                    videoElement.autoplay = true; // Optionally autoplay

                    // Clear previous videos
                    document.getElementById('videoContainer').innerHTML = '';
                    // Append the video to a specific element in your HTML
                    document.getElementById('videoContainer').appendChild(videoElement);
                } else {
                    console.error('Output video not found in response');
                }
            })
            .catch(error => console.error('Error:', error));
        };
    </script>
</body>
</html>