school.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424
  1. // 文件: school.js
  2. // 1. 显示一个公告信息弹窗
  3. async function demoAlert() {
  4. try {
  5. console.log("即将显示公告弹窗...");
  6. const confirmed = await window.AndroidBridgePromise.showAlert(
  7. "重要通知",
  8. "这是一个弹窗示例。",
  9. "好的"
  10. );
  11. if (confirmed) {
  12. console.log("用户点击了确认按钮。Alert Promise Resolved: " + confirmed);
  13. AndroidBridge.showToast("Alert:用户点击了确认!");
  14. return true; // 成功时返回 true
  15. } else {
  16. console.log("用户点击了取消按钮或关闭了弹窗。Alert Promise Resolved: " + confirmed);
  17. AndroidBridge.showToast("Alert:用户取消了!");
  18. return false; // 用户取消时返回 false
  19. }
  20. } catch (error) {
  21. console.error("显示公告弹窗时发生错误:", error);
  22. AndroidBridge.showToast("Alert:显示弹窗出错!" + error.message);
  23. return false; // 出现错误时也返回 false
  24. }
  25. }
  26. // 2. 显示带输入框的弹窗,并进行简单验证
  27. function validateName(name) {
  28. if (name === null || name.trim().length === 0) {
  29. return "输入不能为空!";
  30. }
  31. if (name.length < 2) {
  32. return "姓名至少需要2个字符!";
  33. }
  34. return false;
  35. }
  36. async function demoPrompt() {
  37. try {
  38. console.log("即将显示输入框弹窗...");
  39. const name = await window.AndroidBridgePromise.showPrompt(
  40. "输入你的姓名",
  41. "请输入至少2个字符",
  42. "测试用户",
  43. "validateName"
  44. );
  45. if (name !== null) {
  46. console.log("用户输入的姓名是: " + name);
  47. AndroidBridge.showToast("欢迎你," + name + "!");
  48. return true; // 成功时返回 true
  49. } else {
  50. console.log("用户取消了输入。");
  51. AndroidBridge.showToast("Prompt:用户取消了输入!");
  52. return false; // 用户取消时返回 false
  53. }
  54. } catch (error) {
  55. console.error("显示输入框弹窗时发生错误:", error);
  56. AndroidBridge.showToast("Prompt:显示输入框出错!" + error.message);
  57. return false; // 出现错误时也返回 false
  58. }
  59. }
  60. // 3. 显示一个单选列表弹窗
  61. async function demoSingleSelection() {
  62. const fruits = ["苹果", "香蕉", "橙子", "葡萄", "西瓜", "芒果"];
  63. try {
  64. console.log("即将显示单选列表弹窗...");
  65. const selectedIndex = await window.AndroidBridgePromise.showSingleSelection(
  66. "选择你喜欢的水果",
  67. JSON.stringify(fruits),
  68. 2
  69. );
  70. if (selectedIndex !== null && selectedIndex >= 0 && selectedIndex < fruits.length) {
  71. console.log("用户选择了: " + fruits[selectedIndex] + " (索引: " + selectedIndex + ")");
  72. AndroidBridge.showToast("你选择了 " + fruits[selectedIndex]);
  73. return true; // 成功时返回 true
  74. } else {
  75. console.log("用户取消了选择。");
  76. AndroidBridge.showToast("Single Selection:用户取消了选择!");
  77. return false; // 用户取消时返回 false
  78. }
  79. } catch (error) {
  80. console.error("显示单选列表弹窗时发生错误:", error);
  81. AndroidBridge.showToast("Single Selection:显示列表出错!" + error.message);
  82. return false; // 出现错误时也返回 false
  83. }
  84. }
  85. // 4. 导入课程数据
  86. async function demoSaveCourses() {
  87. console.log("正在准备测试课程数据...");
  88. const testCourses = [
  89. {
  90. "name": "高等数学",
  91. "teacher": "张教授",
  92. "position": "教101",
  93. "day": 1,
  94. "startSection": 1,
  95. "endSection": 2,
  96. "weeks": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
  97. },
  98. {
  99. "name": "测试自定义课程1",
  100. "teacher": "测试老师1",
  101. "position": "测试教室1",
  102. "day": 1,
  103. "isCustomTime": true,
  104. "customStartTime": "08:00",
  105. "customEndTime": "09:00",
  106. "weeks": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
  107. },
  108. {
  109. "name": "测试自定义课程2",
  110. "teacher": "测试老师2",
  111. "position": "测试教室2",
  112. "day": 3,
  113. "isCustomTime": true,
  114. "customStartTime": "06:00",
  115. "customEndTime": "12:00",
  116. "weeks": [3, 5, 7, 9, 11, 13, 15]
  117. },
  118. {
  119. "name": "大学英语",
  120. "teacher": "李老师",
  121. "position": "文史楼203",
  122. "day": 1,
  123. "startSection": 2,
  124. "endSection": 4,
  125. "weeks": [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]
  126. },
  127. {
  128. "name": "数据结构",
  129. "teacher": "王副教授",
  130. "position": "信息楼B301",
  131. "day": 7,
  132. "startSection": 2,
  133. "endSection": 2,
  134. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  135. },
  136. {
  137. "name": "数据结构",
  138. "teacher": "王副教授",
  139. "position": "信息楼B301",
  140. "day": 7,
  141. "startSection": 3,
  142. "endSection": 3,
  143. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  144. },
  145. {
  146. "name": "数据结构",
  147. "teacher": "王副教授",
  148. "position": "信息楼B301",
  149. "day": 7,
  150. "startSection": 4,
  151. "endSection": 4,
  152. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  153. },
  154. {
  155. "name": "数据结构",
  156. "teacher": "王副教授",
  157. "position": "信息楼B301",
  158. "day": 7,
  159. "startSection": 5,
  160. "endSection": 5,
  161. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  162. },
  163. {
  164. "name": "数据结构",
  165. "teacher": "王副教授",
  166. "position": "信息楼B301",
  167. "day": 7,
  168. "startSection": 6,
  169. "endSection": 6,
  170. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  171. },
  172. {
  173. "name": "计算机组成原理",
  174. "teacher": "赵教授",
  175. "position": "实验楼401",
  176. "day": 4,
  177. "startSection": 4,
  178. "endSection": 4,
  179. "weeks": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
  180. },
  181. {
  182. "name": "操作系统",
  183. "teacher": "钱副教授",
  184. "position": "信息楼C205",
  185. "day": 5,
  186. "startSection": 5,
  187. "endSection": 5,
  188. "weeks": [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]
  189. },
  190. {
  191. "name": "计算机网络",
  192. "teacher": "孙教授",
  193. "position": "信息楼D103",
  194. "day": 6,
  195. "startSection": 6,
  196. "endSection": 6,
  197. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  198. },
  199. {
  200. "name": "软件工程",
  201. "teacher": "周副教授",
  202. "position": "创新楼301",
  203. "day": 7,
  204. "startSection": 7,
  205. "endSection": 7,
  206. "weeks": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
  207. },
  208. {
  209. "name": "数据库原理",
  210. "teacher": "吴教授",
  211. "position": "信息楼E201",
  212. "day": 1,
  213. "startSection": 8,
  214. "endSection": 8,
  215. "weeks": [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]
  216. },
  217. {
  218. "name": "人工智能",
  219. "teacher": "郑副教授",
  220. "position": "智能楼101",
  221. "day": 2,
  222. "startSection": 9,
  223. "endSection": 9,
  224. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  225. },
  226. {
  227. "name": "机器学习",
  228. "teacher": "冯教授",
  229. "position": "智能楼203",
  230. "day": 3,
  231. "startSection": 10,
  232. "endSection": 10,
  233. "weeks": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
  234. },
  235. {
  236. "name": "编译原理",
  237. "teacher": "陈副教授",
  238. "position": "信息楼F105",
  239. "day": 4,
  240. "startSection": 11,
  241. "endSection": 11,
  242. "weeks": [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]
  243. },
  244. {
  245. "name": "计算机图形学",
  246. "teacher": "褚教授",
  247. "position": "图形楼301",
  248. "day": 5,
  249. "startSection": 12,
  250. "endSection": 12,
  251. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  252. },
  253. {
  254. "name": "网络安全",
  255. "teacher": "卫副教授",
  256. "position": "安全楼201",
  257. "day": 6,
  258. "startSection": 13,
  259. "endSection": 13,
  260. "weeks": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
  261. },
  262. {
  263. "name": "分布式系统",
  264. "teacher": "蒋教授",
  265. "position": "云楼101",
  266. "day": 7,
  267. "startSection": 14,
  268. "endSection": 14,
  269. "weeks": [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]
  270. },
  271. {
  272. "name": "大数据技术",
  273. "teacher": "沈副教授",
  274. "position": "数据楼301",
  275. "day": 1,
  276. "startSection": 15,
  277. "endSection": 15,
  278. "weeks": [2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
  279. },
  280. {
  281. "name": "物联网技术",
  282. "teacher": "韩教授",
  283. "position": "物联楼201",
  284. "day": 2,
  285. "startSection": 16,
  286. "endSection": 16,
  287. "weeks": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
  288. }
  289. ];
  290. try {
  291. console.log("正在尝试导入课程...");
  292. const result = await window.AndroidBridgePromise.saveImportedCourses(JSON.stringify(testCourses));
  293. if (result === true) {
  294. console.log("课程导入成功!");
  295. AndroidBridge.showToast("测试课程导入成功!");
  296. } else {
  297. console.log("课程导入未成功,结果:" + result);
  298. AndroidBridge.showToast("测试课程导入失败,请查看日志。");
  299. }
  300. } catch (error) {
  301. console.error("导入课程时发生错误:", error);
  302. AndroidBridge.showToast("导入课程失败: " + error.message);
  303. }
  304. }
  305. // 5. 导入预设时间段
  306. async function importPresetTimeSlots() {
  307. console.log("正在准备预设时间段数据...");
  308. const presetTimeSlots = [
  309. { "number": 1, "startTime": "08:00", "endTime": "08:01" },
  310. { "number": 2, "startTime": "09:00", "endTime": "09:01" },
  311. { "number": 3, "startTime": "10:00", "endTime": "10:01" },
  312. { "number": 4, "startTime": "11:00", "endTime": "11:01" },
  313. { "number": 5, "startTime": "12:00", "endTime": "12:01" },
  314. { "number": 6, "startTime": "13:00", "endTime": "13:01" },
  315. { "number": 7, "startTime": "14:00", "endTime": "14:01" },
  316. { "number": 8, "startTime": "15:00", "endTime": "15:01" },
  317. { "number": 9, "startTime": "16:00", "endTime": "16:01" },
  318. { "number": 10, "startTime": "17:00", "endTime": "17:01" },
  319. { "number": 11, "startTime": "18:00", "endTime": "18:01" },
  320. { "number": 12, "startTime": "19:00", "endTime": "19:01" },
  321. { "number": 13, "startTime": "20:00", "endTime": "20:01" },
  322. { "number": 14, "startTime": "21:00", "endTime": "21:01" },
  323. { "number": 15, "startTime": "22:00", "endTime": "22:01" },
  324. { "number": 16, "startTime": "23:00", "endTime": "23:01" }
  325. ];
  326. try {
  327. console.log("正在尝试导入预设时间段...");
  328. const result = await window.AndroidBridgePromise.savePresetTimeSlots(JSON.stringify(presetTimeSlots));
  329. if (result === true) {
  330. console.log("预设时间段导入成功!");
  331. window.AndroidBridge.showToast("测试时间段导入成功!");
  332. } else {
  333. console.log("预设时间段导入未成功,结果:" + result);
  334. window.AndroidBridge.showToast("测试时间段导入失败,请查看日志。");
  335. }
  336. } catch (error) {
  337. console.error("导入时间段时发生错误:", error);
  338. window.AndroidBridge.showToast("导入时间段失败: " + error.message);
  339. }
  340. }
  341. // 6. 导入课表配置
  342. async function demoSaveConfig() {
  343. console.log("正在准备配置数据...");
  344. // 注意:只传入要修改的字段,其他字段(如 semesterTotalWeeks)会使用 Kotlin 模型中的默认值
  345. const courseConfigData = {
  346. "semesterStartDate": "2025-09-01",
  347. "semesterTotalWeeks": 18,
  348. "defaultClassDuration": 50,
  349. "defaultBreakDuration": 5,
  350. "firstDayOfWeek": 7
  351. };
  352. try {
  353. console.log("正在尝试导入课表配置...");
  354. const configJsonString = JSON.stringify(courseConfigData);
  355. const result = await window.AndroidBridgePromise.saveCourseConfig(configJsonString);
  356. if (result === true) {
  357. console.log("课表配置导入成功!");
  358. AndroidBridge.showToast("测试配置导入成功!开学日期: 2025-09-01");
  359. } else {
  360. console.log("课表配置导入未成功,结果:" + result);
  361. AndroidBridge.showToast("测试配置导入失败,请查看日志。");
  362. }
  363. } catch (error) {
  364. console.error("导入配置时发生错误:", error);
  365. AndroidBridge.showToast("导入配置失败: " + error.message);
  366. }
  367. }
  368. AndroidBridge.showToast("这是一个来自 JS 的 Toast 消息,会很快消失!");
  369. /**
  370. * 编排这些异步操作,并在用户取消时停止后续执行。
  371. */
  372. async function runAllDemosSequentially() {
  373. AndroidBridge.showToast("所有演示将按顺序开始...");
  374. // 1. 运行第一个演示:Alert
  375. const alertResult = await demoAlert();
  376. if (!alertResult) {
  377. console.log("用户取消了 Alert 演示,停止后续执行。");
  378. return; // 用户取消,立即退出函数
  379. }
  380. // 2. 运行第二个演示:Prompt
  381. const promptResult = await demoPrompt();
  382. if (!promptResult) {
  383. console.log("用户取消了 Prompt 演示,停止后续执行。");
  384. return; // 用户取消,立即退出函数
  385. }
  386. // 3. 运行第三个演示:SingleSelection
  387. const selectionResult = await demoSingleSelection();
  388. if (!selectionResult) {
  389. console.log("用户取消了 Single Selection 演示,停止后续执行。");
  390. return; // 用户取消,立即退出函数
  391. }
  392. console.log("所有弹窗演示已完成。");
  393. AndroidBridge.showToast("所有弹窗演示已完成!");
  394. // 以下是数据导入,与用户交互无关,可以继续
  395. await demoSaveCourses();
  396. await importPresetTimeSlots();
  397. await demoSaveConfig();
  398. // 发送最终的生命周期完成信号
  399. AndroidBridge.notifyTaskCompletion();
  400. }
  401. // 启动所有演示
  402. runAllDemosSequentially();