diff --git a/demo.html b/demo.html new file mode 100644 index 0000000..b48e7e9 --- /dev/null +++ b/demo.html @@ -0,0 +1,71 @@ + + + + + + Canvas Editor Iframe Demo + + + +

父页面(同源)加载子页面 index.html(支持 ?filePath=URL)

+
+ + + + 支持传入 JSON(完整编辑器数据)或纯文本(作为正文)。文件将以 blob: URL 形式传递,保证同源。 +
+ + + + + \ No newline at end of file diff --git a/public/test.ocd b/public/test.ocd new file mode 100644 index 0000000..2a3e9d9 --- /dev/null +++ b/public/test.ocd @@ -0,0 +1,539 @@ +{ + "header": [ + { + "value": "教材在线编辑器", + "size": 32, + "rowFlex": "center" + }, + { + "value": "\n测试数据", + "size": 18, + "rowFlex": "center" + }, + { + "value": "\n", + "type": "separator", + "width": 554 + } + ], + "main": [ + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "主诉:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "\n发热三天,咳嗽五天。", + "size": 16 + }, + { + "value": "", + "type": "control", + "control": { + "conceptId": "1", + "type": "text", + "value": [], + "placeholder": "其他补充", + "prefix": "{", + "postfix": "}" + } + }, + { + "value": "\n", + "size": 16 + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "现病史:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "\n患者于三天前无明显诱因,感冒后发现面部水肿,无皮疹,尿量减少,出现乏力,在外治疗无好转,现来我院就诊。\n", + "size": 16 + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "既往史:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "\n有糖尿病10年,有高血压2年,有", + "size": 16 + }, + { + "value": "传染性疾病", + "size": 16, + "color": "#FF0000" + }, + { + "value": "1年。", + "size": 16 + }, + { + "value": "", + "type": "control", + "control": { + "conceptId": "2", + "type": "select", + "value": [], + "code": null, + "placeholder": "有无", + "prefix": "{", + "postfix": "}", + "valueSets": [ + { + "value": "有", + "code": "98175" + }, + { + "value": "无", + "code": "98176" + }, + { + "value": "不详", + "code": "98177" + } + ] + } + }, + { + "value": "报告其他既往疾病。\n", + "size": 16 + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "流行病史:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "\n否认14天内接触过", + "size": 16 + }, + { + "value": "", + "type": "hyperlink", + "url": "https://hufe.club/canvas-editor", + "valueList": [ + { + "value": "新冠肺炎", + "size": 16, + "color": "#0000FF", + "underline": true + } + ] + }, + { + "value": "确诊患者、疑似患者、无症状感染者及其密切接触者;否认14天内去过以下场所:水产、肉类批发市场,农贸市场,集市,大型超市,夜市;否认14天内与以下场所工作人员密切接触:水产、肉类批发市场,农贸市场,集市,大型超市;否认14天内周围(如家庭、办公室)有2例以上聚集性发病;否认14天内接触过有发热或呼吸道症状的人员;否认14天内自身有发热或呼吸道症状;否认14天内接触过纳入隔离观察的人员及其他可能与新冠肺炎关联的情形;陪同家属无以上情况。", + "size": 16 + }, + { + "value": "", + "type": "control", + "control": { + "conceptId": "6", + "type": "text", + "value": [], + "placeholder": "内容", + "preText": "其他:", + "postText": "。" + } + }, + { + "value": "\n", + "size": 16 + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "体格检查:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "\nT:39.5℃", + "size": 16 + }, + { + "value": "∆", + "type": "subscript", + "color": "#FF0000" + }, + { + "value": ",P:80bpm,R:20次/分,BP:120/80mmHg;\n", + "size": 16 + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "辅助检查:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "\n2020年6月10日,普放:", + "size": 16 + }, + { + "value": "血细胞比容", + "highlight": "#F2F27F", + "groupIds": [ + "1" + ] + }, + { + "value": "36.50%(偏低)40~50;单核细胞绝对值0.75*10", + "size": 16 + }, + { + "value": "9", + "type": "superscript" + }, + { + "value": "/L(偏高)参考值:0.1~0.6;\n", + "size": 16 + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "门诊诊断:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "", + "type": "list", + "valueList": [ + { + "value": "\n高血压\n糖尿病\n病毒性感冒\n过敏性鼻炎\n过敏性鼻息肉" + } + ], + "listType": "ol" + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "处置治疗:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "", + "type": "list", + "valueList": [ + { + "value": "\n超声引导下甲状腺细针穿刺术;\n乙型肝炎表面抗体测定;\n膜式病变细胞采集术、后颈皮下肤层;" + } + ], + "listType": "ol" + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "电子签名:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "【", + "size": 16 + }, + { + "value": "", + "type": "image", + "width": 89, + "height": 32 + }, + { + "value": "】\n", + "size": 16 + }, + { + "value": "", + "type": "title", + "valueList": [ + { + "value": "其他记录:", + "size": 18, + "bold": true + } + ], + "level": "first" + }, + { + "value": "", + "type": "table", + "trList": [ + { + "height": 42, + "tdList": [ + { + "colspan": 1, + "rowspan": 2, + "value": [ + { + "value": "1.", + "size": 16 + } + ] + }, + { + "colspan": 1, + "rowspan": 1, + "value": [ + { + "value": "2.", + "size": 16 + } + ] + }, + { + "colspan": 2, + "rowspan": 1, + "value": [ + { + "value": "3.", + "size": 16 + } + ] + } + ], + "minHeight": 42 + }, + { + "height": 42, + "tdList": [ + { + "colspan": 1, + "rowspan": 1, + "value": [ + { + "value": "4.", + "size": 16 + } + ] + }, + { + "colspan": 1, + "rowspan": 1, + "value": [ + { + "value": "5.", + "size": 16 + } + ] + }, + { + "colspan": 1, + "rowspan": 1, + "value": [ + { + "value": "6.", + "size": 16 + } + ] + } + ], + "minHeight": 42 + }, + { + "height": 42, + "tdList": [ + { + "colspan": 1, + "rowspan": 1, + "value": [ + { + "value": "7.", + "size": 16 + } + ] + }, + { + "colspan": 1, + "rowspan": 1, + "value": [ + { + "value": "8.", + "size": 16 + } + ] + }, + { + "colspan": 1, + "rowspan": 1, + "value": [ + { + "value": "9.", + "size": 16 + } + ] + }, + { + "colspan": 1, + "rowspan": 1, + "value": [ + { + "value": "10.", + "size": 16 + } + ] + } + ], + "minHeight": 42 + } + ], + "width": 520, + "height": 126, + "colgroup": [ + { + "width": 180 + }, + { + "width": 80 + }, + { + "width": 130 + }, + { + "width": 130 + } + ] + }, + { + "value": "是否同意以上内容:" + }, + { + "value": "", + "type": "control", + "control": { + "conceptId": "3", + "type": "checkbox", + "code": "98175", + "value": [ + { + "value": "同意否定" + } + ], + "valueSets": [ + { + "value": "同意", + "code": "98175" + }, + { + "value": "否定", + "code": "98176" + } + ] + } + }, + { + "value": "\n医学公式:" + }, + { + "value": "{E_k} = hv - {W_0}", + "type": "latex", + "width": 102, + "height": 25 + }, + { + "value": "\n签署日期:" + }, + { + "value": "", + "type": "control", + "control": { + "conceptId": "5", + "type": "date", + "value": [ + { + "value": "2022-08-10 17:30:01", + "type": "text" + } + ], + "placeholder": "签署日期" + } + }, + { + "value": "\n患者签名:" + }, + { + "value": "", + "type": "control", + "control": { + "conceptId": "4", + "type": "text", + "value": [], + "placeholder": "", + "prefix": "‌", + "postfix": "‌", + "minWidth": 160, + "underline": true + } + }, + { + "value": "\n" + }, + { + "value": "", + "type": "tab" + }, + { + "value": "EOF", + "size": 16 + } + ], + "footer": [] +} \ No newline at end of file diff --git a/src/main.ts b/src/main.ts index 923dfa1..5a1c9fe 100644 --- a/src/main.ts +++ b/src/main.ts @@ -66,6 +66,34 @@ window.onload = function () { // cypress使用 Reflect.set(window, 'editor', instance) + // 通过 URL 参数 filePath 自动打开同源文件(iframe 场景) + const params = new URLSearchParams(window.location.search) + const filePath = params.get('filePath') + if (filePath) { + const url = new URL(filePath, window.location.href).toString() + fetch(url) + .then(res => res.text()) + .then(text => { + try { + let editorData + try { + editorData = JSON.parse(text) + } catch { + editorData = { main: [{ value: text }] } + } + instance.command.executeSetValue(editorData) + console.log('[iframe] 根据 filePath 加载完成:', url) + } catch (err) { + console.error('[iframe] 加载失败:', err) + alert('通过参数加载文件失败,请检查格式与同源权限') + } + }) + .catch(err => { + console.error('[iframe] 获取文件失败:', err) + alert('无法获取 filePath 指定的文件') + }) + } + // 菜单弹窗销毁 window.addEventListener( 'click',