mirror of
https://github.com/eugene-serb/wavelovers.git
synced 2023-09-09 23:41:16 +03:00
Added drawing patterns
This commit is contained in:
parent
f47de2f1ae
commit
db70be9c79
@ -261,14 +261,7 @@ a {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.content__header {
|
.content__header {
|
||||||
font-size: 1.8em;
|
text-align: center;
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 32px;
|
|
||||||
padding-left: 16px;
|
|
||||||
border: 4px solid var(--color-background);
|
|
||||||
outline: 2px solid var(--color-border);
|
|
||||||
border-radius: 4px;
|
|
||||||
color: var(--color-header);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------ */
|
/* ------ */
|
||||||
@ -353,14 +346,35 @@ a {
|
|||||||
grid-template-columns: repeat(3, 1fr);
|
grid-template-columns: repeat(3, 1fr);
|
||||||
}
|
}
|
||||||
|
|
||||||
.controls-banner {
|
.pattern-box {
|
||||||
width: 100%;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.controls-banner__list {
|
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
|
gap: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pattern-list {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
gap: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pattern-item {
|
||||||
|
width: 128px;
|
||||||
|
padding: 8px;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: 32px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pattern-item__icon{
|
||||||
|
font-size: 64px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pattern-item__name {
|
||||||
|
font-size: 16px;
|
||||||
|
white-space: nowrap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
18
index.html
18
index.html
@ -10,7 +10,7 @@
|
|||||||
<meta name="robots" content="all" />
|
<meta name="robots" content="all" />
|
||||||
|
|
||||||
<link rel="canonical" href="https://eugene-serb.github.io/wavelovers/" />
|
<link rel="canonical" href="https://eugene-serb.github.io/wavelovers/" />
|
||||||
<link rel="stylesheet" type="text/css" href="https://eugene-serb.github.io/wavelovers/css/styles.css" />
|
<link rel="stylesheet" type="text/css" href="css/styles.css" />
|
||||||
<link rel="shortcut icon" type="image/x-icon" href="https://eugene-serb.github.io/wavelovers/img/favicon.ico" />
|
<link rel="shortcut icon" type="image/x-icon" href="https://eugene-serb.github.io/wavelovers/img/favicon.ico" />
|
||||||
<link rel="apple-touch-icon" sizes="180x180" href="https://eugene-serb.github.io/wavelovers/apple-touch-icon.png" />
|
<link rel="apple-touch-icon" sizes="180x180" href="https://eugene-serb.github.io/wavelovers/apple-touch-icon.png" />
|
||||||
<link rel="icon" type="image/png" sizes="32x32" href="https://eugene-serb.github.io/wavelovers/favicon-32x32.png" />
|
<link rel="icon" type="image/png" sizes="32x32" href="https://eugene-serb.github.io/wavelovers/favicon-32x32.png" />
|
||||||
@ -83,16 +83,20 @@
|
|||||||
<main class="page container">
|
<main class="page container">
|
||||||
<h1 class="visually-hidden">Wavelovers</h1>
|
<h1 class="visually-hidden">Wavelovers</h1>
|
||||||
<div class="wavelovers">
|
<div class="wavelovers">
|
||||||
<div class="content message-box">
|
<div id="message-box" class="content message-box">
|
||||||
<span id="message"></span>
|
<span id="message"></span>
|
||||||
</div>
|
</div>
|
||||||
<div id="device-box" class="content device-box">
|
<div id="device-box" class="content device-box">
|
||||||
<h2>Device List</h2>
|
<h2 class="content__header">Device List</h2>
|
||||||
<div id="device-list" class="device-list"></div>
|
<div id="device-list" class="device-list"></div>
|
||||||
</div>
|
</div>
|
||||||
<section class="content controls-banner">
|
<div id="pattern-box" class="content pattern-box">
|
||||||
<h2 class="">Disclaimer</h2>
|
<h2 class="content__header">Patterns</h2>
|
||||||
<div class="controls-banner__list">
|
<div id="pattern-list" class="pattern-list"></div>
|
||||||
|
</div>
|
||||||
|
<section class="content">
|
||||||
|
<h2 class="content__header">Disclaimer</h2>
|
||||||
|
<div>
|
||||||
<span>
|
<span>
|
||||||
The author of the program code and the publisher is not responsible for the possible consequences of using the program. You use the program at your own risk. Check your device for correct operation. Please consult your doctor before using the program.
|
The author of the program code and the publisher is not responsible for the possible consequences of using the program. You use the program at your own risk. Check your device for correct operation. Please consult your doctor before using the program.
|
||||||
</span>
|
</span>
|
||||||
@ -110,7 +114,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</footer>
|
</footer>
|
||||||
|
|
||||||
<script src="https://eugene-serb.github.io/wavelovers/js/scripts.js"></script>
|
<script src="js/scripts.js"></script>
|
||||||
<script src="https://eugene-serb.github.io/js/scripts.js"></script>
|
<script src="https://eugene-serb.github.io/js/scripts.js"></script>
|
||||||
<noscript><div><img src="https://mc.yandex.ru/watch/79722217" style="position:absolute; left:-9999px;" alt="" /></div></noscript>
|
<noscript><div><img src="https://mc.yandex.ru/watch/79722217" style="position:absolute; left:-9999px;" alt="" /></div></noscript>
|
||||||
</body>
|
</body>
|
||||||
|
@ -9,6 +9,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Constant Weak',
|
name: 'Constant Weak',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '😏',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 0,
|
startDelay: 0,
|
||||||
@ -21,6 +22,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Constant Strong',
|
name: 'Constant Strong',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '🤩',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 0,
|
startDelay: 0,
|
||||||
@ -33,6 +35,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Constant Max',
|
name: 'Constant Max',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '😍',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 0,
|
startDelay: 0,
|
||||||
@ -46,6 +49,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Dotted Weak',
|
name: 'Dotted Weak',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '😌',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 100,
|
startDelay: 100,
|
||||||
@ -58,6 +62,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Dotted Strong',
|
name: 'Dotted Strong',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '😉',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 100,
|
startDelay: 100,
|
||||||
@ -70,6 +75,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Dotted Max',
|
name: 'Dotted Max',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '🙃',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 0,
|
startDelay: 0,
|
||||||
@ -83,6 +89,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Short Dashed Weak',
|
name: 'Short Dashed Weak',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '🙂',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 100,
|
startDelay: 100,
|
||||||
@ -95,6 +102,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Short Dashed Strong',
|
name: 'Short Dashed Strong',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '😇',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 100,
|
startDelay: 100,
|
||||||
@ -107,6 +115,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Short Dashed Max',
|
name: 'Short Dashed Max',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '😊',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 0,
|
startDelay: 0,
|
||||||
@ -120,6 +129,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Long Dashed Weak',
|
name: 'Long Dashed Weak',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '😋',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 100,
|
startDelay: 100,
|
||||||
@ -132,6 +142,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Long Dashed Strong',
|
name: 'Long Dashed Strong',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '😜',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 100,
|
startDelay: 100,
|
||||||
@ -144,6 +155,7 @@ const __PATTERNS = [
|
|||||||
{
|
{
|
||||||
name: 'Long Dashed Max',
|
name: 'Long Dashed Max',
|
||||||
type: 'Simple',
|
type: 'Simple',
|
||||||
|
icon: '🤪',
|
||||||
pattern: [
|
pattern: [
|
||||||
{
|
{
|
||||||
startDelay: 0,
|
startDelay: 0,
|
||||||
@ -290,6 +302,7 @@ class VibrationMaster {
|
|||||||
};
|
};
|
||||||
init = () => {
|
init = () => {
|
||||||
this.#DOMs();
|
this.#DOMs();
|
||||||
|
this.print(__PATTERNS);
|
||||||
|
|
||||||
if (!this.checkGamepadSupport()) {
|
if (!this.checkGamepadSupport()) {
|
||||||
console.log(`This browser does not support of gamepads.`);
|
console.log(`This browser does not support of gamepads.`);
|
||||||
@ -363,11 +376,24 @@ class VibrationMaster {
|
|||||||
return 'getGamepads' in window.navigator;
|
return 'getGamepads' in window.navigator;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
print = (patterns) => {
|
||||||
|
patterns.forEach(pattern => {
|
||||||
|
this.$PATTERN_LIST.innerHTML += `
|
||||||
|
<div class="pattern-item">
|
||||||
|
<span class="pattern-item__icon">${pattern.icon}</span>
|
||||||
|
<span class="pattern-item__name">${pattern.name}</span>
|
||||||
|
</div>
|
||||||
|
`;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
#DOMs = () => {
|
#DOMs = () => {
|
||||||
|
this.$MESSAGE_BOX = document.querySelector('#message-box');
|
||||||
this.$MESSAGE = document.querySelector('#message');
|
this.$MESSAGE = document.querySelector('#message');
|
||||||
this.$MESSAGE_BOX = document.querySelector('.message-box');
|
|
||||||
this.$DEVICE_LIST = document.querySelector('#device-list');
|
|
||||||
this.$DEVICE_BOX = document.querySelector('#device-box');
|
this.$DEVICE_BOX = document.querySelector('#device-box');
|
||||||
|
this.$DEVICE_LIST = document.querySelector('#device-list');
|
||||||
|
this.$PATTERN_BOX = document.querySelector('#pattern-box');
|
||||||
|
this.$PATTERN_LIST = document.querySelector('#pattern-list');
|
||||||
};
|
};
|
||||||
#eventListeners = () => {
|
#eventListeners = () => {
|
||||||
window.addEventListener('gamepadconnected', (event) => {
|
window.addEventListener('gamepadconnected', (event) => {
|
||||||
|
Loading…
Reference in New Issue
Block a user