main.ts 4.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import {config as appConfig, state} from "./state";
  2. import {ClientEvent, Command, HttpSession, is_http_backend, pushData, Session, WebSocketSession} from "./session";
  3. import {InputHandler} from "./handlers/input"
  4. import {OutputHandler} from "./handlers/output"
  5. import {CloseHandler, CommandDispatcher} from "./handlers/base"
  6. import {PopupHandler} from "./handlers/popup";
  7. import {openApp} from "./utils";
  8. import {ScriptHandler} from "./handlers/script";
  9. import {DownloadHandler} from "./handlers/download";
  10. import {ToastHandler} from "./handlers/toast";
  11. import {EnvSettingHandler} from "./handlers/env";
  12. // 获取后端API的绝对地址
  13. function backend_absaddr(addr: string) {
  14. return new URL(addr, window.location.href).href;
  15. }
  16. // 初始化Handler和Session
  17. function set_up_session(webio_session: Session, output_container_elem: JQuery, input_container_elem: JQuery) {
  18. state.CurrentSession = webio_session;
  19. webio_session.on_session_close(function () {
  20. $('#favicon32').attr('href', 'data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAByElEQVRYR82XLUzDUBDH/9emYoouYHAYMGCAYJAYEhxiW2EOSOYwkKBQKBIwuIUPN2g7gSPBIDF8GWbA4DAjG2qitEfesi6lbGxlXd5q393/fr333t07QpdfPp8f0nV9CcACEU0DGAOgN9yrAN6Y+QnATbVavcrlcp/dSFMnI9M0J1RV3WHmFQCJTvaN9RoRXbiuu28YxstfPm0BbNtOMPMeEW0C0LoMHDZzmPmIiHbT6XStlUZLgEKhMK5p2iWAyX8GDruVHMdZzmazr+GFXwCmac4oinINYCSm4L5M2fO8RcMwHoO6PwAaf37bh+BNCMdx5oOZaAKIPQdwF2Pa2yWwBGDOPxNNAMuyDohoK+a0t5Rj5sNMJrMtFusA4qopivLcw2mPyu14njclrmgdoFgsnjLzWlSVXuyJ6CyVSq2TqHDJZPI9QpHpJW7Qt1apVEbJsqwVIjqPSzWKDjOvCoBjItqI4hiXLTOfkG3b9wBm4xKNqPMgAMoAhiM6xmX+IQC+AKhxKUbUcQcCQPoWyD2E0q+h9EIkvRRLb0YD0Y4FhNQHiQCQ/iQTEFIfpX4Nl/os9yGkDiY+hNTRLNhSpQ2n4b7er/H8G7N6BRSbHvW5AAAAAElFTkSuQmCC');
  21. $('#favicon16').attr('href', 'data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAA0ElEQVQ4T62TPQrCQBCF30tA8BZW9mJtY+MNEtKr2HkWK0Xtw+4NbGysxVorbyEKyZMNRiSgmJ/tZufNNzO7M0ThxHHc8zxvSnIIoPNyXyXt0zRdR1F0+gxhblhr25IWJMcA3vcFviRtSc6DILg5XyZ0wQB2AAbFir7YBwAjB8kAxpg1ycmfwZlM0iYMwyldz77vH3+U/Y2rJEn6NMYsSc7KZM+1kla01p4BdKsAAFwc4A6gVRHwaARQr4Xaj1j7G2sPUiOjnEMqL9PnDJRd5ycpJXsd2f2NIAAAAABJRU5ErkJggg==');
  22. });
  23. let output_ctrl = new OutputHandler(webio_session, output_container_elem);
  24. let input_ctrl = new InputHandler(webio_session, input_container_elem);
  25. let popup_ctrl = new PopupHandler(webio_session);
  26. let close_ctrl = new CloseHandler(webio_session);
  27. let script_ctrl = new ScriptHandler(webio_session);
  28. let download_ctrl = new DownloadHandler();
  29. let toast_ctrl = new ToastHandler();
  30. let env_ctrl = new EnvSettingHandler();
  31. let dispatcher = new CommandDispatcher(output_ctrl, input_ctrl, popup_ctrl, close_ctrl, script_ctrl, download_ctrl, toast_ctrl, env_ctrl);
  32. webio_session.on_server_message((msg: Command) => {
  33. try {
  34. let ok = dispatcher.dispatch_message(msg);
  35. if (!ok) console.error('Unknown command:%s', msg.command);
  36. } catch (e) {
  37. console.error('Error(%s) in dispatch command: %s', e, msg.command);
  38. }
  39. });
  40. }
  41. function startWebIOClient(options: {
  42. output_container_elem: JQuery,
  43. input_container_elem: JQuery,
  44. backend_address: string,
  45. app_name: string,
  46. protocol: string, // 'http', 'ws', 'auto'
  47. runtime_config: { [name: string]: any }
  48. }) {
  49. for (let key in options.runtime_config) {
  50. // @ts-ignore
  51. appConfig[key] = options.runtime_config[key];
  52. }
  53. const backend_addr = backend_absaddr(options.backend_address);
  54. let start_session = (is_http:boolean) => {
  55. let session;
  56. if (is_http)
  57. session = new HttpSession(backend_addr, options.app_name, appConfig.httpPullInterval);
  58. else
  59. session = new WebSocketSession(backend_addr, options.app_name);
  60. set_up_session(session, options.output_container_elem, options.input_container_elem);
  61. session.start_session(appConfig.debug);
  62. };
  63. if(options.protocol=='auto')
  64. is_http_backend(backend_addr).then(start_session);
  65. else
  66. start_session(options.protocol == 'http')
  67. }
  68. // @ts-ignore
  69. window.WebIO = {
  70. 'startWebIOClient': startWebIOClient,
  71. 'sendMessage': (msg: ClientEvent) => {
  72. return state.CurrentSession.send_message(msg);
  73. },
  74. 'openApp': openApp,
  75. 'pushData': pushData,
  76. };