1. version
This commit is contained in:
parent
bf1b7dc0f9
commit
776ea21ad9
34
server.js
34
server.js
|
|
@ -3,7 +3,7 @@ const { Pool } = require('pg');
|
||||||
const multer = require('multer');
|
const multer = require('multer');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const puppeteer = require('puppeteer');
|
const puppeteer = require('puppeteer-core');
|
||||||
|
|
||||||
const app = express();
|
const app = express();
|
||||||
const PORT = process.env.PORT || 3000;
|
const PORT = process.env.PORT || 3000;
|
||||||
|
|
@ -173,6 +173,17 @@ app.get('/api/quotes', async (req, res) => {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Get next quote number (MUST be before /:id route)
|
||||||
|
app.get('/api/quotes/next-number', async (req, res) => {
|
||||||
|
try {
|
||||||
|
const quoteNumber = await generateQuoteNumber();
|
||||||
|
res.json({ quote_number: quoteNumber });
|
||||||
|
} catch (err) {
|
||||||
|
console.error(err);
|
||||||
|
res.status(500).json({ error: 'Error generating quote number' });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
app.get('/api/quotes/:id', async (req, res) => {
|
app.get('/api/quotes/:id', async (req, res) => {
|
||||||
try {
|
try {
|
||||||
const quoteResult = await pool.query(
|
const quoteResult = await pool.query(
|
||||||
|
|
@ -347,17 +358,6 @@ app.delete('/api/quotes/:id', async (req, res) => {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Get next quote number
|
|
||||||
app.get('/api/quotes/next-number', async (req, res) => {
|
|
||||||
try {
|
|
||||||
const quoteNumber = await generateQuoteNumber();
|
|
||||||
res.json({ quote_number: quoteNumber });
|
|
||||||
} catch (err) {
|
|
||||||
console.error(err);
|
|
||||||
res.status(500).json({ error: 'Error generating quote number' });
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// Upload logo
|
// Upload logo
|
||||||
app.post('/api/upload-logo', upload.single('logo'), (req, res) => {
|
app.post('/api/upload-logo', upload.single('logo'), (req, res) => {
|
||||||
if (!req.file) {
|
if (!req.file) {
|
||||||
|
|
@ -399,8 +399,14 @@ app.post('/api/quotes/:id/pdf', async (req, res) => {
|
||||||
|
|
||||||
// Generate PDF with Puppeteer
|
// Generate PDF with Puppeteer
|
||||||
const browser = await puppeteer.launch({
|
const browser = await puppeteer.launch({
|
||||||
headless: 'new',
|
executablePath: process.env.PUPPETEER_EXECUTABLE_PATH || '/usr/bin/chromium-browser',
|
||||||
args: ['--no-sandbox', '--disable-setuid-sandbox']
|
headless: true,
|
||||||
|
args: [
|
||||||
|
'--no-sandbox',
|
||||||
|
'--disable-setuid-sandbox',
|
||||||
|
'--disable-dev-shm-usage',
|
||||||
|
'--disable-gpu'
|
||||||
|
]
|
||||||
});
|
});
|
||||||
const page = await browser.newPage();
|
const page = await browser.newPage();
|
||||||
await page.setContent(html, { waitUntil: 'networkidle0' });
|
await page.setContent(html, { waitUntil: 'networkidle0' });
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue