Menu

Blox Fruit Mammoth Fruit Plush - Roblox Blox Fruit Plush

Availability:
Brand: Blox Fruits
SKU:{{ product.sku }}
Write a review
{{ product.price_format }}
{{ product.origin_price_format }}

{{ variable.name }}

{{ value.name }}

Quantity:

Payment & Security

Your payment information is processed securely. We do not store credit card details nor have access to your credit card information.
  • Product Details
  • Shipping & Returns
  • Review

 

  • 【Funny Design】The B-lox fruits plush toy design takes inspiration from the beloved game, incorporating its vibrant and adorable elements to accurately capture the style characteristics.
  • 【Safe Material】B-lox fruits plushies is made of super soft plush material, the inner layer is PP cotton, which is soft and comfortable, will not fall off easily and cause any peculiar smell.
  • 【Great for Kids and Fans】B-lox fruits plush is more than just a toy; It's an expression of love for the game and its vibrant characters. It is an irresistible gift for fans of all ages.
  • 【Great for Kids and Fans】B-lox fruits plush is more than just a toy; It's an expression of love for the game and its vibrant characters. It is an irresistible gift for fans of all ages.
  • 【Perfect Gift】The B-lox fruits plush is a best Birthday Christmas gift choice for your kids, friends, family.It's also a very cute decoration.nobody can refuse the plush toy gift.
You may also Like!
Blox Fruit Venom Fruit Plush - Roblox Blox Fruit Plush
$19.99
Blox Fruit Ice Fruit Plush - Roblox Blox Fruit Plush
$23.99
Blox Fruit Dragon Fruit Plush Roblox Blox Fruit Plush Toy
$26.99
Blox Fruit Buddha Fruit Plush - Roblox Blox Fruit Plush Toy
$21.90
Blox Fruit Chop Fruit 5.9" Plush
$15.89
Blox Fruit Kitsune Plush Toy
$29.99
Blox Fruit Permanent Rumble Fruit Plush Toy ( 6" Medium Plush )
$26.99
Uploaded Image
[[ message ]]
`, props: { productId: { type: Number, required: true }, productRating: { type: Number, required: true }, productRatingQty: { type: Number, required: true }, }, data() { return { reviews: [], isModalVisible: false, uploadedFileUrl: '', uploadedFileUrls: [], uploadedFileVal: '', newReview: { rating: 0, content: '' }, message: '', isError: false }; }, mounted() { this.fetchReviews(); }, methods: { fetchReviews() { this.reviews = $http.get(`/products/${this.productId}/reviews`).then(response => { console.log(response) // this.reviews = response.data; if(parseInt(response.code) === 0){ this.reviews = response.data.map(review => ({ ...review, rating: Number(review.rating) })); } }); }, showReviewModal() { this.$modal.show('review-modal'); }, closeReviewModal() { this.$modal.hide('review-modal'); this.newReview = { rating: 0, content: '' }; this.message = ''; }, submitReview() { console.log(this.newReview); // this.closeReviewModal(); if (this.newReview.content.trim() === '') { // this.message = 'review cannot be empty!'; // this.isError = true; layer.msg('review cannot be empty!'); return; } $http.post(`/products/${this.productId}/reviews_store`, { content: this.newReview.content, rating: this.newReview.rating, img_urls: this.uploadedFileUrls }).then(response => { console.log(new Date()); console.log('response', response); if(parseInt(response.code) > 0){ layer.msg(response.errorMessage.message); return } layer.msg("Thank you for your review"); this.closeReviewModal(); this.fetchReviews(); }).catch(error => { console.log('error', error); if (error.response && error.response.data.errors) { const errors = error.response.data.errors; layer.msg(errors.content ? errors.content[0] : 'Failed to submit, please try again!'); } }); }, handleFileUpload(event) { const file = event.target.files[0]; if (file) { const formData = new FormData(); formData.append('file', file); formData.append('type', 'product_reviews'); this.uploadFile(formData); } }, uploadFile(formData) { $http.post(`/products/${this.productId}/reviews_upload`, formData, { headers: { 'Content-Type': 'multipart/form-data' } }).then(response => { console.log('upload response', response); if(parseInt(response.code) > 0){ layer.msg(response.errorMessage.message); return } if(parseInt(response.code) === 0){ // this.uploadedFileUrl = response.data.url; // this.uploadedFileVal = response.data.value; this.uploadedFileUrls.push({ url: response.data.url, val: response.data.value }); } }).catch(error => { console.error('Upload error:', error); layer.msg('File upload error!') }); }, removeUploadedFile(index) { this.uploadedFileUrls.splice(index, 1); }, }, }); -->