Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Sign in / Register
Toggle navigation
T
test-webshop
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Artem
test-webshop
Commits
5a088784
Commit
5a088784
authored
May 15, 2020
by
Artem
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add notification plugin, show notification when product added to cart
parent
01ca406c
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
709 additions
and
2 deletions
+709
-2
toastr.css
public/css/plugins/toastr.css
+228
-0
cart.js
public/js/cart.js
+1
-1
toastr.js
public/js/plugins/toastr.js
+476
-0
welcome.js
public/js/welcome.js
+2
-1
app.blade.php
resources/views/layouts/app.blade.php
+2
-0
No files found.
public/css/plugins/toastr.css
0 → 100644
View file @
5a088784
.toast-title
{
font-weight
:
bold
;
}
.toast-message
{
-ms-word-wrap
:
break-word
;
word-wrap
:
break-word
;
}
.toast-message
a
,
.toast-message
label
{
color
:
#FFFFFF
;
}
.toast-message
a
:hover
{
color
:
#CCCCCC
;
text-decoration
:
none
;
}
.toast-close-button
{
position
:
relative
;
right
:
-0.3em
;
top
:
-0.3em
;
float
:
right
;
font-size
:
20px
;
font-weight
:
bold
;
color
:
#FFFFFF
;
-webkit-text-shadow
:
0
1px
0
#ffffff
;
text-shadow
:
0
1px
0
#ffffff
;
opacity
:
0.8
;
-ms-filter
:
progid
:
DXImageTransform
.
Microsoft
.
Alpha
(
Opacity
=
80
);
filter
:
alpha
(
opacity
=
80
);
line-height
:
1
;
}
.toast-close-button
:hover
,
.toast-close-button
:focus
{
color
:
#000000
;
text-decoration
:
none
;
cursor
:
pointer
;
opacity
:
0.4
;
-ms-filter
:
progid
:
DXImageTransform
.
Microsoft
.
Alpha
(
Opacity
=
40
);
filter
:
alpha
(
opacity
=
40
);
}
.rtl
.toast-close-button
{
left
:
-0.3em
;
float
:
left
;
right
:
0.3em
;
}
/*Additional properties for button version
iOS requires the button element instead of an anchor tag.
If you want the anchor version, it requires `href="#"`.*/
button
.toast-close-button
{
padding
:
0
;
cursor
:
pointer
;
background
:
transparent
;
border
:
0
;
-webkit-appearance
:
none
;
}
.toast-top-center
{
top
:
0
;
right
:
0
;
width
:
100%
;
}
.toast-bottom-center
{
bottom
:
0
;
right
:
0
;
width
:
100%
;
}
.toast-top-full-width
{
top
:
0
;
right
:
0
;
width
:
100%
;
}
.toast-bottom-full-width
{
bottom
:
0
;
right
:
0
;
width
:
100%
;
}
.toast-top-left
{
top
:
12px
;
left
:
12px
;
}
.toast-top-right
{
top
:
12px
;
right
:
12px
;
}
.toast-bottom-right
{
right
:
12px
;
bottom
:
12px
;
}
.toast-bottom-left
{
bottom
:
12px
;
left
:
12px
;
}
#toast-container
{
position
:
fixed
;
z-index
:
999999
;
pointer-events
:
none
;
/*overrides*/
}
#toast-container
*
{
-moz-box-sizing
:
border-box
;
-webkit-box-sizing
:
border-box
;
box-sizing
:
border-box
;
}
#toast-container
>
div
{
position
:
relative
;
pointer-events
:
auto
;
overflow
:
hidden
;
margin
:
0
0
6px
;
padding
:
15px
15px
15px
50px
;
width
:
300px
;
-moz-border-radius
:
3px
3px
3px
3px
;
-webkit-border-radius
:
3px
3px
3px
3px
;
border-radius
:
3px
3px
3px
3px
;
background-position
:
15px
center
;
background-repeat
:
no-repeat
;
-moz-box-shadow
:
0
0
12px
#999999
;
-webkit-box-shadow
:
0
0
12px
#999999
;
box-shadow
:
0
0
12px
#999999
;
color
:
#FFFFFF
;
opacity
:
0.8
;
-ms-filter
:
progid
:
DXImageTransform
.
Microsoft
.
Alpha
(
Opacity
=
80
);
filter
:
alpha
(
opacity
=
80
);
}
#toast-container
>
div
.rtl
{
direction
:
rtl
;
padding
:
15px
50px
15px
15px
;
background-position
:
right
15px
center
;
}
#toast-container
>
div
:hover
{
-moz-box-shadow
:
0
0
12px
#000000
;
-webkit-box-shadow
:
0
0
12px
#000000
;
box-shadow
:
0
0
12px
#000000
;
opacity
:
1
;
-ms-filter
:
progid
:
DXImageTransform
.
Microsoft
.
Alpha
(
Opacity
=
100
);
filter
:
alpha
(
opacity
=
100
);
cursor
:
pointer
;
}
#toast-container
>
.toast-info
{
background-image
:
url("")
!important
;
}
#toast-container
>
.toast-error
{
background-image
:
url("")
!important
;
}
#toast-container
>
.toast-success
{
background-image
:
url("")
!important
;
}
#toast-container
>
.toast-warning
{
background-image
:
url("")
!important
;
}
#toast-container
.toast-top-center
>
div
,
#toast-container
.toast-bottom-center
>
div
{
width
:
300px
;
margin-left
:
auto
;
margin-right
:
auto
;
}
#toast-container
.toast-top-full-width
>
div
,
#toast-container
.toast-bottom-full-width
>
div
{
width
:
96%
;
margin-left
:
auto
;
margin-right
:
auto
;
}
.toast
{
background-color
:
#030303
;
}
.toast-success
{
background-color
:
#51A351
;
}
.toast-error
{
background-color
:
#BD362F
;
}
.toast-info
{
background-color
:
#2F96B4
;
}
.toast-warning
{
background-color
:
#F89406
;
}
.toast-progress
{
position
:
absolute
;
left
:
0
;
bottom
:
0
;
height
:
4px
;
background-color
:
#000000
;
opacity
:
0.4
;
-ms-filter
:
progid
:
DXImageTransform
.
Microsoft
.
Alpha
(
Opacity
=
40
);
filter
:
alpha
(
opacity
=
40
);
}
/*Responsive Design*/
@media
all
and
(
max-width
:
240px
)
{
#toast-container
>
div
{
padding
:
8px
8px
8px
50px
;
width
:
11em
;
}
#toast-container
>
div
.rtl
{
padding
:
8px
50px
8px
8px
;
}
#toast-container
.toast-close-button
{
right
:
-0.2em
;
top
:
-0.2em
;
}
#toast-container
.rtl
.toast-close-button
{
left
:
-0.2em
;
right
:
0.2em
;
}
}
@media
all
and
(
min-width
:
241px
)
and
(
max-width
:
480px
)
{
#toast-container
>
div
{
padding
:
8px
8px
8px
50px
;
width
:
18em
;
}
#toast-container
>
div
.rtl
{
padding
:
8px
50px
8px
8px
;
}
#toast-container
.toast-close-button
{
right
:
-0.2em
;
top
:
-0.2em
;
}
#toast-container
.rtl
.toast-close-button
{
left
:
-0.2em
;
right
:
0.2em
;
}
}
@media
all
and
(
min-width
:
481px
)
and
(
max-width
:
768px
)
{
#toast-container
>
div
{
padding
:
15px
15px
15px
50px
;
width
:
25em
;
}
#toast-container
>
div
.rtl
{
padding
:
15px
50px
15px
15px
;
}
}
public/js/cart.js
View file @
5a088784
...
...
@@ -45,7 +45,7 @@ function setRemoveItemEventListener() {
})
.
catch
(
function
(
error
)
{
console
.
log
(
error
);
alert
(
'Sorry, error, we are just learning how to code
'
);
toastr
.
error
(
'Error, something went wrong
'
);
});
});
}
...
...
public/js/plugins/toastr.js
0 → 100644
View file @
5a088784
/*
* Toastr
* Copyright 2012-2015
* Authors: John Papa, Hans Fjällemark, and Tim Ferrell.
* All Rights Reserved.
* Use, reproduction, distribution, and modification of this code is subject to the terms and
* conditions of the MIT license, available at http://www.opensource.org/licenses/mit-license.php
*
* ARIA Support: Greta Krafsig
*
* Project: https://github.com/CodeSeven/toastr
*/
/* global define */
(
function
(
define
)
{
define
([
'jquery'
],
function
(
$
)
{
return
(
function
()
{
var
$container
;
var
listener
;
var
toastId
=
0
;
var
toastType
=
{
error
:
'error'
,
info
:
'info'
,
success
:
'success'
,
warning
:
'warning'
};
var
toastr
=
{
clear
:
clear
,
remove
:
remove
,
error
:
error
,
getContainer
:
getContainer
,
info
:
info
,
options
:
{},
subscribe
:
subscribe
,
success
:
success
,
version
:
'2.1.4'
,
warning
:
warning
};
var
previousToast
;
return
toastr
;
////////////////
function
error
(
message
,
title
,
optionsOverride
)
{
return
notify
({
type
:
toastType
.
error
,
iconClass
:
getOptions
().
iconClasses
.
error
,
message
:
message
,
optionsOverride
:
optionsOverride
,
title
:
title
});
}
function
getContainer
(
options
,
create
)
{
if
(
!
options
)
{
options
=
getOptions
();
}
$container
=
$
(
'#'
+
options
.
containerId
);
if
(
$container
.
length
)
{
return
$container
;
}
if
(
create
)
{
$container
=
createContainer
(
options
);
}
return
$container
;
}
function
info
(
message
,
title
,
optionsOverride
)
{
return
notify
({
type
:
toastType
.
info
,
iconClass
:
getOptions
().
iconClasses
.
info
,
message
:
message
,
optionsOverride
:
optionsOverride
,
title
:
title
});
}
function
subscribe
(
callback
)
{
listener
=
callback
;
}
function
success
(
message
,
title
,
optionsOverride
)
{
return
notify
({
type
:
toastType
.
success
,
iconClass
:
getOptions
().
iconClasses
.
success
,
message
:
message
,
optionsOverride
:
optionsOverride
,
title
:
title
});
}
function
warning
(
message
,
title
,
optionsOverride
)
{
return
notify
({
type
:
toastType
.
warning
,
iconClass
:
getOptions
().
iconClasses
.
warning
,
message
:
message
,
optionsOverride
:
optionsOverride
,
title
:
title
});
}
function
clear
(
$toastElement
,
clearOptions
)
{
var
options
=
getOptions
();
if
(
!
$container
)
{
getContainer
(
options
);
}
if
(
!
clearToast
(
$toastElement
,
options
,
clearOptions
))
{
clearContainer
(
options
);
}
}
function
remove
(
$toastElement
)
{
var
options
=
getOptions
();
if
(
!
$container
)
{
getContainer
(
options
);
}
if
(
$toastElement
&&
$
(
':focus'
,
$toastElement
).
length
===
0
)
{
removeToast
(
$toastElement
);
return
;
}
if
(
$container
.
children
().
length
)
{
$container
.
remove
();
}
}
// internal functions
function
clearContainer
(
options
)
{
var
toastsToClear
=
$container
.
children
();
for
(
var
i
=
toastsToClear
.
length
-
1
;
i
>=
0
;
i
--
)
{
clearToast
(
$
(
toastsToClear
[
i
]),
options
);
}
}
function
clearToast
(
$toastElement
,
options
,
clearOptions
)
{
var
force
=
clearOptions
&&
clearOptions
.
force
?
clearOptions
.
force
:
false
;
if
(
$toastElement
&&
(
force
||
$
(
':focus'
,
$toastElement
).
length
===
0
))
{
$toastElement
[
options
.
hideMethod
]({
duration
:
options
.
hideDuration
,
easing
:
options
.
hideEasing
,
complete
:
function
()
{
removeToast
(
$toastElement
);
}
});
return
true
;
}
return
false
;
}
function
createContainer
(
options
)
{
$container
=
$
(
'<div/>'
)
.
attr
(
'id'
,
options
.
containerId
)
.
addClass
(
options
.
positionClass
);
$container
.
appendTo
(
$
(
options
.
target
));
return
$container
;
}
function
getDefaults
()
{
return
{
tapToDismiss
:
true
,
toastClass
:
'toast'
,
containerId
:
'toast-container'
,
debug
:
false
,
showMethod
:
'fadeIn'
,
//fadeIn, slideDown, and show are built into jQuery
showDuration
:
300
,
showEasing
:
'swing'
,
//swing and linear are built into jQuery
onShown
:
undefined
,
hideMethod
:
'fadeOut'
,
hideDuration
:
1000
,
hideEasing
:
'swing'
,
onHidden
:
undefined
,
closeMethod
:
false
,
closeDuration
:
false
,
closeEasing
:
false
,
closeOnHover
:
true
,
extendedTimeOut
:
1000
,
iconClasses
:
{
error
:
'toast-error'
,
info
:
'toast-info'
,
success
:
'toast-success'
,
warning
:
'toast-warning'
},
iconClass
:
'toast-info'
,
positionClass
:
'toast-top-right'
,
timeOut
:
1000
,
// Set timeOut and extendedTimeOut to 0 to make it sticky
titleClass
:
'toast-title'
,
messageClass
:
'toast-message'
,
escapeHtml
:
false
,
target
:
'body'
,
closeHtml
:
'<button type="button">×</button>'
,
closeClass
:
'toast-close-button'
,
newestOnTop
:
true
,
preventDuplicates
:
false
,
progressBar
:
false
,
progressClass
:
'toast-progress'
,
rtl
:
false
};
}
function
publish
(
args
)
{
if
(
!
listener
)
{
return
;
}
listener
(
args
);
}
function
notify
(
map
)
{
var
options
=
getOptions
();
var
iconClass
=
map
.
iconClass
||
options
.
iconClass
;
if
(
typeof
(
map
.
optionsOverride
)
!==
'undefined'
)
{
options
=
$
.
extend
(
options
,
map
.
optionsOverride
);
iconClass
=
map
.
optionsOverride
.
iconClass
||
iconClass
;
}
if
(
shouldExit
(
options
,
map
))
{
return
;
}
toastId
++
;
$container
=
getContainer
(
options
,
true
);
var
intervalId
=
null
;
var
$toastElement
=
$
(
'<div/>'
);
var
$titleElement
=
$
(
'<div/>'
);
var
$messageElement
=
$
(
'<div/>'
);
var
$progressElement
=
$
(
'<div/>'
);
var
$closeElement
=
$
(
options
.
closeHtml
);
var
progressBar
=
{
intervalId
:
null
,
hideEta
:
null
,
maxHideTime
:
null
};
var
response
=
{
toastId
:
toastId
,
state
:
'visible'
,
startTime
:
new
Date
(),
options
:
options
,
map
:
map
};
personalizeToast
();
displayToast
();
handleEvents
();
publish
(
response
);
if
(
options
.
debug
&&
console
)
{
console
.
log
(
response
);
}
return
$toastElement
;
function
escapeHtml
(
source
)
{
if
(
source
==
null
)
{
source
=
''
;
}
return
source
.
replace
(
/&/g
,
'&'
)
.
replace
(
/"/g
,
'"'
)
.
replace
(
/'/g
,
'''
)
.
replace
(
/</g
,
'<'
)
.
replace
(
/>/g
,
'>'
);
}
function
personalizeToast
()
{
setIcon
();
setTitle
();
setMessage
();
setCloseButton
();
setProgressBar
();
setRTL
();
setSequence
();
setAria
();
}
function
setAria
()
{
var
ariaValue
=
''
;
switch
(
map
.
iconClass
)
{
case
'toast-success'
:
case
'toast-info'
:
ariaValue
=
'polite'
;
break
;
default
:
ariaValue
=
'assertive'
;
}
$toastElement
.
attr
(
'aria-live'
,
ariaValue
);
}
function
handleEvents
()
{
if
(
options
.
closeOnHover
)
{
$toastElement
.
hover
(
stickAround
,
delayedHideToast
);
}
if
(
!
options
.
onclick
&&
options
.
tapToDismiss
)
{
$toastElement
.
click
(
hideToast
);
}
if
(
options
.
closeButton
&&
$closeElement
)
{
$closeElement
.
click
(
function
(
event
)
{
if
(
event
.
stopPropagation
)
{
event
.
stopPropagation
();
}
else
if
(
event
.
cancelBubble
!==
undefined
&&
event
.
cancelBubble
!==
true
)
{
event
.
cancelBubble
=
true
;
}
if
(
options
.
onCloseClick
)
{
options
.
onCloseClick
(
event
);
}
hideToast
(
true
);
});
}
if
(
options
.
onclick
)
{
$toastElement
.
click
(
function
(
event
)
{
options
.
onclick
(
event
);
hideToast
();
});
}
}
function
displayToast
()
{
$toastElement
.
hide
();
$toastElement
[
options
.
showMethod
](
{
duration
:
options
.
showDuration
,
easing
:
options
.
showEasing
,
complete
:
options
.
onShown
}
);
if
(
options
.
timeOut
>
0
)
{
intervalId
=
setTimeout
(
hideToast
,
options
.
timeOut
);
progressBar
.
maxHideTime
=
parseFloat
(
options
.
timeOut
);
progressBar
.
hideEta
=
new
Date
().
getTime
()
+
progressBar
.
maxHideTime
;
if
(
options
.
progressBar
)
{
progressBar
.
intervalId
=
setInterval
(
updateProgress
,
10
);
}
}
}
function
setIcon
()
{
if
(
map
.
iconClass
)
{
$toastElement
.
addClass
(
options
.
toastClass
).
addClass
(
iconClass
);
}
}
function
setSequence
()
{
if
(
options
.
newestOnTop
)
{
$container
.
prepend
(
$toastElement
);
}
else
{
$container
.
append
(
$toastElement
);
}
}
function
setTitle
()
{
if
(
map
.
title
)
{
var
suffix
=
map
.
title
;
if
(
options
.
escapeHtml
)
{
suffix
=
escapeHtml
(
map
.
title
);
}
$titleElement
.
append
(
suffix
).
addClass
(
options
.
titleClass
);
$toastElement
.
append
(
$titleElement
);
}
}
function
setMessage
()
{
if
(
map
.
message
)
{
var
suffix
=
map
.
message
;
if
(
options
.
escapeHtml
)
{
suffix
=
escapeHtml
(
map
.
message
);
}
$messageElement
.
append
(
suffix
).
addClass
(
options
.
messageClass
);
$toastElement
.
append
(
$messageElement
);
}
}
function
setCloseButton
()
{
if
(
options
.
closeButton
)
{
$closeElement
.
addClass
(
options
.
closeClass
).
attr
(
'role'
,
'button'
);
$toastElement
.
prepend
(
$closeElement
);
}
}
function
setProgressBar
()
{
if
(
options
.
progressBar
)
{
$progressElement
.
addClass
(
options
.
progressClass
);
$toastElement
.
prepend
(
$progressElement
);
}
}
function
setRTL
()
{
if
(
options
.
rtl
)
{
$toastElement
.
addClass
(
'rtl'
);
}
}
function
shouldExit
(
options
,
map
)
{
if
(
options
.
preventDuplicates
)
{
if
(
map
.
message
===
previousToast
)
{
return
true
;
}
else
{
previousToast
=
map
.
message
;
}
}
return
false
;
}
function
hideToast
(
override
)
{
var
method
=
override
&&
options
.
closeMethod
!==
false
?
options
.
closeMethod
:
options
.
hideMethod
;
var
duration
=
override
&&
options
.
closeDuration
!==
false
?
options
.
closeDuration
:
options
.
hideDuration
;
var
easing
=
override
&&
options
.
closeEasing
!==
false
?
options
.
closeEasing
:
options
.
hideEasing
;
if
(
$
(
':focus'
,
$toastElement
).
length
&&
!
override
)
{
return
;
}
clearTimeout
(
progressBar
.
intervalId
);
return
$toastElement
[
method
]({
duration
:
duration
,
easing
:
easing
,
complete
:
function
()
{
removeToast
(
$toastElement
);
clearTimeout
(
intervalId
);
if
(
options
.
onHidden
&&
response
.
state
!==
'hidden'
)
{
options
.
onHidden
();
}
response
.
state
=
'hidden'
;
response
.
endTime
=
new
Date
();
publish
(
response
);
}
});
}
function
delayedHideToast
()
{
if
(
options
.
timeOut
>
0
||
options
.
extendedTimeOut
>
0
)
{
intervalId
=
setTimeout
(
hideToast
,
options
.
extendedTimeOut
);
progressBar
.
maxHideTime
=
parseFloat
(
options
.
extendedTimeOut
);
progressBar
.
hideEta
=
new
Date
().
getTime
()
+
progressBar
.
maxHideTime
;
}
}
function
stickAround
()
{
clearTimeout
(
intervalId
);
progressBar
.
hideEta
=
0
;
$toastElement
.
stop
(
true
,
true
)[
options
.
showMethod
](
{
duration
:
options
.
showDuration
,
easing
:
options
.
showEasing
}
);
}
function
updateProgress
()
{
var
percentage
=
((
progressBar
.
hideEta
-
(
new
Date
().
getTime
()))
/
progressBar
.
maxHideTime
)
*
100
;
$progressElement
.
width
(
percentage
+
'%'
);
}
}
function
getOptions
()
{
return
$
.
extend
({},
getDefaults
(),
toastr
.
options
);
}
function
removeToast
(
$toastElement
)
{
if
(
!
$container
)
{
$container
=
getContainer
();
}
if
(
$toastElement
.
is
(
':visible'
))
{
return
;
}
$toastElement
.
remove
();
$toastElement
=
null
;
if
(
$container
.
children
().
length
===
0
)
{
$container
.
remove
();
previousToast
=
undefined
;
}
}
})();
});
}(
typeof
define
===
'function'
&&
define
.
amd
?
define
:
function
(
deps
,
factory
)
{
if
(
typeof
module
!==
'undefined'
&&
module
.
exports
)
{
//Node
module
.
exports
=
factory
(
require
(
'jquery'
));
}
else
{
window
.
toastr
=
factory
(
window
.
jQuery
);
}
}));
public/js/welcome.js
View file @
5a088784
...
...
@@ -8,10 +8,11 @@ function setAddToCardEventListener() {
.
then
(
function
(
response
)
{
const
cartAmountElem
=
document
.
querySelector
(
'.amount-in-cart'
);
cartAmountElem
.
textContent
=
response
.
data
;
toastr
.
success
(
'Product added to cart'
);
})
.
catch
(
function
(
error
)
{
console
.
log
(
error
);
alert
(
'Sorry, error, we are just learning how to code
'
);
toastr
.
error
(
'Error, something went wrong
'
);
});
});
}
...
...
resources/views/layouts/app.blade.php
View file @
5a088784
...
...
@@ -11,9 +11,11 @@
<!-- Scripts -->
<script
src=
"{{ asset('js/app.js') }}"
defer
></script>
<script
src=
"{{ asset('js/plugins/toastr.js') }}"
defer
></script>
<!-- Styles -->
<link
href=
"{{ asset('css/app.css') }}"
rel=
"stylesheet"
>
<link
href=
"{{ asset('css/plugins/toastr.css') }}"
rel=
"stylesheet"
>
@yield('pagecss')
</head>
<body>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment