|
|
|
<!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"></script>
|
|
|
|
<script type="text/javascript" src="./WatEvent.js"></script>
|
|
|
|
<script type="text/javascript">
|
|
|
|
|
|
|
|
// 数据元属性
|
|
|
|
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 appendLine(s) {
|
|
|
|
var textArea = document.getElementById("textBox");
|
|
|
|
if (textArea)
|
|
|
|
textArea.value += "\r\n" + s;
|
|
|
|
}
|
|
|
|
|
|
|
|
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() {
|
|
|
|
console.log("load........");
|
|
|
|
emrView = new THCEmrViewLib({
|
|
|
|
//hcServer: "http://139.9.152.193:12880/", // HC服务端IP-->
|
|
|
|
//hcServer: "http://127.0.0.1:12880/", // HC服务端IP-->
|
|
|
|
//hcServer: "http://192.168.1.122:12880/",
|
|
|
|
//hcServer: "http://192.168.5.104:12880/",
|
|
|
|
hcServer: "http://11.21.6.225:12880/",
|
|
|
|
baseUrl: "./", // 编辑器需要的资源路径
|
|
|
|
el: "divHCEmrView", // 编辑器父容器的ID
|
|
|
|
defaultFontSize: "小四", // 编辑器默认字号,默认小四
|
|
|
|
defaultFontFamily: "宋体", // 编辑器默认字体,默认宋体
|
|
|
|
paperSize: "A4", // 纸张大小
|
|
|
|
paperOrientation: 0, // 纸张方向 0纵向 1横向,默认0
|
|
|
|
designMode: false, // 是否设计模式,也可以使用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,
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
// 右键菜单中添加自定义菜单
|
|
|
|
contextMenu: [
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
// 事件
|
|
|
|
event: {
|
|
|
|
|
|
|
|
// 点击了编辑器工具栏上的保存按钮时触发
|
|
|
|
onSave: function() {
|
|
|
|
appendLine("onSave 事件触发");
|
|
|
|
feedbackEmrStreamToWat();
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 单选或多选数据元获鼠标点击后,显示选项时触发,可在这里把选项传递到编辑器中
|
|
|
|
onPopupGetDeItemDomain: function(cmv) {
|
|
|
|
appendLine("onPopupGetDeItemDomain 选项类数据元点击时请求选项 参数:" + cmv);
|
|
|
|
//xgf
|
|
|
|
var data = new EmrToWatData("S","EMR004",cmv);//编辑器初始化完成
|
|
|
|
return watEvents.getDeItemDomain(data,watEvents.url);
|
|
|
|
},
|
|
|
|
|
|
|
|
// 数据元选项有扩展内容时,获取扩展内容
|
|
|
|
onPopupGetDomainItemExtraLib: function(item, cvvid) {
|
|
|
|
if (item.Index == 495) { // 性别
|
|
|
|
if (cvvid == 3683) { // 选择了带内容的
|
|
|
|
emrView.SetActiveItemExtraWithJSON({
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
// 当编辑器在加载文档或插入了新的Item时触发,便于外部替换数据元的值
|
|
|
|
onInserItemSync: function(sender, data, item) {
|
|
|
|
console.log("装载数据元:"+item.Code);
|
|
|
|
var hcdata =watEvents.getHcData();
|
|
|
|
|
|
|
|
for(prop in hcdata){
|
|
|
|
if(item.Code==prop){
|
|
|
|
item.Text = hcdata[prop];
|
|
|
|
item.AllocValue = true; // 该元素填写过值了
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (item.Index == "494") { // item是编辑
|
|
|
|
item.Text = "李四";
|
|
|
|
item.AllocValue = true; // 该元素填写过值了
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
// 当编辑器中的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选中范围续打
|
|
|
|
console.log(type == 0 ? "打印" : "续打");
|
|
|
|
},
|
|
|
|
onInitialization: function(){
|
|
|
|
appendLine("初始化完成");
|
|
|
|
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 propertys = emrView.GetCaretDeGroupProperty("Propertys","json");//json对象
|
|
|
|
console.log(propertys.isSave);
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 向编辑器的右键菜单中添加菜单
|
|
|
|
emrView.AddContextMenu(
|
|
|
|
[
|
|
|
|
|
|
|
|
{
|
|
|
|
text:"删除病程标识",
|
|
|
|
exec:function(){
|
|
|
|
emrView.InnerView.DeleteAllProcMark();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
function applyTextStyle(style) {
|
|
|
|
// 设置选中的文本设置样式
|
|
|
|
emrView.ApplyTextStyle(style);
|
|
|
|
}
|
|
|
|
|
|
|
|
function applyParaAlignHorz(align) {
|
|
|
|
// 设置当前光标所在的段水平对齐
|
|
|
|
emrView.ApplyParaAlignHorz(align);
|
|
|
|
}
|
|
|
|
|
|
|
|
function LoadFromBytes(bytes) { // 二进制数组
|
|
|
|
// 加载文件,文件数据是byte数组
|
|
|
|
emrView.LoadFromBytes(bytes);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**------------------------------------------------------------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;
|
|
|
|
}
|
|
|
|
//保存数据返回给平台[add by xgf 2020年7月23日 10:13:13]
|
|
|
|
function feedbackDataToWat(data){
|
|
|
|
//console.log("二进制数据:"+data,"strwinid:"+GetQueryString('strwinid'),+"strctrid:"+GetQueryString('strctrid'));
|
|
|
|
return window.parent.top.DxURLPage.action(GetQueryString('strwinid'),GetQueryString('strctrid'),data);
|
|
|
|
}
|
|
|
|
//病历二进制数据返回给平台
|
|
|
|
function feedbackEmrStreamToWat(){
|
|
|
|
var steamData = emrView.SaveToLiteBytes(); //保存片段
|
|
|
|
var emrData = new EmrToWatData("B","saveEMRByte",steamData);
|
|
|
|
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
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**------------------------------------------------------------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>
|