[WIP]: Add styling to itemPage

- added smooth transformation
- added nav
This commit is contained in:
Luis S. Ruisinger
2022-06-06 20:33:15 +02:00
parent e3942b5d16
commit 243cc4cf06

View File

@@ -1,6 +1,6 @@
<template> <template>
<div class="main"> <div class="main">
<h1 class="email">{{userEmail}}</h1> <h1 class="email">{{ userEmail }}</h1>
<section class="itemapp"> <section class="itemapp">
<div v-if="loading"> <div v-if="loading">
<h1 class="loading">Loading...</h1> <h1 class="loading">Loading...</h1>
@@ -38,13 +38,16 @@
<!-- input field --> <!-- input field -->
<header class="inputField-header"> <header class="inputField-header">
<input class="newItemName" id="inputTextField" autofocus autocomplete="off" placeholder=" " v-model="newItem" @keyup.enter="addItem"/> <input class="newItemName" id="inputTextField" autofocus autocomplete="off" placeholder=" " v-model="newItem"
@keyup.enter="addItem"/>
<label for="inputTextField" class="formLabel"> <label for="inputTextField" class="formLabel">
Add here Add here ...
</label> </label>
</header> </header>
<section class="main" v-show="items.length" v-cloak> <!-- response element -->
<section class="item-section" v-show="items.length" v-cloak>
<ul class="item-list"> <ul class="item-list">
<li v-for="item in items" <li v-for="item in items"
class="item" class="item"
@@ -65,16 +68,16 @@
<script> <script>
import api from '../Api'; import api from '../Api';
const Items = { const Items = {
name: 'Items', name: 'Items',
props: { props: {
activeUser: Object activeUser: Object
}, },
// app initial state // app initial state
data: function() { data: function () {
return { return {
items: [], items: [],
newItem: '', newItem: '',
@@ -117,14 +120,14 @@
var components = value.split(' ') var components = value.split(' ')
api.createNew(components[0], api.createNew(components[0],
parseInt(components[1].replace ( /[^\d.]/g, '' )), parseInt(components[1].replace(/[^\d.]/g, '')),
components[1].replace(/[0-9]/g, '') === 'ml' ? 'MILLILETERS' : "GRAMMS" components[1].replace(/[0-9]/g, '') === 'ml' ? 'MILLILETERS' : "GRAMMS"
).then( (response) => { ).then((response) => {
this.$log.debug("New item created:", response); this.$log.debug("New item created:", response);
this.items.push({ this.items.push({
id: response.data.id, id: response.data.id,
name: components[0], name: components[0],
quantity: parseInt(components[1].replace ( /[^\d.]/g, '' )), quantity: parseInt(components[1].replace(/[^\d.]/g, '')),
unit: components[1].replace(/[0-9]/g, '') === 'MILLILETERS' ? 'ml' : 'g' unit: components[1].replace(/[0-9]/g, '') === 'MILLILETERS' ? 'ml' : 'g'
}) })
}).catch((error) => { }).catch((error) => {
@@ -153,8 +156,7 @@
} }
} }
} }
}
}
export default Items export default Items
</script> </script>
@@ -170,7 +172,7 @@ export default Items
padding: 0; padding: 0;
} }
.main{ .main {
font-family: 'Montserrat', sans-serif; font-family: 'Montserrat', sans-serif;
height: 100vh; height: 100vh;
display: grid; display: grid;
@@ -180,9 +182,19 @@ export default Items
background-color: darkcyan; background-color: darkcyan;
} }
/* cursor styling */
.cursor {
width: 1rem;
height: 1rem;
border: 0.15rem solid black;
border-radius: 100%;
position: absolute;
}
/* navbar styling */ /* navbar styling */
.navbar-header{ .navbar-header {
position: fixed; position: fixed;
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
@@ -194,47 +206,46 @@ export default Items
color: black; color: black;
z-index: 1; z-index: 1;
a{ a {
text-decoration: none; text-decoration: none;
color: inherit; color: inherit;
text-transform: uppercase; text-transform: uppercase;
font-size: 2rem; font-size: 2rem;
} }
.nav-links{ .nav-links {
display: flex; display: flex;
list-style: none; list-style: none;
.nav-link{ a {
a{
margin: 0.2rem; margin: 0.2rem;
padding: 1rem 0.5rem; padding: 1rem 0.5rem;
transition: all 300ms;
} }
a:hover{ a:hover {
font-size: 3.5rem; font-size: 3.5rem;
transition: all 300ms;
}
}
}
} .menu-icon {
}
}
.menu-icon{
position: relative; position: relative;
padding: 26px 10px; padding: 26px 10px;
cursor: pointer; cursor: pointer;
z-index: 1; z-index: 1;
display: none; display: none;
&__line{ &__line {
display: block; display: block;
position: relative; position: relative;
background: black; background: black;
height: 5px; height: 2.5px;
width: 40px; width: 3rem;
border-radius: 4px; border-radius: 4px;
&::before, &::after{ &::before, &::after {
content: ''; content: '';
position: absolute; position: absolute;
height: 100%; height: 100%;
@@ -244,49 +255,50 @@ export default Items
transition: background .8s ease; transition: background .8s ease;
} }
&::before{ &::before {
transform: translateY(-10px); transform: translateY(-10px);
} }
&::after{ &::after {
transform: translateY(10px); transform: translateY(10px);
} }
} }
}
.menu-btn{
display: none;
}
} }
.logo:hover{ .menu-btn {
display: none;
}
.logo:hover {
cursor: default; cursor: default;
} }
@media screen { @media screen {
.navbar-header{ .navbar-header {
.menu-icon{ .menu-icon {
display: block; display: block;
font-weight: bold;
&__line{ &__line {
animation: closedButton 0.8s backwards; animation: closedButton 1s backwards;
animation-direction: reverse; animation-direction: reverse;
&::before{ &::before {
animation: closedButtonBefore 0.8s backwards; animation: closedButtonBefore 1s backwards;
animation-direction: reverse; animation-direction: reverse;
} }
&::after{ &::after {
animation: closedButtonAfter 0.8s backwards; animation: closedButtonAfter 1s backwards;
animation-direction: reverse; animation-direction: reverse;
} }
} }
} }
.nav-links{ .nav-links {
position: absolute; position: absolute;
top: -2.5rem; top: -2.5rem;
left: 0; left: 0;
@@ -298,51 +310,52 @@ export default Items
width: 100vw; width: 100vw;
height: 100vh; height: 100vh;
font-size: 2rem; font-size: 2rem;
font-weight: bolder;
letter-spacing: 0.25rem;
color: white; color: white;
background: #272727; background: #272727;
transition: transition: opacity 0.8s 0.5s,
opacity 0.8s 0.5s,
clip-path 1s 0.5s; clip-path 1s 0.5s;
clip-path: circle(200px at top right); clip-path: circle(200px at top right);
.nav-links{ .nav-links {
opacity: 0; opacity: 0;
transform: translateX(100%); transform: translateX(100%);
width: 100%; width: 100%;
text-align: center; text-align: center;
a{ a {
display: block; display: block;
padding: 2rem 0; padding: 2rem 0;
} }
} }
} }
.menu-btn:checked ~ .nav-links{ .menu-btn:checked ~ .nav-links {
opacity: 1; opacity: 1;
clip-path: circle(100% at center); clip-path: circle(100% at center);
.nav-link{ .nav-link {
opacity: 1; opacity: 1;
transform: translateX(0); transform: translateX(0);
} }
} }
.menu-btn:checked ~ .menu-icon{ .menu-btn:checked ~ .menu-icon {
.menu-icon__line{ .menu-icon__line {
background: white; background: white;
animation: openButton 0.8s forwards; animation: openButton 1s forwards;
&::before{ &::before {
background: white; background: white;
animation: openButtonBefore 0.8s forwards; animation: openButtonBefore 1s forwards;
} }
&::after{ &::after {
background: white; background: white;
animation: openButtonAfter 0.8s forwards; animation: openButtonAfter 1s forwards;
} }
} }
} }
@@ -350,79 +363,79 @@ export default Items
} }
@keyframes openButtonBefore { @keyframes openButtonBefore {
0%{ 0% {
transform: translateY(-10px) rotate(0deg); transform: translateY(-10px) rotate(0deg);
} }
50%{ 50% {
transform: translateY(0px) rotate(0deg); transform: translateY(0px) rotate(0deg);
} }
100%{ 100% {
transform: translateY(0px) rotate(90deg); transform: translateY(0px) rotate(90deg);
} }
} }
@keyframes openButton { @keyframes openButton {
50%{ 50% {
transform: rotate(0deg); transform: rotate(0deg);
} }
100%{ 100% {
transform: rotate(45deg); transform: rotate(45deg);
} }
} }
@keyframes openButtonAfter { @keyframes openButtonAfter {
0%{ 0% {
transform: translateY(10px) rotate(0deg); transform: translateY(10px) rotate(0deg);
} }
50%{ 50% {
transform: translateY(0px) rotate(0deg); transform: translateY(0px) rotate(0deg);
} }
100%{ 100% {
transform: translateY(0px) rotate(90deg); transform: translateY(0px) rotate(90deg);
} }
} }
@keyframes closedButtonBefore { @keyframes closedButtonBefore {
0%{ 0% {
transform: translateY(-10px) rotate(0deg); transform: translateY(-10px) rotate(0deg);
} }
50%{ 50% {
transform: translateY(0px) rotate(0deg); transform: translateY(0px) rotate(0deg);
} }
100%{ 100% {
transform: translateY(0px) rotate(90deg); transform: translateY(0px) rotate(90deg);
} }
} }
@keyframes closedButton { @keyframes closedButton {
50%{ 50% {
transform: rotate(0deg); transform: rotate(0deg);
} }
100%{ 100% {
transform: rotate(45deg); transform: rotate(45deg);
} }
} }
@keyframes closedButtonAfter { @keyframes closedButtonAfter {
0%{ 0% {
transform: translateY(10px) rotate(0deg); transform: translateY(10px) rotate(0deg);
} }
50%{ 50% {
transform: translateY(0px) rotate(0deg); transform: translateY(0px) rotate(0deg);
} }
100%{ 100% {
transform: translateY(0px) rotate(90deg); transform: translateY(0px) rotate(90deg);
} }
} }
/* input field styling */ /* input field styling */
.inputField-header{ .inputField-header {
position: relative; position: relative;
width: 20rem; width: 20rem;
} }
.newItemName{ .newItemName {
position: absolute; position: absolute;
top: -75rem; top: -75rem;
left: 0; left: 0;
@@ -436,18 +449,19 @@ export default Items
outline: none; outline: none;
padding: 1.5rem; padding: 1.5rem;
background: none; background: none;
box-shadow: 10px 10px 30px rgba(0, 0, 0, 0.4);
} }
.newItemName:hover{ .newItemName:hover {
border-color: black; border-color: black;
} }
.newItemName:focus{ .newItemName:focus {
border-color: black; border-color: black;
} }
.formLabel{ .formLabel {
position: absolute; position: absolute;
left: 1rem; left: 1rem;
top: -74.5rem; top: -74.5rem;
@@ -458,18 +472,22 @@ export default Items
background-color: darkcyan; background-color: darkcyan;
} }
.newItemName:hover ~ .formLabel, .newItemName:not(:placeholder-shown).newItemName:not(:hover) ~ .formLabel{ .newItemName:hover ~ .formLabel, .newItemName:not(:placeholder-shown).newItemName:not(:hover) ~ .formLabel {
top: -76.25rem; top: -76.25rem;
left: 0.25rem; left: 0.25rem;
font-size: 0.00001rem; font-size: 0.00001rem;
color: black; color: black;
// set context here
} }
.newItemName:focus ~ .formLabel, .newItemName:not(:placeholder-shown).newItemName:not(:focus) ~ .formLabel{ .newItemName:focus ~ .formLabel, .newItemName:not(:placeholder-shown).newItemName:not(:focus) ~ .formLabel {
top: -76.25rem; top: -76.25rem;
left: 0.25rem; left: 0.25rem;
font-size: 0.00001rem; font-size: 0.00001rem;
color: black; color: black;
// set context here
} }
/* item section */
</style> </style>