|
|
<!DOCTYPE html>
|
|
|
<html>
|
|
|
|
|
|
<head>
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
|
|
<title>HCEmrViewLib Demo</title>
|
|
|
<script type="text/javascript" src="./HCEmrViewLib.min.js?v=17"></script>
|
|
|
<script type="text/javascript" src="./WatEvent.js?v=92"></script>
|
|
|
<script src="./select/js/jquery_3.3.1.min.js"></script>
|
|
|
<script language="javascript" type="text/javascript" src="./layer/layer.js"></script>
|
|
|
<script type="text/javascript">
|
|
|
// 数据元类型
|
|
|
var TItemStyle = {
|
|
|
Null: -1,
|
|
|
Image: -2, // 图片
|
|
|
Table: -3, // 表格
|
|
|
Tab: -4, // TAB键
|
|
|
Line: -5, // 直线
|
|
|
Express: -6, // 公式
|
|
|
Vector: -7, // 矢量图
|
|
|
Domain: -8, // 域
|
|
|
PageBreak: -9, // 分页
|
|
|
CheckBox: -10, // 勾选框
|
|
|
Gif: -11, // GIF动画
|
|
|
Control: -12, // 控件
|
|
|
Edit: -13, // Edit 文本框
|
|
|
Combobox: -14, // Combobox 下拉弹出框
|
|
|
QRCode: -15, // 二维码
|
|
|
BarCode: -16, // 一维码
|
|
|
Fraction: -17, // 分数
|
|
|
DateTimePicker: -18, // 日期时间控件
|
|
|
RadioGroup: -19, // RadioGroup 单选、多选控件
|
|
|
SupSubScript: -20, // 同时上下标
|
|
|
Button: -21, // 按钮控件
|
|
|
FloatLine: -101, // 浮动直线
|
|
|
FloatBarCode: -102, // 浮动一维码
|
|
|
Custom: -1000
|
|
|
}
|
|
|
// 数据元属性
|
|
|
var TDeProp = {
|
|
|
Index: "Index", // 唯一索引
|
|
|
Code: "Code", // 编码
|
|
|
Name: "Name", // 名称
|
|
|
Frmtp: "Frmtp", // 类别,见TDeFrmtp枚举
|
|
|
Unit: "Unit", // 单位
|
|
|
HideUnit: "HdUnit", // 是否隐藏单位,比如血压的收缩压不显示单位
|
|
|
PreFormat: "PRFMT", // 表示格式
|
|
|
Raw: "Raw", // 原始数据
|
|
|
CMV: "CMV", // 受控词汇表(值域代码)
|
|
|
CMVVCode: "CMVVCode", // 受控词汇编码(值编码)
|
|
|
Trace: "Trace", // 痕迹信息
|
|
|
Secret: "Secret", // 是否属于隐私信息
|
|
|
}
|
|
|
|
|
|
// 数据元类型
|
|
|
var TDeFrmtp = {
|
|
|
Radio: "RS", // 单选
|
|
|
Multiselect: "MS", // 多选
|
|
|
Number: "N", // 数值
|
|
|
String: "S", // 文本
|
|
|
Date: "D", // 日期
|
|
|
Time: "T", // 时间
|
|
|
DateTime: "DT" // 日期和时间
|
|
|
}
|
|
|
|
|
|
// 痕迹样式
|
|
|
var TStyleExtra = {
|
|
|
None: 0, // 无
|
|
|
Del: 1, // 删除
|
|
|
Add: 2 // 添加
|
|
|
}
|
|
|
|
|
|
var TGroupProp = {
|
|
|
Index: "Index",
|
|
|
Name: "Name",
|
|
|
SubType: "RT",
|
|
|
Propertys: "Propertys"
|
|
|
}
|
|
|
|
|
|
var emrView;
|
|
|
|
|
|
|
|
|
|
|
|
function getBase64ByUrl (src, callback, outputFormat) {
|
|
|
var xhr = new XMLHttpRequest();
|
|
|
xhr.open("GET", src, true);
|
|
|
|
|
|
xhr.responseType = "arraybuffer";
|
|
|
|
|
|
xhr.onload = function(e) {
|
|
|
if (xhr.status == 200) {
|
|
|
var uInt8Array = new Uint8Array(xhr.response);
|
|
|
var i = uInt8Array.length;
|
|
|
var binaryString = new Array(i);
|
|
|
while (i--)
|
|
|
binaryString[i] = String.fromCharCode(uInt8Array[i]);
|
|
|
|
|
|
var data = binaryString.join('');
|
|
|
var base64 = window.btoa(data);
|
|
|
var dataUrl = "data:" + (outputFormat || "image/png") + ";base64," + base64;
|
|
|
callback.call(this, dataUrl);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
xhr.send();
|
|
|
}
|
|
|
|
|
|
function getFileAsBytes(src, callback) {
|
|
|
var xhr = new XMLHttpRequest();
|
|
|
xhr.open("GET", src, true);
|
|
|
xhr.responseType = "arraybuffer";
|
|
|
xhr.onload = function(e) {
|
|
|
if (xhr.status == 200) {
|
|
|
var vBytes = new Uint8Array(xhr.response);
|
|
|
callback.call(this, vBytes);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
xhr.send();
|
|
|
}
|
|
|
|
|
|
function load() {
|
|
|
|
|
|
emrView = new THCEmrViewLib({
|
|
|
hcServer: "http://127.0.0.1:12880/", // HC服务端IP
|
|
|
//hcServer: "http://124.71.81.19:12880/", // HC服务端IP
|
|
|
//hcServer: "http://192.168.2.111:12880/", // HC服务端IP
|
|
|
//hcServer: "http://192.168.1.122:12880/",
|
|
|
//hcServer: "http://192.168.5.104:12880/",
|
|
|
//hcServer: "http://192.168.20.100:12880/",
|
|
|
//hcServer: "http://192.168.20.100:12880/", // HC服务端IP
|
|
|
baseUrl: "./", // 编辑器需要的资源路径
|
|
|
el: "divHCEmrView", // 编辑器父容器的ID
|
|
|
defaultFontSize: "小四", // 编辑器默认字号,默认小四
|
|
|
defaultFontFamily: "宋体", // 编辑器默认字体,默认宋体
|
|
|
paperSize: "A4", // 纸张大小
|
|
|
paperOrientation: 0, // 纸张方向 0纵向 1横向,默认0
|
|
|
designMode: true, // 是否设计模式,也可以使用emrView.designMode = true;
|
|
|
// multItemEditValue: true, // 多选数据元选项上屏后,再次点击直接编辑内容,使用右键菜单重新选择
|
|
|
//deUnDoneColor: "#FF8C00", // 没选过选项或没写过内容时数据元背景色
|
|
|
//deDoneColor: "#AFEEEE", // 填写或选择过选项的数据元背景色
|
|
|
//deHotColor: "#87CEFA", // 鼠标移动上去时的颜色
|
|
|
|
|
|
// 工具条
|
|
|
toolBar: {
|
|
|
visible: true, // 是否整体显示顶部工具条,也可以使用emrView.toolBar.visible = false;
|
|
|
//height: 35, // 设置工具栏高度
|
|
|
// 文件按钮
|
|
|
btnFile: {
|
|
|
visible: 1
|
|
|
},
|
|
|
|
|
|
// 打印按钮
|
|
|
btnPrint: {
|
|
|
visible: true,
|
|
|
},
|
|
|
|
|
|
// 外部自定义按钮
|
|
|
// btnCustoms: [
|
|
|
// {
|
|
|
// text: "保存关键词",
|
|
|
// exec: function() {
|
|
|
// console.log("保存关键词");
|
|
|
// var steamData = emrView.SaveToLiteBytes();
|
|
|
// var emrData = new EmrToWatData("B","saveLiteByte",steamData);
|
|
|
// watEvents.emrToWatEvent(emrData);
|
|
|
// }
|
|
|
// }
|
|
|
// ]
|
|
|
},
|
|
|
|
|
|
// 右键菜单中添加自定义菜单
|
|
|
contextMenu: [
|
|
|
// {
|
|
|
// // 菜单名
|
|
|
// text: "添加诊断",
|
|
|
// // 菜单点击事件
|
|
|
// exec: function() {
|
|
|
// appendLine("点击了菜单:添加诊断");
|
|
|
// emrView.InsertText("添加诊断");
|
|
|
// },
|
|
|
// },
|
|
|
|
|
|
// {
|
|
|
// text: "插入数据从HIS",
|
|
|
// exec: function() { appendLine("点击了菜单:插入数据从HIS"); },
|
|
|
|
|
|
// // 子菜单
|
|
|
// subMenu: [
|
|
|
// {
|
|
|
// text: "插入检查",
|
|
|
// exec: function() {
|
|
|
// appendLine("点击了菜单:插入检查");
|
|
|
// emrView.InsertText("插入检查");
|
|
|
// },
|
|
|
// },
|
|
|
|
|
|
// {
|
|
|
// text: "插入医嘱",
|
|
|
// exec: function() {
|
|
|
// appendLine("点击了菜单:插入医嘱");
|
|
|
// emrView.InsertText("插入医嘱");
|
|
|
// },
|
|
|
// }
|
|
|
// ]
|
|
|
// }
|
|
|
],
|
|
|
|
|
|
// 事件
|
|
|
event: {
|
|
|
// 编辑器状态变化时触发:从未修改状态变为修改状态,或从修改状态变为未修改状态,
|
|
|
onChangedSwitch: function() {
|
|
|
if (emrView.IsChanged){
|
|
|
|
|
|
}else{
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
onCaretItemChanged: function() {//用于DeEdit元素的属性值设置
|
|
|
let viewData = emrView.InnerView.ActiveSectionTopLevelData(); // 当前光标处的Data
|
|
|
if (viewData) {
|
|
|
let item = viewData.GetActiveItem(); // 当前光标处的Item
|
|
|
if (item.Index != "") { // 光标处是数据元
|
|
|
if (item.StyleNo > TItemStyle.Null) { // 是纯文本数据元
|
|
|
|
|
|
} else if (item.StyleNo === TItemStyle.Edit) { // 是Edit数据元
|
|
|
watEvents.DeEditData = item;
|
|
|
var param={
|
|
|
Index:item.Index,
|
|
|
Code:item.GetValue("Code"),
|
|
|
Name:item.GetValue("Name"),
|
|
|
AutoSize:item.AutoSize,
|
|
|
Width:item.Width,
|
|
|
Height:item.Height,
|
|
|
Text:item.Text,
|
|
|
BorderLeft:item.BorderSides.has(1),
|
|
|
BorderTop:item.BorderSides.has(1 << 1),
|
|
|
BorderRight:item.BorderSides.has(1 << 2),
|
|
|
BorderBottom:item.BorderSides.has(1 << 3),
|
|
|
};
|
|
|
var data = new EmrToWatData("S","DeEditInfo",param);
|
|
|
watEvents.emrToWatEvent(data);
|
|
|
//item.SetValue("Name","测试");
|
|
|
}
|
|
|
|
|
|
console.log(item.Index);
|
|
|
} else
|
|
|
console.log("当前不是数据元");
|
|
|
}
|
|
|
},
|
|
|
|
|
|
// 点击了编辑器工具栏上的保存按钮时触发
|
|
|
onSave: function() {
|
|
|
emrView.InnerView.DeleteAllProcMark();//把病程标识清除掉
|
|
|
feedbackEmrStreamToWat();
|
|
|
},
|
|
|
|
|
|
// 鼠标点击数据元触发,如果数据元的信息有变化,可以这里重新赋值
|
|
|
onPopupGetDeItemInfo: function(item) {
|
|
|
var data = new EmrToWatData("S","DeItemInfo","{"+item.ToJSONString()+"}");
|
|
|
watEvents.emrToWatEvent(data);
|
|
|
//return watEvents.getDeItemDomain(data,watEvents.url);
|
|
|
///if (item.Index == "495") { // 性别
|
|
|
// 点击数据元时,给数据元通过item.Index重新同步最新信息的机会,响应此事件,需要返回frmtp,数值类的需要返回单位deunit,单选多选要返回选项值域domainid
|
|
|
//item.SetValue(TDeProp.Frmtp, TDeFrmtp.Radio);
|
|
|
//item.SetValue(TDeProp.CMV, "271"); // 值域,271是数据库里性别元素的值域代码,实际可以通过e.index判断是哪个数据元,返回类别,如果是单选或多选类型同时要返回值域
|
|
|
|
|
|
//item.SetValue(TDeProp.Frmtp, TDeFrmtp.Number); // 类别,RS:单选 MS:多选 N:数值 S:文本 D:日期 T:时间 DT:日期时间
|
|
|
//item.SetValue(TDeProp.Unit, "岁,月,天,小时"); // 数值类的要传递单位
|
|
|
//}
|
|
|
},
|
|
|
// 编辑器中插入了新的Item时触发,也可创建后赋值emrView.OnInserItemSync
|
|
|
onSectionInsertItem: function(section, data, item) {
|
|
|
if (item.StyleNo == TItemStyle.RadioGroup)
|
|
|
item.OnSetItemChecked = function(radiogroup) {
|
|
|
//console.log("radiogroup 有选项勾选状态变化");
|
|
|
let viewData = emrView.InnerView.ActiveSectionTopLevelData();
|
|
|
if (viewData) {
|
|
|
//if (viewData.Script != "")
|
|
|
{
|
|
|
let vItemNo = viewData.GetItemNo(radiogroup);
|
|
|
//vFn = new Function("view", "data", "itemNo", "action", viewData.Script);
|
|
|
vFn = new Function("view", "data", "itemNo", "action",
|
|
|
"if (action == 0) { " +
|
|
|
"let vDomainInfo = data.GetItemDomain(itemNo);" +
|
|
|
"let curDeGroupIndex = data.Items[vDomainInfo.beginNo].Index;"+
|
|
|
"for (let i = vDomainInfo.beginNo + 1; i < vDomainInfo.endNo; i++) {" +
|
|
|
"if (data.Items[i].StyleNo == -19 &&i != itemNo && !data.Items[i].MultSelect ){" + // -19可根据脚本运行环境决定是否替换为THCStyle.RadioGroup或TItemStyle.RadioGroup
|
|
|
|
|
|
"let vDomainInfoTemp = data.GetItemDomain(i);" +
|
|
|
"if (vDomainInfoTemp.beginNo >= 0 && data.Items[vDomainInfoTemp.beginNo].Index == curDeGroupIndex ) {" +
|
|
|
"data.Items[i].SetAllChecked(false);" +
|
|
|
"}"+
|
|
|
"}" +
|
|
|
"}" +
|
|
|
"}"
|
|
|
);
|
|
|
try {
|
|
|
vFn(emrView, viewData, vItemNo, 0);
|
|
|
} catch (e) {
|
|
|
console.log(e.message); // 显示脚本错误信息
|
|
|
}
|
|
|
|
|
|
vFn = null;
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
|
|
|
// 单选或多选数据元获鼠标点击后,显示选项时触发,可在这里把选项传递到编辑器中
|
|
|
onPopupGetDeItemDomain: function(cmv) {
|
|
|
//appendLine("onPopupGetDeItemDomain 选项类数据元点击时请求选项 参数:" + cmv);
|
|
|
console.log("onPopupGetDeItemDomain 选项类数据元点击时请求选项 参数:" + cmv);
|
|
|
var data = new EmrToWatData("S","EMR004",cmv);//编辑器初始化完成
|
|
|
var vs = watEvents.getDeItemDomain(data,watEvents.url);
|
|
|
//var vs = '{"cv": [{"value": "皮疹", "code": "1", "id": 689, "py": "PZ", "content": ""},'
|
|
|
// + '{"value": "皮下出血", "code": "2", "id": 690, "py": "PZCX", "content": ""}'
|
|
|
// + ']}';
|
|
|
|
|
|
return vs;
|
|
|
// if (cmv == 271) { // 值域ID,271是性别值域ID
|
|
|
// var vs = '{"cv": [{"value": "男性", "code": "1", "id": 3681, "py": "NX", "content": ""},'
|
|
|
// + '{"value": "女性", "code": "2", "id": 3682, "py": "NX", "content": ""},'
|
|
|
// + '{"value": "未知(描述原因)", "code": "9", "id": 3683, "py": "WZ", "content": "..."}'
|
|
|
// + ']}';
|
|
|
// return JSON.parse(vs);
|
|
|
// } else if (cmv == 299) {
|
|
|
// var vs = '{"cv": [{"value": "静脉无曲张", "code": "1", "id": 681, "py": "JMWQZ", "content": ""},'
|
|
|
// + '{"value": "静脉曲张(有曲张描述血流方向)", "code": "2", "id": 682, "py": "JMQZ", "content": ""}'
|
|
|
// + ']}';
|
|
|
// return JSON.parse(vs);
|
|
|
// } else if (cmv == 272) {
|
|
|
// var vs = '{"cv": [{"value": "皮疹", "code": "1", "id": 689, "py": "PZ", "content": ""},'
|
|
|
// + '{"value": "皮下出血", "code": "2", "id": 690, "py": "PZCX", "content": ""}'
|
|
|
// + ']}';
|
|
|
// return JSON.parse(vs);
|
|
|
// }
|
|
|
},
|
|
|
|
|
|
// 数据元选项有扩展内容时,获取扩展内容
|
|
|
onPopupGetDomainItemExtraLib: function(item, cvvid) {
|
|
|
var data = new EmrToWatData("S","getLiteByte",item.Index);//编辑器初始化完成
|
|
|
watEvents.getLiteByte(data,watEvents.url);
|
|
|
},
|
|
|
|
|
|
// 当编辑器在加载文档或插入了新的Item时触发,便于外部替换数据元的值
|
|
|
onInserItemSync: function(sender, data, item) {
|
|
|
|
|
|
},
|
|
|
|
|
|
// 当编辑器中的Combobox控件点击了下拉按钮,显示选项时触发
|
|
|
onDeComboboxPopup: function(cmbxItem) {
|
|
|
if (cmbxItem.Index == 495) { // 是性别
|
|
|
if (!cmbxItem.SaveItem) { // combobox自己没有保存选项
|
|
|
if (cmbxItem.Items.count > 0)
|
|
|
cmbxItem.Clear();
|
|
|
|
|
|
cmbxItem.AddItem("男", "1");
|
|
|
cmbxItem.AddItem("女", "2");
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
|
|
|
// 判断当前情况下是否能编辑,此事件在引起内容变化的时候触发,较频繁,所以不要写复杂的业务
|
|
|
onCanEdit: function(data) {
|
|
|
if (emrView.EditProcIndex != "") // 当前指定了要编辑的病程
|
|
|
return emrView.CaretProcInfo.Index == emrView.EditProcIndex; // 光标所在病程和当前允许编辑的病程Index相同
|
|
|
else
|
|
|
return true;
|
|
|
},
|
|
|
|
|
|
// 数据元右键菜单中的 更新引用 点击后触发的事件
|
|
|
onDeItemGetSyncValue: function(item) {
|
|
|
if (item.Index == "494") // 姓名
|
|
|
return "李四福";
|
|
|
},
|
|
|
|
|
|
// 点了打印并在浏览器里显示了要打印的文件
|
|
|
onPrinted: function(type) {
|
|
|
// type 0打印全部或1-n页,1按行续打,2选中范围续打
|
|
|
|
|
|
},
|
|
|
onInitialization: function(){
|
|
|
var jsonData = new EmrToWatData("S","EMR001","emr001");//编辑器初始化完成
|
|
|
feedbackDataToWat(JSON.stringify(jsonData));
|
|
|
|
|
|
},
|
|
|
// 编辑器双击事件,查看属性
|
|
|
onDblClick: function() {
|
|
|
//var deGroupCode = emrView.GetCaretDeGroupProperty(TDeProp.Code);
|
|
|
//var deGroupIndex = emrView.GetCaretDeGroupProperty(TDeProp.Index);
|
|
|
var deGroupInfo = emrView.GetCaretDeGroupProperty(TDeProp.Index);
|
|
|
if (deGroupInfo != "") {
|
|
|
var propertys = emrView.GetCaretDeGroupProperty("Propertys","json");//json对象
|
|
|
var data = new EmrToWatData("S","DeGroupInfo",propertys);
|
|
|
watEvents.emrToWatEvent(data);
|
|
|
}
|
|
|
},
|
|
|
}
|
|
|
});
|
|
|
|
|
|
// 向工具栏中添加按钮
|
|
|
// emrView.AddToolButton(
|
|
|
// [
|
|
|
// {
|
|
|
// text: "自定义",
|
|
|
// exec: function() {
|
|
|
// alert("点击了自定义按钮2");
|
|
|
// }
|
|
|
// }
|
|
|
// ]
|
|
|
// );
|
|
|
|
|
|
// 向编辑器的右键菜单中添加菜单
|
|
|
emrView.AddContextMenu(
|
|
|
[
|
|
|
{
|
|
|
text: "保存关键词",
|
|
|
exec: function() {
|
|
|
|
|
|
var steamData = emrView.SaveToLiteBytes();
|
|
|
var emrData = new EmrToWatData("B","saveLiteByte",steamData);
|
|
|
watEvents.emrToWatEvent(emrData);
|
|
|
}
|
|
|
},
|
|
|
{
|
|
|
text:"删除病程标识",
|
|
|
exec:function(){
|
|
|
emrView.InnerView.DeleteAllProcMark();
|
|
|
}
|
|
|
}
|
|
|
]
|
|
|
);
|
|
|
|
|
|
// 插入普通文本
|
|
|
// emrView.InsertText("姓名:");
|
|
|
|
|
|
// // 插入性别数据元,如果有赋值onInserItemSync方法,会在其中替换为实际的患者姓名
|
|
|
// var vDeItem = emrView.InsertDeItem({
|
|
|
// Index: "494",
|
|
|
// Name: "姓名",
|
|
|
// });
|
|
|
// //vDeItem.SetValue(); // 设置数据元的属性
|
|
|
|
|
|
// // 插入DeCombobox示例
|
|
|
// var vDeCombobox = emrView.InsertDeCombobox({
|
|
|
// Index: "4955",
|
|
|
// Name: "性别",
|
|
|
// Static: true, // 是否只能通过选项赋值(不能输入内容),true是,false否
|
|
|
// ReadOnly: false, // 是否只读,只读后不能修改内容
|
|
|
// SaveItem: true, // 是否保存选项(保存选项会增加文件体积)
|
|
|
// PrintOnlyText: true, // 打印时只打印文字,不打印按钮
|
|
|
// Items: [ // 插入时添加选项,注意如果要将选项保存到病历文件中,需要设置vDeCombobx.SaveItem = true;
|
|
|
// {
|
|
|
// Text: "男性",
|
|
|
// TextValue: "1",
|
|
|
// Checked: true,
|
|
|
// },
|
|
|
|
|
|
// {
|
|
|
// Text: "女性",
|
|
|
// TextValue: "2",
|
|
|
// Checked: false,
|
|
|
// },
|
|
|
// ]
|
|
|
// });
|
|
|
|
|
|
// 插入RadioGroup示例
|
|
|
// var vDeRadioGroup = emrView.InsertDeRadioGroup({
|
|
|
// Index: "495",
|
|
|
// Name: "性别",
|
|
|
// Style: "Radio", // Radio:圆点 CheckBox:勾选
|
|
|
// MultSelect: "0", // 单选or多选 0单选 1多选
|
|
|
// AutoSize: false, // 根据内容自动计大小
|
|
|
// Columes: 2, // 以几列显示
|
|
|
// ColumnAlign: true, // 列自动对齐
|
|
|
// ItemHit: true, // 点击文件就算选中 false点击圆点或勾选框才算选中
|
|
|
|
|
|
// Width: 300,
|
|
|
// Items: [ // 选项
|
|
|
// {
|
|
|
// Text: "未知的性别",
|
|
|
// TextValue: "0",
|
|
|
// Checked: false,
|
|
|
// },
|
|
|
|
|
|
// {
|
|
|
// Text: "男",
|
|
|
// TextValue: "1",
|
|
|
// Checked: true,
|
|
|
// },
|
|
|
|
|
|
// {
|
|
|
// Text: "女",
|
|
|
// TextValue: "2",
|
|
|
// Checked: false,
|
|
|
// },
|
|
|
|
|
|
// {
|
|
|
// Text: "未说明的性别",
|
|
|
// TextValue: "9",
|
|
|
// Checked: false,
|
|
|
// }
|
|
|
// ]
|
|
|
// });
|
|
|
|
|
|
// 插入表格示例
|
|
|
// var vDeTable = emrView.InsertDeTable({
|
|
|
// RowCount: 3,
|
|
|
// ColCount: 3,
|
|
|
// Rows: [ // 行s
|
|
|
// { // 第1行
|
|
|
// Cells: [ // 列s
|
|
|
// { // 第1列
|
|
|
// Text: "第一行第一列"
|
|
|
// },
|
|
|
// {
|
|
|
|
|
|
// },
|
|
|
// {
|
|
|
// Text: "第一行第三列"
|
|
|
// }
|
|
|
// ]
|
|
|
// },
|
|
|
|
|
|
// {
|
|
|
|
|
|
// },
|
|
|
|
|
|
// {
|
|
|
// Cells: [
|
|
|
// {
|
|
|
// Text: "第三行第一列"
|
|
|
// }
|
|
|
// ]
|
|
|
// }
|
|
|
// ]
|
|
|
// });
|
|
|
|
|
|
// var vMuDeItem = emrView.InsertDeItem({
|
|
|
// Index: "201", // 数据元唯一ID
|
|
|
// Name: "皮疹及出血", // 数据元名称
|
|
|
// Text: "有皮疹、皮下出血", // 默认内容,注意设置默认内容后数据元的是否填写过值为true 如果想置为false,需要设置 AllocValue: "0"
|
|
|
// Frmtp: TDeFrmtp.Multiselect, // 多选
|
|
|
// CMV: "272", // 值域ID
|
|
|
// CMVVCode: "1,2", // 选择的选项Code,以英文逗号分隔
|
|
|
// ItemMutex: "1", // 多选时选项互拆
|
|
|
// });
|
|
|
}
|
|
|
|
|
|
function applyTextStyle(style) {
|
|
|
// 设置选中的文本设置样式
|
|
|
emrView.ApplyTextStyle(style);
|
|
|
}
|
|
|
|
|
|
function applyParaAlignHorz(align) {
|
|
|
// 设置当前光标所在的段水平对齐
|
|
|
emrView.ApplyParaAlignHorz(align);
|
|
|
}
|
|
|
|
|
|
function LoadFromBytes(bytes) { // 二进制数组
|
|
|
// 加载文件,文件数据是byte数组
|
|
|
emrView.LoadFromBytes(bytes);
|
|
|
}
|
|
|
|
|
|
function saveToStream() {
|
|
|
// 保存文件,返回文件数据的byte数组
|
|
|
return emrView.SaveToStream();
|
|
|
}
|
|
|
|
|
|
|
|
|
function insertDeItem() {
|
|
|
// 插入数据元
|
|
|
emrView.InsertDeItem(
|
|
|
// {
|
|
|
// Index: "499",
|
|
|
// Name: "静脉曲张",
|
|
|
// //Text: "静脉无曲张",
|
|
|
// //CMVVCode: "1",
|
|
|
// Frmtp: TDeFrmtp.Multiselect,
|
|
|
// CMV: "299"
|
|
|
// }
|
|
|
{
|
|
|
"CMV": "1000000062",
|
|
|
// "CMVVCode": "",
|
|
|
// "code": "",
|
|
|
"Frmtp": "MS",
|
|
|
// "hideUnit": "",
|
|
|
"Index": "1000000062",
|
|
|
"Name": "皮肤颜色",
|
|
|
// "preFormat": "",
|
|
|
// "raw": "",
|
|
|
// "secret": "",
|
|
|
// "trace": "",
|
|
|
// "unit": ""
|
|
|
}
|
|
|
);
|
|
|
}
|
|
|
|
|
|
function getDeItemText(index) {
|
|
|
// 获取指定index的数据元的内容
|
|
|
// var vInfo = emrView.GetDeItemText(index);
|
|
|
// if (vInfo.result) { // 取到了
|
|
|
// appendLine("取到数据元内容:" + vInfo.text); // 取到的内容
|
|
|
// console.log(vInfo);
|
|
|
// }else{
|
|
|
// appendLine("未取到数据元内容");
|
|
|
// }
|
|
|
// console.log("emrView.getDeItem:"+emrView.getDeItem(index));
|
|
|
|
|
|
}
|
|
|
|
|
|
function getDeItemProperty(index, propName) {
|
|
|
// 获取指定index的数据元的指定属性内容
|
|
|
var vInfo = emrView.GetDeItemProperty(index, propName);
|
|
|
if (vInfo.result) // 取到了
|
|
|
console.log("取到数据元属性:" + vInfo.text); // 取到的内容
|
|
|
else
|
|
|
console.log("未取到数据元属性内容");
|
|
|
}
|
|
|
|
|
|
function insertDeGroup(index, name) {
|
|
|
// 插入数据组
|
|
|
emrView.InsertDeGroup({
|
|
|
Index: index,
|
|
|
Name: name,
|
|
|
});
|
|
|
}
|
|
|
|
|
|
function setDeGroupText(index, s) {
|
|
|
emrView.SetDeGroupText(index, s);
|
|
|
}
|
|
|
|
|
|
function getDeGroupText(index) {
|
|
|
console.log(index + "数据组内容:" + emrView.GetDeGroupText(index));
|
|
|
}
|
|
|
|
|
|
function insertDeImage(index, name) {
|
|
|
// 仅插入空白占位图片,实际业务中再替换成相应的图片
|
|
|
emrView.InsertDeImage({
|
|
|
Index: index,
|
|
|
Name: name
|
|
|
});
|
|
|
|
|
|
// 直接插入图片
|
|
|
// getBase64ByUrl("./image/qm.png", function(base64) {
|
|
|
// emrView.InsertDeImage({
|
|
|
// Index: index,
|
|
|
// Name: name,
|
|
|
// Base64: base64,
|
|
|
// ImageType: "png"
|
|
|
// });
|
|
|
// });
|
|
|
}
|
|
|
|
|
|
function setSignatureGraphic(index) {
|
|
|
// 替换签名图片
|
|
|
getBase64ByUrl("./image/qm.png", function(base64) {
|
|
|
emrView.SetDeImage({
|
|
|
Index: index,
|
|
|
Base64: base64
|
|
|
});
|
|
|
});
|
|
|
}
|
|
|
|
|
|
/* 遍历编辑器中的数据元时,每遍历到一个数据元触发
|
|
|
此方法参数使用编辑器内置的原生Item对象,注意相关的属性大小写
|
|
|
*/
|
|
|
function traverseFun(data, itemNo, tag, domainStack, stop) {
|
|
|
let vItem = data.Items[itemNo];
|
|
|
let dataElement = new Object();
|
|
|
if (vItem.StyleNo == -8) { // 数据组
|
|
|
|
|
|
if (vItem.IsProcBegin)
|
|
|
console.log("病程开始--------唯一标识:" + vItem.Index);
|
|
|
else if (vItem.IsProcEnd){
|
|
|
console.log("病程结束--------唯一标识:" + vItem.Index);
|
|
|
}
|
|
|
else if (vItem.MarkType == 0){
|
|
|
console.log("数据组开始--------Index:" + vItem.Index);
|
|
|
dataElement.Index = vItem.Index;
|
|
|
dataElement.Code = vItem.Code;
|
|
|
dataElement.Name = vItem.Name;
|
|
|
dataElement.DataType="1";
|
|
|
emrView._emrDataElement.push(dataElement);
|
|
|
}
|
|
|
else{
|
|
|
console.log("数据组结束--------Index:" + vItem.Index);
|
|
|
}
|
|
|
|
|
|
} else if (vItem.StyleNo > -1) { // 文本
|
|
|
if (vItem.IsElement){
|
|
|
dataElement.Index = vItem.Index;
|
|
|
dataElement.Code = vItem.Code;
|
|
|
dataElement.Name = vItem.Name;
|
|
|
dataElement.Frmtp = vItem.Frmtp;
|
|
|
dataElement.Format = vItem.GetValue('Format');
|
|
|
dataElement.DataType="0";
|
|
|
emrView._emrDataElement.push(dataElement);
|
|
|
}
|
|
|
else
|
|
|
console.log("自然文本 Text:" + vItem.Text); // 原生Item文本属性Text(大写T开始)
|
|
|
} else if(vItem.StyleNo == -19){//radioGroup
|
|
|
dataElement.Index = vItem.Index;
|
|
|
dataElement.Code = vItem.Code;
|
|
|
dataElement.Name = vItem.GetValue("Name");
|
|
|
dataElement.DataType="2";
|
|
|
emrView._emrDataElement.push(dataElement);
|
|
|
// let tList = vItem.FItems;
|
|
|
// for(let i =0 ;i<tList.length;i++){
|
|
|
// if(tList[i].FChecked == true){//被选中
|
|
|
// dataElement.SelectedValue= tList[i].TextValue;
|
|
|
// }
|
|
|
// }
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
// 遍历编辑器中的数据元
|
|
|
function traverseElement() {
|
|
|
/*emrView.TraverseElement(fun, areas, tag)需要3个参数
|
|
|
fun表示每遍历到一个元素时触发的事件
|
|
|
areas是个集合,表示要遍历的文档区域,集合的成员是1:页眉、2:正文、4:页脚,areas为null时表示全部区域(正文,页眉,页脚)
|
|
|
tag遍历标识,用于区域本次遍历是完成什么业务,可根据需要赋值
|
|
|
*/
|
|
|
console.log("开始遍历文档-----------------------------");
|
|
|
let vAreas = new Set([]);
|
|
|
// vAreas.add(1);
|
|
|
vAreas.add(2);
|
|
|
// vAreas.add(4);
|
|
|
emrView._emrDataElement = new Array();
|
|
|
emrView.TraverseElement(traverseFun, vAreas, 0);
|
|
|
console.log(emrView._emrDataElement);
|
|
|
}
|
|
|
|
|
|
// 插入病程
|
|
|
function insertProc() {
|
|
|
getFileAsBytes("./file/首次病程记录.hcf", function(bytes) {
|
|
|
if (bytes.length == 0)
|
|
|
return;
|
|
|
|
|
|
// 病程时间,实际业务应该取服务端时间
|
|
|
var vDate = new Date();
|
|
|
var vDateTime = vDate.getFullYear() + (vDate.getMonth() + 1).toString()
|
|
|
+ vDate.getDate() + vDate.getHours() + vDate.getMinutes() + vDate.getSeconds();
|
|
|
|
|
|
// 病程属性,可添加病程控制相关的属性,每个属性是一个键值对,多个属性以\r\n分隔
|
|
|
var vPropertys = TGroupProp.Name + "=首次病程记录\r\nuser=jt\r\ndt=" + vDateTime; // 用户jt,日期vDateTime
|
|
|
|
|
|
// 病程唯一ID,这里使用了当前时间,实际业务使用时可换为业务里的病程唯一ID生成规则
|
|
|
var vProcIndex = vDateTime;
|
|
|
|
|
|
// 在指定的病程(ID为vBeforProcIndex)前面插入新病程,如为""表示在最后插入病程
|
|
|
var vBeforProcIndex = "";
|
|
|
|
|
|
// 当前病历是否没有病程,即要插入的病程是否为整个病历的第一个病程
|
|
|
var vFirstProc = emrView.ProcCount == 0;
|
|
|
|
|
|
emrView.ReadOnly = false; // 病历切换为非只读
|
|
|
|
|
|
// 插入病程标识
|
|
|
if (emrView.InsertProc(vProcIndex, vPropertys, vBeforProcIndex)) { // 插入病程标识成功
|
|
|
console.log("插入病程,标识为:" + vProcIndex);
|
|
|
emrView.EditProcIndex = vProcIndex; // 当前编辑的病程为新插入的病程
|
|
|
emrView.SetProcBytes(vProcIndex, bytes); // 设置当前病程的内容s
|
|
|
if (vFirstProc) { // 是整个病历的第一个病程
|
|
|
emrView.BeginUpdate(); // 开启批量更新,提高效率
|
|
|
try {
|
|
|
emrView.LoadHeaderFromBytes(bytes); // 加载页眉
|
|
|
emrView.LoadFooterFromBytes(bytes); // 加载页脚
|
|
|
} finally {
|
|
|
emrView.EndUpdate();
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
emrView.ClearUndo(); // 清空撤销记录,防止用户把新插入的病程撤销了
|
|
|
});
|
|
|
}
|
|
|
|
|
|
// 取指定Inex的病程内容
|
|
|
function getProc() {
|
|
|
var procIndex = document.getElementById("procIndex").value;
|
|
|
//var text = emrView.GetProcAsText(procIndex); // 返回病程内容文本
|
|
|
//var bytes = emrView.GetProcAsBytes(procIndex); // 返回病程内容Byte数组(二进制)
|
|
|
var html = emrView.GetProcAsHtml(procIndex); // 返回病程内容Html格式
|
|
|
var vWindow = window.open("", "", "width=" + emrView.ActiveSection.PaperWidthPix);
|
|
|
vWindow.document.write(html);
|
|
|
vWindow.focus();
|
|
|
}
|
|
|
|
|
|
// 编辑光标处病程
|
|
|
function editCaretProc() {
|
|
|
emrView.EditProcIndex = emrView.CaretProcInfo.Index;
|
|
|
}
|
|
|
|
|
|
// 取病程属性信息
|
|
|
function getProcProperty() {
|
|
|
var procIndex = document.getElementById("procIndex").value;
|
|
|
// 取病程所有属性信息
|
|
|
//appendLine("病程" + procIndex + "的属性信息:" + emrView.GetProcProperty(procIndex, TGroupProp.Propertys));
|
|
|
// 取病程Name属性
|
|
|
console.log("病程" + procIndex + "的属性信息:" + emrView.GetProcProperty(procIndex, TGroupProp.Name));
|
|
|
}
|
|
|
|
|
|
// 开启关闭痕迹
|
|
|
function setTrace() {
|
|
|
emrView.Trace = !emrView.Trace;
|
|
|
if (emrView.Trace)
|
|
|
document.getElementById("btnTrace").innerHTML = "关闭留痕";
|
|
|
else
|
|
|
document.getElementById("btnTrace").innerHTML = "开启留痕";
|
|
|
}
|
|
|
|
|
|
// 在留痕模式下,对新痕迹添加痕迹信息
|
|
|
function setTraceInfo() {
|
|
|
// 痕迹时间,实际业务应该取服务端时间
|
|
|
var vDate = new Date();
|
|
|
var vDateTime = vDate.getFullYear() + "-" + (vDate.getMonth() + 1).toString()
|
|
|
+ "-" + vDate.getDate() + " " + vDate.getHours() + ":" + vDate.getMinutes() + ":" + vDate.getSeconds();
|
|
|
var vDeItem;
|
|
|
|
|
|
if (emrView.Trace) { // 当前是留痕模式
|
|
|
let vAreas = new Set([]);
|
|
|
vAreas.add(2);
|
|
|
emrView.TraverseElement(
|
|
|
function (data, itemNo, tag, domainStack, stop) {
|
|
|
vDeItem = data.Items[itemNo];
|
|
|
if (vDeItem.StyleNo > -1) { // 是文本
|
|
|
switch (vDeItem.StyleEx) {
|
|
|
case TStyleExtra.None: {
|
|
|
if (vDeItem.GetValue(TDeProp.Trace) != "")
|
|
|
vDeItem.SetValue(TDeProp.Trace, "");
|
|
|
}
|
|
|
break;
|
|
|
|
|
|
case TStyleExtra.Del: {
|
|
|
if (vDeItem.GetValue(TDeProp.Trace) == "") // 新的删除痕迹
|
|
|
vDeItem.SetValue(TDeProp.Trace, "(jt " + vDateTime + ")删除");
|
|
|
}
|
|
|
break;
|
|
|
|
|
|
case TStyleExtra.Add: {
|
|
|
if (vDeItem.GetValue(TDeProp.Trace) == "") // 新的添加痕迹
|
|
|
vDeItem.SetValue(TDeProp.Trace, "(jt " + vDateTime + ")添加");
|
|
|
}
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
vAreas, 0);
|
|
|
}
|
|
|
else
|
|
|
console.log("当前不是留痕模式");
|
|
|
}
|
|
|
/**------------------------------------------------------------xgf 2020年7月23日 10:18:45 begin -------------------------------------------------**/
|
|
|
function GetQueryString(name){
|
|
|
var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");
|
|
|
var r = window.location.search.substr(1).match(reg);
|
|
|
if(r!=null){
|
|
|
return unescape(r[2]);
|
|
|
}
|
|
|
return null;
|
|
|
}
|
|
|
function feedbackDataToWat(data){
|
|
|
return window.parent.top.DxURLPage.action(GetQueryString('strwinid'),GetQueryString('strctrid'),data);
|
|
|
}
|
|
|
//病历二进制数据返回给平台
|
|
|
function feedbackEmrStreamToWat(asyn){
|
|
|
var steamData = saveToStream();
|
|
|
var emrData = new EmrToWatData("B","saveEMRByte",steamData);
|
|
|
watEvents.emrToWatEvent(emrData,asyn);
|
|
|
}
|
|
|
//病历xml数据返回给平台
|
|
|
function feedbackEmrXmlToWat(){
|
|
|
var xmlData = emrView.SaveToXml();
|
|
|
console.log(xmlData);
|
|
|
var emrData = new EmrToWatData("B","saveEMRXml",xmlData);
|
|
|
watEvents.emrToWatEvent(emrData);
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function watResultToIFrame(data){
|
|
|
var jsonData = JSON.parse(data);
|
|
|
console.log("平台传入的数据event:"+jsonData.event);
|
|
|
// console.log("平台传入的数据data:"+jsonData.data);
|
|
|
watEvents.watToEMREvent(jsonData);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
//数据传递对象
|
|
|
/**
|
|
|
接受平台数据
|
|
|
{
|
|
|
dataType:"",//数据类型,
|
|
|
event:""//数据来源,类别。业务类别,emr001=编辑器init完成。
|
|
|
data:{}
|
|
|
}
|
|
|
**/
|
|
|
function EmrToWatData(dataType,event,data){
|
|
|
this.dataType = dataType;//
|
|
|
this.event = event;
|
|
|
this.data = data;
|
|
|
|
|
|
}
|
|
|
function InsertDeCombobox(){
|
|
|
emrView.InsertDeCombobox({
|
|
|
Index: "495",
|
|
|
Name: "性别",
|
|
|
Static: true, // 是否只能通过选项赋值(不能输入内容),true是,false否
|
|
|
ReadOnly: false, // 是否只读,只读后不能修改内容
|
|
|
SaveItem: true, // 是否保存选项(保存选项会增加文件体积)
|
|
|
PrintOnlyText: true, // 打印时只打印文字,不打印按钮
|
|
|
Items: [ // 插入时添加选项,注意如果要将选项保存到病历文件中,需要设置vDeCombobx.SaveItem = true;
|
|
|
{
|
|
|
Text: "男性",
|
|
|
TextValue: "1",
|
|
|
Checked: true,
|
|
|
},
|
|
|
|
|
|
{
|
|
|
Text: "女性",
|
|
|
TextValue: "2",
|
|
|
Checked: false,
|
|
|
},
|
|
|
]
|
|
|
})
|
|
|
}
|
|
|
function InsertDeRadioGroup(){
|
|
|
emrView.InsertDeRadioGroup({
|
|
|
Index: "495",
|
|
|
Name: "性别",
|
|
|
Style: "CheckBox", // Radio:圆点 CheckBox:勾选
|
|
|
MultSelect: "0", // 单选or多选 0单选 1多选
|
|
|
AutoSize: true, // 根据内容自动计大小
|
|
|
Columes: 2, // 以几列显示
|
|
|
ColumnAlign: true, // 列自动对齐
|
|
|
ItemHit: true, // 点击文件就算选中 false点击圆点或勾选框才算选中
|
|
|
|
|
|
Width: 300,
|
|
|
Items: [ // 选项
|
|
|
{
|
|
|
Text: "未知的性别",
|
|
|
TextValue: "0",
|
|
|
Checked: false,
|
|
|
},
|
|
|
|
|
|
{
|
|
|
Text: "男",
|
|
|
TextValue: "1",
|
|
|
Checked: true,
|
|
|
},
|
|
|
|
|
|
{
|
|
|
Text: "女",
|
|
|
TextValue: "2",
|
|
|
Checked: false,
|
|
|
},
|
|
|
|
|
|
{
|
|
|
Text: "未说明的性别",
|
|
|
TextValue: "9",
|
|
|
Checked: false,
|
|
|
}
|
|
|
]
|
|
|
});
|
|
|
}
|
|
|
function InsertDeCheckBox(){
|
|
|
emrView.InsertDeCheckBox(
|
|
|
{
|
|
|
Index: "495",
|
|
|
Name: "性别",
|
|
|
Style: "CheckBox", // Radio:圆点 CheckBox:勾选
|
|
|
Static: true, // 是否只能通过选项赋值(不能输入内容),true是,false否
|
|
|
ReadOnly: false, // 是否只读,只读后不能修改内容
|
|
|
SaveItem: true, // 是否保存选项(保存选项会增加文件体积)
|
|
|
PrintOnlyText: true, // 打印时只打印文字,不打印按钮
|
|
|
Items: [ // 插入时添加选项,注意如果要将选项保存到病历文件中,需要设置vDeCombobx.SaveItem = true;
|
|
|
{
|
|
|
Text: "男性",
|
|
|
TextValue: "1",
|
|
|
Checked: true,
|
|
|
},
|
|
|
|
|
|
{
|
|
|
Text: "女性",
|
|
|
TextValue: "2",
|
|
|
Checked: false,
|
|
|
},
|
|
|
]
|
|
|
}
|
|
|
|
|
|
);
|
|
|
}
|
|
|
|
|
|
// const interval=1000*60;
|
|
|
// var t_time = setTimeout(function(){
|
|
|
// if(emrView.IsChanged){
|
|
|
// console.log(new Date());
|
|
|
// var steamData = emrView.SaveToBytes();
|
|
|
// var emrData = new EmrToWatData("B","saveEMRByte",steamData);
|
|
|
// window.parent.top.DxURLPage.action(GetQueryString('strwinid'),GetQueryString('strctrid'),JSON.stringify(emrData));
|
|
|
// setTimeout(arguments.callee,interval)
|
|
|
// }
|
|
|
// },interval);
|
|
|
// console.log(t_time);
|
|
|
/**------------------------------------------------------------xgf 2020年7月23日 10:18:45 end -------------------------------------------------**/
|
|
|
</script>
|
|
|
</head>
|
|
|
|
|
|
<body style="height: 100%;" onload="load()">
|
|
|
<div id="divHCEmrView" style="left: 2px; top: 0px; position: fixed; width: 100%; height:100%; background: lightgray;"></div>
|
|
|
</body>
|
|
|
|
|
|
</html> |