Skip to content

Commit 10a35ef

Browse files
committed
Add client
1 parent 6a4f5f3 commit 10a35ef

File tree

8 files changed

+223
-0
lines changed

8 files changed

+223
-0
lines changed

playground/.gitignore

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
# Logs
2+
logs
3+
*.log
4+
npm-debug.log*
5+
yarn-debug.log*
6+
yarn-error.log*
7+
pnpm-debug.log*
8+
lerna-debug.log*
9+
10+
node_modules
11+
dist
12+
dist-ssr
13+
*.local
14+
15+
# Editor directories and files
16+
.vscode/*
17+
!.vscode/extensions.json
18+
.idea
19+
.DS_Store
20+
*.suo
21+
*.ntvs*
22+
*.njsproj
23+
*.sln
24+
*.sw?

playground/README.md

Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
Запуск:
2+
3+
### 1. Подготовьте папку с расширением
4+
5+
- `manifest.json`
6+
- `background.js`
7+
- `popup.html`
8+
- `popup.js`
9+
- `style.css`
10+
- `icon.png`
11+
12+
### 2. Откройте Google Chrome
13+
14+
15+
### 3. Перейдите в раздел "Расширения"
16+
17+
Адрес `chrome://extensions/`
18+
19+
### 4. Включите режим разработчика
20+
21+
В правом верхнем углу страницы вы увидите переключатель "Режим разработчика". Включите его, нажав на переключатель.
22+
23+
### 5. Загрузите распакованное расширение
24+
25+
Загрузите папку `client`
26+
27+
### 6. Откройте расширение
28+

playground/client/background.js

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
chrome.action.onClicked.addListener((tab) => {
2+
chrome.tabs.create({ url: chrome.runtime.getURL("popup.html") });
3+
});

playground/client/icon.png

4.09 KB
Loading

playground/client/manifest.json

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
{
2+
"manifest_version": 3,
3+
"name": "Запись экрана",
4+
"version": "1.0",
5+
"permissions": ["desktopCapture", "storage"],
6+
"background": {
7+
"service_worker": "background.js"
8+
},
9+
"action": {
10+
"default_icon": "icon.png",
11+
"default_title": "Открыть запись экрана"
12+
},
13+
"commands": {
14+
"open_popup": {
15+
"description": "Открыть запись экрана"
16+
}
17+
}
18+
}

playground/client/popup.html

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
<!DOCTYPE html>
2+
<html lang="ru">
3+
<head>
4+
<meta charset="UTF-8">
5+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
6+
<title>Запись экрана</title>
7+
<link rel="stylesheet" href="style.css">
8+
<script src="popup.js" defer></script>
9+
</head>
10+
<body>
11+
<div class="container">
12+
<h1>Запись экрана</h1>
13+
<input type="text" id="username" placeholder="Введите ваше имя" class="input" />
14+
<div class="button-container">
15+
<button id="startBtn" class="button">Начать запись</button>
16+
<button id="stopBtn" class="button" disabled>Остановить запись</button>
17+
</div>
18+
</div>
19+
</body>
20+
</html>

playground/client/popup.js

Lines changed: 71 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
1+
let mediaRecorder;
2+
let recordedChunks = [];
3+
4+
// TODO(пока случайный id)
5+
function generateRecordingId() {
6+
return 'recording-' + Math.random().toString(36).substr(2, 9); // Генерация случайной строки
7+
}
8+
9+
// Запуск записи
10+
function startRecording(stream) {
11+
recordedChunks = [];
12+
mediaRecorder = new MediaRecorder(stream);
13+
const recordingId = generateRecordingId(); // Генерация ID записи
14+
15+
mediaRecorder.ondataavailable = (event) => {
16+
if (event.data.size > 0) {
17+
recordedChunks.push(event.data);
18+
}
19+
};
20+
21+
mediaRecorder.onstop = () => {
22+
const blob = new Blob(recordedChunks, { type: 'video/webm' });
23+
const url = URL.createObjectURL(blob);
24+
downloadVideo(url);
25+
alert(`Запись завершена! ID записи: ${recordingId}`); // Вывод ID записи
26+
};
27+
28+
mediaRecorder.start();
29+
document.getElementById('startBtn').disabled = true;
30+
document.getElementById('stopBtn').disabled = false;
31+
}
32+
33+
// Остановка записи
34+
function stopRecording() {
35+
mediaRecorder.stop();
36+
document.getElementById('startBtn').disabled = false;
37+
document.getElementById('stopBtn').disabled = true;
38+
}
39+
40+
// Функция для скачивания видео
41+
function downloadVideo(url) {
42+
const username = document.getElementById('username').value.trim() || 'recording'; // Получаем имя пользователя или используем значение по умолчанию
43+
const a = document.createElement('a');
44+
a.style.display = 'none';
45+
a.href = url;
46+
a.download = `${username}_recording.webm`; // Имя файла для скачивания
47+
document.body.appendChild(a);
48+
a.click();
49+
window.URL.revokeObjectURL(url);
50+
document.body.removeChild(a);
51+
}
52+
53+
// Обработчики событий для кнопок
54+
document.getElementById('startBtn').addEventListener('click', () => {
55+
const username = document.getElementById('username').value.trim();
56+
if (!username) {
57+
alert("Пожалуйста, введите ваше имя перед началом записи."); // Предупреждение, если имя не введено
58+
return;
59+
}
60+
61+
navigator.mediaDevices.getDisplayMedia({
62+
video: true,
63+
audio: true
64+
}).then((stream) => {
65+
startRecording(stream);
66+
}).catch((error) => {
67+
console.error("Ошибка при получении медиа-данных:", error);
68+
});
69+
});
70+
71+
document.getElementById('stopBtn').addEventListener('click', stopRecording);

playground/client/style.css

Lines changed: 59 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
body {
2+
font-family: Arial, sans-serif;
3+
background-color: #f0f4ff;
4+
color: #333;
5+
display: flex;
6+
justify-content: center;
7+
align-items: center;
8+
height: 100vh;
9+
margin: 0;
10+
}
11+
12+
.container {
13+
text-align: center;
14+
background-color: #ffffff;
15+
padding: 20px;
16+
border-radius: 10px;
17+
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
18+
}
19+
20+
h1 {
21+
color: #007bff;
22+
margin-bottom: 20px;
23+
}
24+
25+
.input {
26+
padding: 10px;
27+
margin-bottom: 20px;
28+
border: 1px solid #007bff;
29+
border-radius: 5px;
30+
width: 100%;
31+
max-width: 300px;
32+
}
33+
34+
.button-container {
35+
display: flex;
36+
justify-content: center;
37+
gap: 20px;
38+
}
39+
40+
.button {
41+
background-color: #007bff;
42+
color: white;
43+
border: none;
44+
border-radius: 5px;
45+
padding: 10px 20px;
46+
font-size: 16px;
47+
cursor: pointer;
48+
transition: background-color 0.3s, transform 0.2s;
49+
}
50+
51+
.button:hover {
52+
background-color: #0056b3;
53+
transform: translateY(-2px);
54+
}
55+
56+
.button:disabled {
57+
background-color: #cccccc;
58+
cursor: not-allowed;
59+
}

0 commit comments

Comments
 (0)