Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
WebKuliner2021
Project
Overview
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
Tiarro Elprida Tamba
WebKuliner2021
Commits
cca7217e
Commit
cca7217e
authored
4 years ago
by
Tiarro Elprida Tamba
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Upload New File
parent
1a3ee8ca
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
191 additions
and
0 deletions
+191
-0
Keranjang.vue
WebKuliner/src/views/Keranjang.vue
+191
-0
No files found.
WebKuliner/src/views/Keranjang.vue
0 → 100644
View file @
cca7217e
<
template
>
<div
class=
"keranjang"
>
<Navbar
:updateKeranjang=
"keranjangs"
/>
<div
class=
"container"
>
<!--Breadcrumb-->
<div
class=
"row mt-5"
>
<div
class=
"col"
>
<nav
aria-label=
"breadcrumb"
>
<ol
class=
"breadcrumb"
>
<li
class=
"breadcrumb-item"
>
<router-link
to=
"/"
class=
"text-dark"
>
Home
</router-link>
</li>
<li
class=
"breadcrumb-item"
>
<router-link
to=
"/foods"
class=
"text-dark"
>
Foods
</router-link>
</li>
<li
class=
"breadcrumb-item active"
aria-current=
"page"
>
Keranjang
</li>
</ol>
</nav>
</div>
</div>
<div
class=
"row"
>
<div
class=
"col"
>
<h2>
Keranjang
<strong>
Saya
</strong></h2>
<div
class=
"table-responsive mt-3"
>
<table
class=
"table"
>
<thead>
<tr>
<th
scope=
"col"
>
#
</th>
<th
scope=
"col"
>
Foto
</th>
<th
scope=
"col"
>
Makanan
</th>
<th
scope=
"col"
>
Keterangan
</th>
<th
scope=
"col"
>
Jumlah
</th>
<th
scope=
"col"
>
Harga
</th>
<th
scope=
"col"
>
Total Harga
</th>
<th
scope=
"col"
>
Hapus
</th>
</tr>
</thead>
<tbody>
<tr
v-for=
"(keranjang, index) in keranjangs"
:key=
"keranjang.id"
>
<th>
{{
index
+
1
}}
</th>
<td>
<img
:src=
"'../assests/images/' + keranjang.products.gambar"
class=
"img-fluid shadow"
width=
"250"
/>
</td>
<td>
<strong>
{{
keranjang
.
products
.
nama
}}
</strong>
</td>
<td>
{{
keranjang
.
keterangan
?
keranjang
.
keterangan
:
"-"
}}
</td>
<td>
{{
keranjang
.
jumlah_pemesanan
}}
</td>
<td
align=
"right"
>
Rp.
{{
keranjang
.
products
.
harga
}}
</td>
<td
align=
"right"
>
<strong
>
Rp.
{{
keranjang
.
products
.
harga
*
keranjang
.
jumlah_pemesanan
}}
</strong
>
</td>
<td
align=
"center"
class=
"text-danger"
>
<b-icon-trash
@
click=
"hapusKeranjang(keranjang.id)"
>
{
</b-icon-trash>
</td>
</tr>
<tr>
<td
colspan=
"6"
align=
"right"
>
<strong>
Total Harga :
</strong>
</td>
<td
colspan=
"1"
align=
"right"
>
<strong>
Rp.
{{
totalHarga
}}
</strong>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
<!-- Form Checkout -->
<div
class=
"row justify-content-end"
>
<div
class=
"col-md-"
>
<form
class=
"mt-4"
v-on:submit
.
prevent
>
<div
class=
"form-group"
>
<label
for=
"nama"
>
Nama :
</label>
<input
type=
"text"
class=
"form-control"
v-model=
"pesan.nama"
/>
</div>
<div
class=
"form-group"
>
<label
for=
"noMeja"
>
Nomor Meja :
</label>
<input
type=
"text"
class=
"form-control"
v-model=
"pesan.noMeja"
/>
</div>
<button
type=
"submit"
class=
"btn btn-success float-right"
@
click=
"checkout"
>
<b-icon-cart></b-icon-cart>
Pesan
</button>
</form>
</div>
</div>
</div>
</div>
</
template
>
<
script
>
import
Navbar
from
"@/components/Navbar.vue"
;
import
axios
from
"axios"
;
export
default
{
name
:
"Keranjang"
,
components
:
{
Navbar
,
},
data
()
{
return
{
keranjangs
:
[],
pesan
:
{},
};
},
methods
:
{
setKeranjangs
(
data
)
{
this
.
keranjangs
=
data
;
},
hapusKeranjang
(
id
)
{
axios
.
delete
(
"http://localhost:3000/keranjangs/"
+
id
)
.
then
(()
=>
{
this
.
$toast
.
error
(
"Sukses Hapus Keranjang"
,
{
type
:
"success"
,
position
:
"top-right"
,
duration
:
3000
,
dismissible
:
true
,
});
//update Data Keranjang
axios
.
get
(
"http://localhost:3000/keranjangs"
)
.
then
((
response
)
=>
this
.
setKeranjangs
(
response
.
data
))
.
catch
((
error
)
=>
console
.
log
(
error
));
})
.
catch
((
error
)
=>
console
.
log
(
error
));
},
checkout
()
{
if
(
this
.
pesan
.
nama
&&
this
.
pesan
.
noMeja
)
{
this
.
pesan
.
keranjangs
=
this
.
keranjangs
;
axios
.
post
(
"http://localhost:3000/pesanans"
,
this
.
pesan
)
.
then
(()
=>
{
// Hapus Semua Keranjang
this
.
keranjangs
.
map
(
function
(
item
)
{
return
axios
.
delete
(
"http://localhost:3000/keranjangs/"
+
item
.
id
)
.
catch
((
error
)
=>
console
.
log
(
error
));
});
this
.
$router
.
push
({
path
:
"/pesanan-sukses"
});
this
.
$toast
.
success
(
"Sukses Dipesan"
,
{
type
:
"success"
,
position
:
"top-right"
,
duration
:
3000
,
dismissible
:
true
,
});
})
.
catch
((
err
)
=>
console
.
log
(
err
));
}
else
{
this
.
$toast
.
error
(
"Nama dan Nomor Meja Harus diisi"
,
{
type
:
"error"
,
position
:
"top-right"
,
duration
:
3000
,
dismissible
:
true
,
});
}
},
},
mounted
()
{
axios
.
get
(
"http://localhost:3000/keranjangs"
)
.
then
((
response
)
=>
this
.
setKeranjangs
(
response
.
data
))
.
catch
((
error
)
=>
console
.
log
(
error
));
},
computed
:
{
totalHarga
()
{
return
this
.
keranjangs
.
reduce
(
function
(
items
,
data
)
{
return
items
+
data
.
products
.
harga
*
data
.
jumlah_pemesanan
;
},
0
);
},
},
};
</
script
>
<
style
>
</
style
>
This diff is collapsed.
Click to expand it.
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