|
1 | | -// --- API Endpoints --- |
2 | | - |
3 | | -// Handle CORS preflight OPTIONS requests (no custom headers possible) |
4 | | -function doOptions(e) { |
5 | | - // Google Apps Script does not support setting CORS headers for APIs. |
6 | | - // This will just return a 200 OK with a simple JSON body. |
7 | | - return ContentService.createTextOutput( |
8 | | - JSON.stringify({ status: "ok" }) |
9 | | - ) |
10 | | - .setMimeType(ContentService.MimeType.JSON); |
11 | | -} |
12 | | - |
13 | | -// Handle GET requests |
14 | | -function doGet(e) { |
15 | | - let responseData; |
16 | | - try { |
17 | | - const action = e.parameter.action; |
18 | | - |
19 | | - // Parse JSON parameters |
20 | | - const params = {}; |
21 | | - for (const key in e.parameter) { |
22 | | - if (key !== 'action' && key !== 'callback') { |
23 | | - try { |
24 | | - params[key] = JSON.parse(e.parameter[key]); |
25 | | - } catch (error) { |
26 | | - params[key] = e.parameter[key]; |
27 | | - } |
28 | | - } |
29 | | - } |
30 | | - |
31 | | - switch (action) { |
32 | | - case 'login': |
33 | | - responseData = loginUser(params.username, params.password); |
34 | | - break; |
35 | | - case 'register': |
36 | | - responseData = registerUser(params.username, params.password); |
37 | | - break; |
38 | | - case 'getTasks': |
39 | | - responseData = getTasks(params.username); |
40 | | - break; |
41 | | - case 'addTask': |
42 | | - responseData = addTask(params.task, params.username); |
43 | | - break; |
44 | | - case 'updateTask': |
45 | | - responseData = updateTask(params.taskId, params.updates, params.username); |
46 | | - break; |
47 | | - case 'getUsers': |
48 | | - responseData = getUsersList(); |
49 | | - break; |
50 | | - default: |
51 | | - responseData = { success: false, message: 'Invalid action' }; |
52 | | - } |
53 | | - } catch (error) { |
54 | | - responseData = { success: false, message: 'Error: ' + error.toString() }; |
55 | | - } |
56 | | - |
57 | | - // Handle JSONP callback |
58 | | - const callback = e.parameter.callback; |
59 | | - if (callback) { |
60 | | - return ContentService.createTextOutput(callback + '(' + JSON.stringify(responseData) + ')') |
61 | | - .setMimeType(ContentService.MimeType.JAVASCRIPT); |
62 | | - } else { |
63 | | - return ContentService.createTextOutput(JSON.stringify(responseData)) |
64 | | - .setMimeType(ContentService.MimeType.JSON); |
65 | | - } |
| 1 | +// --- Main function to serve the web app --- |
| 2 | +function doGet() { |
| 3 | + return HtmlService.createTemplateFromFile('index') |
| 4 | + .evaluate() |
| 5 | + .setTitle('Friends Task Manager') |
| 6 | + .setXFrameOptionsMode(HtmlService.XFrameOptionsMode.ALLOWALL); |
66 | 7 | } |
67 | 8 |
|
68 | | -// Handle POST requests |
69 | | -function doPost(e) { |
70 | | - let responseData; |
71 | | - try { |
72 | | - const requestData = JSON.parse(e.postData.contents); |
73 | | - const action = requestData.action; |
74 | | - |
75 | | - switch (action) { |
76 | | - case 'login': |
77 | | - responseData = loginUser(requestData.username, requestData.password); |
78 | | - break; |
79 | | - case 'register': |
80 | | - responseData = registerUser(requestData.username, requestData.password); |
81 | | - break; |
82 | | - case 'getTasks': |
83 | | - responseData = getTasks(requestData.username); |
84 | | - break; |
85 | | - case 'addTask': |
86 | | - responseData = addTask(requestData.task, requestData.username); |
87 | | - break; |
88 | | - case 'updateTask': |
89 | | - responseData = updateTask(requestData.taskId, requestData.updates, requestData.username); |
90 | | - break; |
91 | | - case 'getUsers': |
92 | | - responseData = getUsersList(); |
93 | | - break; |
94 | | - default: |
95 | | - responseData = { success: false, message: 'Invalid action' }; |
96 | | - } |
97 | | - } catch (error) { |
98 | | - responseData = { success: false, message: 'Error: ' + error.toString(), stack: error.stack }; |
99 | | - } |
100 | | - |
101 | | - return ContentService.createTextOutput(JSON.stringify(responseData)) |
102 | | - .setMimeType(ContentService.MimeType.JSON); |
| 9 | +// --- Include HTML, CSS, JS files --- |
| 10 | +function include(filename) { |
| 11 | + return HtmlService.createHtmlOutputFromFile(filename).getContent(); |
103 | 12 | } |
104 | 13 |
|
105 | 14 | // --- Configuration --- |
106 | | -const SPREADSHEET_ID = SpreadsheetApp.getActiveSpreadsheet().getId(); |
107 | 15 | const TASKS_SHEET_NAME = "Tasks"; |
108 | 16 | const USERS_SHEET_NAME = "Users"; |
109 | 17 |
|
110 | 18 | // --- Helper Functions --- |
111 | 19 | function getSheet(sheetName) { |
112 | | - return SpreadsheetApp.openById(SPREADSHEET_ID).getSheetByName(sheetName); |
| 20 | + return SpreadsheetApp.getActiveSpreadsheet().getSheetByName(sheetName); |
113 | 21 | } |
114 | 22 |
|
115 | 23 | function generateUniqueId() { |
116 | 24 | return Utilities.getUuid(); |
117 | 25 | } |
118 | 26 |
|
119 | 27 | function setupSheetsIfNeeded() { |
120 | | - const ss = SpreadsheetApp.openById(SPREADSHEET_ID); |
| 28 | + const ss = SpreadsheetApp.getActiveSpreadsheet(); |
121 | 29 |
|
122 | 30 | // Check and create Users sheet if needed |
123 | 31 | let usersSheet = ss.getSheetByName(USERS_SHEET_NAME); |
@@ -187,7 +95,7 @@ function getUsersList() { |
187 | 95 | } |
188 | 96 |
|
189 | 97 | // --- Task Management --- |
190 | | -function getTasks(username) { |
| 98 | +function getTasks() { |
191 | 99 | setupSheetsIfNeeded(); |
192 | 100 | const tasksSheet = getSheet(TASKS_SHEET_NAME); |
193 | 101 | if (!tasksSheet) return { success: false, tasks: [], message: 'Tasks sheet not found.' }; |
|
0 commit comments