Fix API endpoint for product insert

master
Mark Moffat 2019-12-16 14:10:56 +10:30
parent cd0b4e992f
commit 8a638a3324
4 changed files with 51 additions and 90 deletions

View File

@ -112,6 +112,37 @@ $(document).ready(function (){
}); });
}); });
$('#productNewForm').validator().on('submit', function(e){
if(!e.isDefaultPrevented()){
e.preventDefault();
if($('#productPermalink').val() === '' && $('#productTitle').val() !== ''){
$('#productPermalink').val(slugify($('#productTitle').val()));
}
$.ajax({
method: 'POST',
url: '/admin/product/insert',
data: {
productTitle: $('#productTitle').val(),
productPrice: $('#productPrice').val(),
productPublished: $('#productPublished').val(),
productStock: $('#productStock').val(),
productDescription: $('#productDescription').val(),
productPermalink: $('#productPermalink').val(),
productOptions: $('#productOptions').val(),
productSubscription: $('#productSubscription').val(),
productComment: $('#productComment').is(':checked'),
productTags: $('#productTags').val()
}
})
.done(function(msg){
showNotification(msg.message, 'success', false, '/admin/product/edit/' + msg.productId);
})
.fail(function(msg){
showNotification(msg.responseJSON.message, 'danger');
});
}
});
$('#productEditForm').validator().on('submit', function(e){ $('#productEditForm').validator().on('submit', function(e){
if(!e.isDefaultPrevented()){ if(!e.isDefaultPrevented()){
e.preventDefault(); e.preventDefault();

File diff suppressed because one or more lines are too long

View File

@ -106,56 +106,15 @@ router.post('/admin/product/insert', restrict, checkAccess, async (req, res) =>
// Validate the body again schema // Validate the body again schema
const schemaValidate = validateJson('newProduct', doc); const schemaValidate = validateJson('newProduct', doc);
if(!schemaValidate.result){ if(!schemaValidate.result){
// If API request, return json
if(req.apiAuthenticated){
res.status(400).json(schemaValidate.errors);
return;
}
console.log('schemaValidate errors', schemaValidate.errors); console.log('schemaValidate errors', schemaValidate.errors);
req.session.message = 'Form invalid. Please check values and try again.'; res.status(400).json(schemaValidate.errors);
req.session.messageType = 'danger';
// keep the current stuff
req.session.productTitle = req.body.productTitle;
req.session.productDescription = req.body.productDescription;
req.session.productPrice = req.body.productPrice;
req.session.productPermalink = req.body.productPermalink;
req.session.productOptions = productOptions;
req.session.productComment = common.checkboxBool(req.body.productComment);
req.session.productTags = req.body.productTags;
req.session.productStock = req.body.productStock ? parseInt(req.body.productStock) : null;
// redirect to insert
res.redirect('/admin/product/new');
return; return;
} }
// Check permalink doesn't already exist // Check permalink doesn't already exist
const product = await db.products.countDocuments({ productPermalink: req.body.productPermalink }); const product = await db.products.countDocuments({ productPermalink: req.body.productPermalink });
if(product > 0 && req.body.productPermalink !== ''){ if(product > 0 && req.body.productPermalink !== ''){
// permalink exits res.status(400).json({ message: 'Permalink already exists. Pick a new one.' });
req.session.message = 'Permalink already exists. Pick a new one.';
req.session.messageType = 'danger';
// keep the current stuff
req.session.productTitle = req.body.productTitle;
req.session.productDescription = req.body.productDescription;
req.session.productPrice = req.body.productPrice;
req.session.productPermalink = req.body.productPermalink;
req.session.productOptions = productOptions;
req.session.productComment = common.checkboxBool(req.body.productComment);
req.session.productTags = req.body.productTags;
req.session.productStock = req.body.productStock ? parseInt(req.body.productStock) : null;
// If API request, return json
if(req.apiAuthenticated){
res.status(400).json({ message: 'Permalink already exists. Pick a new one.' });
return;
}
// redirect to insert
res.redirect('/admin/product/new');
return; return;
} }
@ -167,42 +126,14 @@ router.post('/admin/product/insert', restrict, checkAccess, async (req, res) =>
// add to lunr index // add to lunr index
indexProducts(req.app) indexProducts(req.app)
.then(() => { .then(() => {
req.session.message = 'New product successfully created'; res.status(200).json({
req.session.messageType = 'success'; message: 'New product successfully created',
productId: newId
// If API request, return json });
if(req.apiAuthenticated){
res.status(200).json({ message: 'New product successfully created' });
return;
}
// redirect to new doc
res.redirect('/admin/product/edit/' + newId);
}); });
}catch(ex){ }catch(ex){
console.log(colors.red('Error inserting document: ' + ex)); console.log(colors.red('Error inserting document: ' + ex));
res.status(400).json({ message: 'Error inserting document' });
// keep the current stuff
req.session.productTitle = req.body.productTitle;
req.session.productDescription = req.body.productDescription;
req.session.productPrice = req.body.productPrice;
req.session.productPermalink = req.body.productPermalink;
req.session.productOptions = productOptions;
req.session.productComment = common.checkboxBool(req.body.productComment);
req.session.productTags = req.body.productTags;
req.session.productStock = req.body.productStock ? parseInt(req.body.productStock) : null;
req.session.message = 'Error: Inserting product';
req.session.messageType = 'danger';
// If API request, return json
if(req.apiAuthenticated){
res.status(400).json({ message: 'Error inserting document' });
return;
}
// redirect to insert
res.redirect('/admin/product/new');
} }
}); });

View File

@ -1,6 +1,6 @@
{{> partials/menu}} {{> partials/menu}}
<div class="col-lg-9"> <div class="col-lg-9">
<form method="post" class="form-horizontal" id="insert_form" action="/admin/product/insert" data-toggle="validator"> <form class="form-horizontal" id="productNewForm" data-toggle="validator">
<div class="col-lg-12"> <div class="col-lg-12">
<div class="page-header"> <div class="page-header">
<div class="pull-right"> <div class="pull-right">
@ -11,7 +11,7 @@
<div class="form-group"> <div class="form-group">
<label for="productTitle" class="col-sm-2 control-label">{{ @root.__ "Product title" }} *</label> <label for="productTitle" class="col-sm-2 control-label">{{ @root.__ "Product title" }} *</label>
<div class="col-sm-10"> <div class="col-sm-10">
<input type="text" id="productTitle" name="productTitle" class="form-control" minlength="5" maxlength="200" value="{{productTitle}}" required/> <input type="text" id="productTitle" class="form-control" minlength="5" maxlength="200" value="{{productTitle}}" required/>
</div> </div>
</div> </div>
<div class="form-group"> <div class="form-group">
@ -19,14 +19,14 @@
<div class="col-sm-6"> <div class="col-sm-6">
<div class="input-group"> <div class="input-group">
<span class="input-group-addon">$</span> <span class="input-group-addon">$</span>
<input type="number" name="productPrice" class="form-control" step="any" value="{{productPrice}}" required/> <input type="number" id="productPrice" class="form-control" step="any" value="{{productPrice}}" required/>
</div> </div>
</div> </div>
</div> </div>
<div class="form-group"> <div class="form-group">
<label for="productPublished" class="col-sm-2 control-label">{{ @root.__ "Status" }}</label> <label for="productPublished" class="col-sm-2 control-label">{{ @root.__ "Status" }}</label>
<div class="col-sm-6"> <div class="col-sm-6">
<select class="form-control" id="productPublished" name="productPublished"> <select class="form-control" id="productPublished">
<option value="true" selected>{{ @root.__ "Published" }}</option> <option value="true" selected>{{ @root.__ "Published" }}</option>
<option value="false">{{ @root.__ "Draft" }}</option> <option value="false">{{ @root.__ "Draft" }}</option>
</select> </select>
@ -36,21 +36,21 @@
<div class="form-group"> <div class="form-group">
<label for="productStock" class="col-sm-2 control-label">{{ @root.__ "Stock level" }}</label> <label for="productStock" class="col-sm-2 control-label">{{ @root.__ "Stock level" }}</label>
<div class="col-sm-6"> <div class="col-sm-6">
<input type="number" name="productStock" class="form-control" value="{{productStock}}" step="any" /> <input type="number" id="productStock" class="form-control" value="{{productStock}}" step="any" />
</div> </div>
</div> </div>
{{/if}} {{/if}}
<div class="form-group" id="editor-wrapper"> <div class="form-group" id="editor-wrapper">
<label for="editor" class="col-sm-2 control-label">{{ @root.__ "Product description" }} *</label> <label for="editor" class="col-sm-2 control-label">{{ @root.__ "Product description" }} *</label>
<div class="col-sm-10"> <div class="col-sm-10">
<textarea id="editor" minlength="5" rows="10" name="productDescription" class="form-control" required>{{productDescription}}</textarea> <textarea minlength="5" rows="10" id="productDescription" class="form-control" required>{{productDescription}}</textarea>
</div> </div>
</div> </div>
<div class="form-group"> <div class="form-group">
<label class="col-sm-2 control-label">Permalink</label> <label class="col-sm-2 control-label">Permalink</label>
<div class="col-sm-10"> <div class="col-sm-10">
<div class="input-group"> <div class="input-group">
<input type="text" class="form-control" name="productPermalink" id="productPermalink" placeholder="Permalink for the article" value={{productPermalink}}> <input type="text" class="form-control" id="productPermalink" placeholder="Permalink for the article" value={{productPermalink}}>
<span class="input-group-btn"> <span class="input-group-btn">
<button class="btn btn-success" id="validate_permalink" type="button">Validate</button> <button class="btn btn-success" id="validate_permalink" type="button">Validate</button>
</span> </span>
@ -59,7 +59,7 @@
</div> </div>
</div> </div>
<div class="form-group"> <div class="form-group">
<input type="hidden" id="productOptions" name="productOptions" value="{{result.productOptions}}" /> <input type="hidden" id="productOptions" value="{{result.productOptions}}" />
<label for="editor" class="col-sm-2 control-label">{{ @root.__ "Product options" }}</label> <label for="editor" class="col-sm-2 control-label">{{ @root.__ "Product options" }}</label>
<div class="col-lg-10"> <div class="col-lg-10">
<ul class="list-group" id="product_opt_wrapper"> <ul class="list-group" id="product_opt_wrapper">
@ -110,7 +110,7 @@
<div class="form-group"> <div class="form-group">
<label class="col-sm-2 control-label">Subscription plan</label> <label class="col-sm-2 control-label">Subscription plan</label>
<div class="col-sm-10"> <div class="col-sm-10">
<input type="text" class="form-control" name="productSubscription" id="productSubscription" placeholder="plan_XXXXXXXXXXXXXX"> <input type="text" class="form-control" id="productSubscription" placeholder="plan_XXXXXXXXXXXXXX">
<p class="help-block">First setup the plan in <strong>Stripe</strong> dashboard and enter the Plan ID. Format: plan_XXXXXXXXXXXXXX</p> <p class="help-block">First setup the plan in <strong>Stripe</strong> dashboard and enter the Plan ID. Format: plan_XXXXXXXXXXXXXX</p>
</div> </div>
</div> </div>
@ -120,8 +120,7 @@
<div class="col-sm-10"> <div class="col-sm-10">
<div class="checkbox"> <div class="checkbox">
<label> <label>
<input class="productComment" type="checkbox" {{checkedState result.productComment}} id="productComment" <input class="productComment" type="checkbox" {{checkedState result.productComment}} id="productComment">
name="productComment">
</label> </label>
</div> </div>
<p class="help-block">{{ @root.__ "Allow free form comments when adding products to cart" }}</p> <p class="help-block">{{ @root.__ "Allow free form comments when adding products to cart" }}</p>
@ -130,7 +129,7 @@
<div class="form-group"> <div class="form-group">
<label for="productTags" class="col-sm-2 control-label">Product tag words</label> <label for="productTags" class="col-sm-2 control-label">Product tag words</label>
<div class="col-sm-10"> <div class="col-sm-10">
<input type="text" class="form-control" id="productTags" name="productTags"> <input type="text" class="form-control" id="productTags">
<p class="help-block">{{ @root.__ "Tag words used to indexed products, making them easier to find and filter." }}</p> <p class="help-block">{{ @root.__ "Tag words used to indexed products, making them easier to find and filter." }}</p>
</div> </div>
</div> </div>
@ -141,7 +140,7 @@
<link href="https://cdnjs.cloudflare.com/ajax/libs/summernote/0.8.2/summernote.css" rel="stylesheet"> <link href="https://cdnjs.cloudflare.com/ajax/libs/summernote/0.8.2/summernote.css" rel="stylesheet">
<script> <script>
$(document).ready(function() { $(document).ready(function() {
$('#editor').summernote({ $('#productDescription').summernote({
height: 300, height: 300,
minHeight: null minHeight: null
}); });