72 lines
2.3 KiB
JavaScript
72 lines
2.3 KiB
JavaScript
// Required modules
|
|
const router = require('express').Router();
|
|
const util = require("./../utilities/utilities.js");
|
|
const moment = require("moment");
|
|
|
|
router.get("/", async function(req, res) {
|
|
try {
|
|
let conn;
|
|
try {
|
|
conn = await util.getDBConnection(); // get connection from db
|
|
const result = await conn.query("SELECT item_content FROM item_info;");
|
|
res.json(result);
|
|
}
|
|
catch(e) {
|
|
console.error(e);
|
|
res.json({suc : false});
|
|
}
|
|
finally {
|
|
util.closeDBConnection(conn); // close db connection
|
|
}
|
|
}
|
|
catch(e) {
|
|
console.log(e);
|
|
}
|
|
})
|
|
|
|
router.post("/", async function(req, res) {
|
|
try {
|
|
let conn;
|
|
try {
|
|
console.log(req.body);
|
|
// data
|
|
const apply_infos = req.body.apply_infos; // get data from request
|
|
const time = moment(new Date()).format("YYYY-MM-DD");
|
|
|
|
conn = await util.getDBConnection(); // get connection from db
|
|
await conn.beginTransaction();
|
|
|
|
// insert data into table : scholarship_application
|
|
const scholarship_application_info = await conn.batch("INSERT INTO scholarship_application(`application_date`, `student_id`) VALUES(?, ?);", [time, req.body.student_id]);
|
|
const scholarship_application_id = scholarship_application_info.insertId; // get the application_id of previous record
|
|
|
|
// 這邊你們要再改
|
|
const application_unit = "test unit";
|
|
const subsidy = 1000;
|
|
|
|
console.log(scholarship_application_info.insertId);
|
|
console.log(apply_infos);
|
|
|
|
// insert each apply item into item_form
|
|
for (let i = 0;i < apply_infos.length;i++) {
|
|
await conn.batch("INSERT INTO item_form(`application_id`, `item_info_id`, `application_unit`, `subsidy`) VALUES(?, ?, ?, ?);", [scholarship_application_id, apply_infos[i], application_unit, subsidy]);
|
|
}
|
|
await conn.commit();
|
|
|
|
res.json({suc : true});
|
|
}
|
|
catch(e) {
|
|
console.error(e);
|
|
await conn.rollback();
|
|
res.json({suc : false});
|
|
}
|
|
finally {
|
|
util.closeDBConnection(conn); // close db connection
|
|
}
|
|
}
|
|
catch(e) {
|
|
console.log(e);
|
|
}
|
|
})
|
|
|
|
module.exports = router; |