Create Cart sidebar and controller

This commit is contained in:
Matt-Yorkley
2020-05-21 10:52:13 +02:00
parent 7290d68687
commit 85abfd2056
5 changed files with 220 additions and 207 deletions

View File

@@ -0,0 +1,5 @@
Darkswarm.controller "CartDropdownCtrl", ($scope) ->
$scope.showCartSidebar = false
$scope.toggleCartSidebar = ->
$scope.showCartSidebar = !$scope.showCartSidebar

View File

@@ -16,243 +16,241 @@ $sidebar-medium-width: 65%;
$sidebar-large-width: 45%;
$sidebar-footer-height: 5em;
.darkswarm {
.shop-filters-sidebar {
display: flex;
flex-direction: column;
.shop-filters-sidebar, .cart-sidebar {
display: flex;
flex-direction: column;
height: 100%;
.background {
position: fixed;
top: 0;
right: 0;
z-index: 200;
height: 100%;
width: 100%;
background-color: $shop-sidebar-overlay;
opacity: 0;
transition: opacity $transition-sidebar;
}
&.shown {
.background {
position: fixed;
top: 0;
right: 0;
z-index: 200;
height: 100%;
width: 100%;
background-color: $shop-sidebar-overlay;
opacity: 0;
transition: opacity $transition-sidebar;
opacity: 1;
}
&.shown {
.background {
opacity: 1;
}
.sidebar, .sidebar-footer {
margin-right: 0;
}
}
.sidebar {
position: fixed;
top: 0;
right: 0;
z-index: 210;
height: 100%;
width: $sidebar-large-width;
margin-right: -$sidebar-large-width;
background-color: rgba($white, 0.95);
padding: 1em;
transition: margin $transition-sidebar;
overflow-y: scroll;
.property-selectors {
margin-bottom: $sidebar-footer-height + 2em;
}
}
.sidebar-footer {
background-color: $grey-800;
width: $sidebar-large-width;
margin-right: -$sidebar-large-width;
height: $sidebar-footer-height;
position: fixed;
bottom: 0;
right: 0;
transition: margin $transition-sidebar;
padding: 1em;
button {
width: 48%;
}
}
@include breakpoint(tablet) {
.sidebar, .sidebar-footer {
width: $sidebar-medium-width;
margin-right: -$sidebar-medium-width;
}
}
@include breakpoint(mobile) {
.sidebar, .sidebar-footer {
width: $sidebar-small-width;
margin-right: -$sidebar-small-width;
}
.sidebar, .sidebar-footer {
margin-right: 0;
}
}
products {
.sidebar {
position: fixed;
top: 0;
right: 0;
z-index: 210;
height: 100%;
width: $sidebar-large-width;
margin-right: -$sidebar-large-width;
background-color: rgba($white, 0.95);
padding: 1em;
transition: margin $transition-sidebar;
overflow-y: scroll;
.property-selectors {
margin-bottom: $sidebar-footer-height + 2em;
}
}
.sidebar-footer {
background-color: $grey-800;
width: $sidebar-large-width;
margin-right: -$sidebar-large-width;
height: $sidebar-footer-height;
position: fixed;
bottom: 0;
right: 0;
transition: margin $transition-sidebar;
padding: 1em;
button {
width: 48%;
}
}
@include breakpoint(tablet) {
.sidebar, .sidebar-footer {
width: $sidebar-medium-width;
margin-right: -$sidebar-medium-width;
}
}
@include breakpoint(mobile) {
.sidebar, .sidebar-footer {
width: $sidebar-small-width;
margin-right: -$sidebar-small-width;
}
}
}
products {
display: block;
@include breakpoint(tablet) {
input.button.right {
float: left;
}
}
@include breakpoint(mobile) {
.add_to_cart {
margin-top: 2rem;
}
}
form {
input.small.button.primary.right.add_to_cart {
&.dirty {
padding-left: 3.2rem;
}
}
i.cart-spinner {
position: absolute;
top: 14px;
right: 146px;
color: white;
font-size: 1.2em;
// Necessary to be below Z index of cart popover:
z-index: 98;
-webkit-animation: spin 2s infinite linear;
animation: spin 2s infinite linear;
}
}
product {
@include csstrans;
border-bottom: 1px solid #e5e5e5;
border-top: 1px solid #e5e5e5;
padding-bottom: 1px;
margin-bottom: 20px !important;
position: relative;
display: block;
color: $med-drk-grey;
@include breakpoint(tablet) {
input.button.right {
float: left;
&:hover, &:focus, &:active {
border-bottom: 1px solid $clr-brick-med-bright;
border-top: 1px solid $clr-brick-med-bright;
}
// BULK
.bulk-buy {
font-size: 0.875rem;
@include breakpoint(tablet) {
font-size: 0.75rem;
}
}
@include breakpoint(mobile) {
.add_to_cart {
margin-top: 2rem;
.bulk-buy, .bulk-buy i {
color: #888;
}
.inline {
display: inline;
}
.spinner {
width: 100px;
margin-bottom: 20px;
}
// ICONS
i {
font-size: 0.75em;
padding-right: 0.9375rem;
@include breakpoint(phablet) {
padding-right: 0.25rem;
}
}
form {
input.small.button.primary.right.add_to_cart {
&.dirty {
padding-left: 3.2rem;
}
}
i.cart-spinner {
position: absolute;
top: 14px;
right: 146px;
color: white;
font-size: 1.2em;
// Necessary to be below Z index of cart popover:
z-index: 98;
-webkit-animation: spin 2s infinite linear;
animation: spin 2s infinite linear;
}
i.ofn-i_056-bulk {
font-size: 1rem;
padding-right: 0rem;
}
product {
@include csstrans;
border-bottom: 1px solid #e5e5e5;
border-top: 1px solid #e5e5e5;
padding-bottom: 1px;
margin-bottom: 20px !important;
position: relative;
display: block;
color: $med-drk-grey;
&:hover, &:focus, &:active {
border-bottom: 1px solid $clr-brick-med-bright;
border-top: 1px solid $clr-brick-med-bright;
}
// BULK
.bulk-buy {
font-size: 0.875rem;
@include breakpoint(tablet) {
font-size: 0.75rem;
}
}
.bulk-buy, .bulk-buy i {
color: #888;
}
.inline {
display: inline;
}
.spinner {
width: 100px;
margin-bottom: 20px;
}
// ICONS
i {
font-size: 0.75em;
padding-right: 0.9375rem;
@include breakpoint(phablet) {
padding-right: 0.25rem;
}
}
i.ofn-i_056-bulk {
font-size: 1rem;
padding-right: 0rem;
}
i.ofn-i_036-producers {
padding-left: 0.2rem;
padding-right: 0rem;
font-size: 0.8rem;
}
i.ofn-i_036-producers {
padding-left: 0.2rem;
padding-right: 0rem;
font-size: 0.8rem;
}
}
}
.alert-box.changeable-orders-alert {
margin-bottom: 0px;
.alert-box.changeable-orders-alert {
margin-bottom: 0px;
}
.select-oc-message {
margin-top: 1rem;
.highlighted {
color: $red-700;
font-weight: bold;
}
}
.select-oc-message {
margin-top: 1rem;
.open-shop-message {
a {
color: #0096ad;
.highlighted {
color: $red-700;
font-weight: bold;
&:hover, &:focus, &:active {
text-decoration: none;
color: #4aadbd;
}
}
}
.open-shop-message {
a {
color: #0096ad;
.closed-shop-header {
background-color: $grey-650;
color: $white;
&:hover, &:focus, &:active {
text-decoration: none;
color: #4aadbd;
}
}
}
.closed-shop-header {
background-color: $grey-650;
h4 {
color: $white;
h4 {
color: $white;
}
p {
margin: 1rem 0 0.4rem;
}
.message {
display: inline-block;
}
}
p {
margin: 1rem 0 0.4rem;
}
.message {
display: inline-block;
}
}
.warning-sign {
margin: 0 10px 0 5px;
display: inline-block;
line-height: 1.9rem;
strong {
color: $grey-650;
display: block;
position: relative;
text-align: center;
width: 23px;
}
strong {
color: $grey-650;
display: block;
position: relative;
text-align: center;
width: 23px;
}
.rectangle {
background-color: $white;
border-radius: 4px;
color: $grey-650;
height: 23px;
position: absolute;
top: 27px;
transform: rotate(-315deg);
width: 23px;
}
.rectangle {
background-color: $white;
border-radius: 4px;
color: $grey-650;
height: 23px;
position: absolute;
top: 27px;
transform: rotate(-315deg);
width: 23px;
}
}

View File

@@ -0,0 +1,8 @@
.cart-sidebar{ng: {show: 'showCartSidebar', class: "{'shown': showCartSidebar, 'hidden': !showCartSidebar}"}}
.background{ng: {click: 'toggleCartSidebar()'}}
.sidebar
.sidebar-footer
%button.large.dark.left{type: 'button'}
Edit Cart
%button.large.bright.right{type: 'button', ng: {click: 'toggleCartSidebar()'}}
Checkout

View File

@@ -1,4 +1,6 @@
= render "shared/menu/large_menu"
%ofn-flash
= render "shared/menu/mobile_menu"
= render "shared/menu/offcanvas_menu"
%div{'ng-controller' => 'CartDropdownCtrl'}
= render "shared/menu/large_menu"
%ofn-flash
= render "shared/menu/mobile_menu"
= render "shared/menu/offcanvas_menu"
= render "shared/menu/cart_sidebar"

View File

@@ -9,8 +9,8 @@
%img{src: ContentConfig.logo_mobile.url, srcset: ContentConfig.logo_mobile_svg.url, width: "75", height: "26"}
%section.right{"ng-cloak" => true}
%span.cart-span{"ng-controller" => "CartCtrl", "ng-class" => "{ dirty: Cart.dirty || Cart.empty(), 'pure-dirty': Cart.dirty }"}
%a.icon{href: main_app.cart_path}
%span.cart-span{"ng-class" => "{ dirty: Cart.dirty || Cart.empty(), 'pure-dirty': Cart.dirty }"}
%a.icon{ng: {click: 'toggleCartSidebar()'}}
%span
= t '.cart'
%span.count