index.jsx 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. /**
  2. * Created by Jacky.gao on 2016/9/18.
  3. */
  4. import ScoreCardTable from './ScoreCardTable.js';
  5. import '../../node_modules/bootstrap/dist/css/bootstrap.css';
  6. import '../css/iconfont.css';
  7. import './scorecard.css';
  8. import '../editor/context.standalone.css';
  9. import '../editor/urule/ruleset.css';
  10. import React from 'react';
  11. import ReactDOM from 'react-dom';
  12. import '../Remark.js';
  13. import '../editor/common/jquery.utils.js';
  14. import '../editor/common/URule.js';
  15. import '../editor/common/contextMenu.js';
  16. import '../editor/Math.uuid.js';
  17. import '../editor/common/Context.js';
  18. import '../editor/decisiontable/CellCondition.js';
  19. import '../editor/decisiontable/Condition.js';
  20. import '../editor/decisiontable/Join.js';
  21. import '../editor/decisiontable/Connection.js';
  22. import '../editor/common/ComparisonOperator.js';
  23. import '../editor/common/ComplexArithmetic.js';
  24. import '../editor/common/VariableValue.js';
  25. import '../editor/common/ConstantValue.js';
  26. import '../editor/urule/SimpleArithmetic.js';
  27. import '../editor/common/InputType.js';
  28. import '../editor/common/NextType.js';
  29. import '../editor/common/Paren.js';
  30. import '../editor/common/MethodParameter.js';
  31. import '../editor/common/MethodAction.js';
  32. import '../editor/common/ParameterValue.js';
  33. import '../editor/common/MethodValue.js';
  34. import '../editor/common/FunctionProperty.js';
  35. import '../editor/common/FunctionParameter.js';
  36. import '../editor/common/FunctionValue.js';
  37. import '../editor/common/SimpleValue.js';
  38. import '../editor/urule/ConfigActionDialog.js';
  39. import '../editor/urule/ConfigConstantDialog.js';
  40. import '../editor/urule/ConfigParameterDialog.js';
  41. import '../editor/urule/ConfigVariableDialog.js';
  42. import '../editor/urule/RuleProperty.js';
  43. import {ajaxSave,getParameter} from '../Utils.js';
  44. import KnowledgeTreeDialog from '../components/dialog/component/KnowledgeTreeDialog.jsx';
  45. $(document).ready(function (e) {
  46. const file=getParameter("file");
  47. if(!file){
  48. alert("未指定文件.");
  49. return;
  50. }
  51. const toolbarContainer=$("#toolbarContainer");
  52. const toolbar=$(`<div class="btn-toolbar" style="border: solid 1px #d0d0d0;padding:5px;margin:3px;border-radius: 5px;background: #fdfdfd"></div>`);
  53. toolbarContainer.append(toolbar);
  54. const operationGroup=$(`<div class="btn-group btn-group-sm"></div>`);
  55. toolbar.append(operationGroup);
  56. const addAttributeButton=$("<button type='button' class='btn btn-default'><i class='glyphicon glyphicon-plus'></i> 添加属性行</button>");
  57. operationGroup.append(addAttributeButton);
  58. const addCustomColButton=$("<button type='button' class='btn btn-default'><i class='glyphicon glyphicon-plus-sign'></i> 添加自定义列</button>");
  59. operationGroup.append(addCustomColButton);
  60. var self=this;
  61. const configGroup=$(`<div class="btn-group btn-group-sm"></div>`);
  62. toolbar.append(configGroup);
  63. const variableButton=$(`<button type="button" class="btn btn-default"><i class="rf rf-variable"></i> 变量库</button>`);
  64. configGroup.append(variableButton);
  65. variableButton.click(function () {
  66. if(!self.configVarDialog){
  67. self.configVarDialog=new urule.ConfigVariableDialog(self);
  68. }
  69. self.configVarDialog.open();
  70. });
  71. const constButton=$(`<button type="button" class="btn btn-default"><i class="rf rf-constant"></i> 常量库</button>`);
  72. configGroup.append(constButton);
  73. constButton.click(function () {
  74. if(!self.configConstantDialog){
  75. self.configConstantDialog=new urule.ConfigConstantDialog(self);
  76. }
  77. self.configConstantDialog.open();
  78. });
  79. const actionButton=$(`<button type="button" class="btn btn-default"><i class="rf rf-action"></i> 动作库</button>`);
  80. configGroup.append(actionButton);
  81. actionButton.click(function () {
  82. if(!self.configActionDialog){
  83. self.configActionDialog=new urule.ConfigActionDialog(self);
  84. }
  85. self.configActionDialog.open();
  86. });
  87. const parameterButton=$(` <button type="button" class="btn btn-default"><i class="rf rf-parameter"></i> 参数库</button>`);
  88. configGroup.append(parameterButton);
  89. parameterButton.click(function () {
  90. if(!self.configParameterDialog){
  91. self.configParameterDialog=new urule.ConfigParameterDialog(self);
  92. }
  93. self.configParameterDialog.open();
  94. });
  95. const saveGroup=$(`<div class="btn-group btn-group-sm"></div>`);
  96. toolbar.append(saveGroup);
  97. const saveButton=$(`<button type="button" class="btn btn-default disabled"><i class="rf rf-save"></i> 保存</button>`);
  98. saveGroup.append(saveButton);
  99. const saveVersionButton=$(`<button type="button" class="btn btn-default disabled"><i class="rf rf-savenewversion"></i> 保存新版本</button>`);
  100. saveGroup.append(saveVersionButton);
  101. window._setDirty=function(){
  102. if(self._dirty){
  103. return;
  104. }
  105. self._dirty=true;
  106. window._dirty=true;
  107. saveButton.html("<i class='rf rf-save'></i> *保存");
  108. saveButton.removeClass("disabled");
  109. saveVersionButton.html("<i class='rf rf-savenewversion'></i> *保存新版本");
  110. saveVersionButton.removeClass("disabled");
  111. };
  112. function cancelDirty(){
  113. if(!self._dirty){
  114. return;
  115. }
  116. self._dirty=false;
  117. window._dirty=false;
  118. saveButton.html("<i class='rf rf-save'></i> 保存");
  119. saveButton.addClass("disabled");
  120. saveVersionButton.html("<i class='rf rf-savenewversion'></i> 保存新版本");
  121. saveVersionButton.addClass("disabled");
  122. };
  123. addAttributeButton.click(function () {
  124. cardTable.addAttributeRow();
  125. });
  126. addCustomColButton.click(function () {
  127. cardTable.addCustomCol();
  128. });
  129. const cardTable=new ScoreCardTable({
  130. container:$("#tableContainer"),
  131. headers:[]
  132. });
  133. function save(newVersion) {
  134. try{
  135. const content=cardTable.toXml();
  136. const url=window._server+"/common/saveFile";
  137. if(newVersion){
  138. bootbox.prompt("请输入新版本描述.",function (versionComment) {
  139. if(!versionComment){
  140. return;
  141. }
  142. ajaxSave(url,{content,file,newVersion,versionComment},function () {
  143. cancelDirty();
  144. });
  145. });
  146. }else{
  147. ajaxSave(url,{content,file,newVersion},function () {
  148. cancelDirty();
  149. });
  150. }
  151. }catch(error){
  152. bootbox.alert(error.message || error);
  153. //throw error;
  154. }
  155. };
  156. saveButton.click(function () {
  157. save(false);
  158. });
  159. saveVersionButton.click(function () {
  160. save(true);
  161. });
  162. ReactDOM.render(
  163. <KnowledgeTreeDialog/>,
  164. document.getElementById("dialogContainer")
  165. );
  166. $.ajax({
  167. url:window._server+"/common/loadXml",
  168. type:"POST",
  169. data:{files:file},
  170. success:function (data) {
  171. const card=data[0];
  172. cardTable.init(card);
  173. var libraries=card.libraries;
  174. if(libraries){
  175. for(var i=0;i<libraries.length;i++){
  176. var lib=libraries[i];
  177. var type=lib["type"];
  178. var path=lib["path"];
  179. switch(type){
  180. case "Constant":
  181. constantLibraries.push(path);
  182. break;
  183. case "Action":
  184. actionLibraries.push(path);
  185. break;
  186. case "Variable":
  187. variableLibraries.push(path);
  188. break;
  189. case "Parameter":
  190. parameterLibraries.push(path);
  191. break;
  192. }
  193. refreshActionLibraries();
  194. refreshConstantLibraries();
  195. refreshVariableLibraries();
  196. refreshParameterLibraries();
  197. refreshFunctionLibraries();
  198. }
  199. cancelDirty();
  200. }
  201. },
  202. error:function (response) {
  203. if(response && response.responseText){
  204. bootbox.alert("<span style='color: red'>加载数据失败,服务端错误:"+response.responseText+"</span>");
  205. }else{
  206. bootbox.alert("<span style='color: red'>加载数据失败,服务端出错</span>");
  207. }
  208. }
  209. });
  210. });