edit.html 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620
  1. <!DOCTYPE html>
  2. <html lang="zh" xmlns:th="http://www.thymeleaf.org" >
  3. <head>
  4. <th:block th:include="include :: header('修改生成信息')" />
  5. <th:block th:include="include :: select2-css" />
  6. <style type="text/css">
  7. .select-table table{table-layout:fixed;}.table>thead>tr>th{text-align:center;}.select-table .table td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.form-control{padding:3px 6px 4px;height:30px;}.icheckbox-blue{top:0px;left:6px;}.form-control.select2-hidden-accessible{position:static!important;}.select-table table label.error{position: inherit;}select + label.error{z-index:1;right:40px;}
  8. </style>
  9. </head>
  10. <body class="gray-bg" style="font: 14px Helvetica Neue, Helvetica, PingFang SC, 微软雅黑, Tahoma, Arial, sans-serif !important;">
  11. <section class="section-content">
  12. <div class="row">
  13. <div class="col-xs-12">
  14. <div class="ibox float-e-margins">
  15. <div class="ibox-content" style="border-style:none;">
  16. <div class="nav-tabs-custom">
  17. <ul class="nav nav-tabs">
  18. <li><a href="#tab-basic" data-toggle="tab" aria-expanded="false">基本信息</a></li>
  19. <li class="active"><a href="#tab-field" data-toggle="tab" aria-expanded="true">字段信息</a></li>
  20. <li><a href="#tab-gen" data-toggle="tab" aria-expanded="false">生成信息</a></li>
  21. <li class="pull-right header">
  22. <i class="fa fa-code"></i> 生成配置
  23. </li>
  24. </ul>
  25. <form id="form-gen-edit" class="form-horizontal" th:object="${table}">
  26. <input name="tableId" type="hidden" th:field="*{tableId}" />
  27. <div class="tab-content">
  28. <!-- 基本信息 -->
  29. <div class="tab-pane" id="tab-basic">
  30. <div class="row mt20">
  31. <div class="col-sm-6">
  32. <div class="form-group">
  33. <label class="col-sm-4 control-label is-required">表名称:</label>
  34. <div class="col-sm-8">
  35. <input name="tableName" class="form-control" type="text" placeholder="请输入表名称" maxlength="200" th:field="*{tableName}" required>
  36. </div>
  37. </div>
  38. </div>
  39. <div class="col-sm-6">
  40. <div class="form-group">
  41. <label class="col-sm-4 control-label is-required">表描述:</label>
  42. <div class="col-sm-8">
  43. <input name="tableComment" class="form-control" type="text" placeholder="请输入表描述" maxlength="500" th:field="*{tableComment}" required>
  44. </div>
  45. </div>
  46. </div>
  47. </div>
  48. <div class="row">
  49. <div class="col-sm-6">
  50. <div class="form-group">
  51. <label class="col-sm-4 control-label is-required">实体类名称:</label>
  52. <div class="col-sm-8">
  53. <input name="className" class="form-control" type="text" placeholder="请输入实体类名称" maxlength="100" th:field="*{className}" required>
  54. </div>
  55. </div>
  56. </div>
  57. <div class="col-sm-6">
  58. <div class="form-group">
  59. <label class="col-sm-4 control-label is-required">作者:</label>
  60. <div class="col-sm-8">
  61. <input name="functionAuthor" class="form-control" type="text" placeholder="请输入作者" maxlength="50" th:field="*{functionAuthor}" required>
  62. </div>
  63. </div>
  64. </div>
  65. </div>
  66. <div class="row">
  67. <div class="col-sm-12">
  68. <div class="form-group">
  69. <label class="col-xs-2 control-label">备注:</label>
  70. <div class="col-xs-10">
  71. <textarea name="remark" maxlength="500" class="form-control" rows="3"></textarea>
  72. </div>
  73. </div>
  74. </div>
  75. </div>
  76. </div>
  77. <!-- 字段信息 -->
  78. <div class="tab-pane active" id="tab-field">
  79. <div class="select-table table-striped" style="margin-top: 0px;padding-top: 0px;padding-bottom: 0px;">
  80. <table id="bootstrap-table" data-use-row-attr-func="true" data-reorderable-rows="true"></table>
  81. </div>
  82. </div>
  83. <!-- 生成信息 -->
  84. <div class="tab-pane" id="tab-gen">
  85. <div class="row mt20">
  86. <div class="col-sm-6">
  87. <div class="form-group">
  88. <label class="col-sm-4 control-label is-required">生成模板:</label>
  89. <div class="col-sm-8">
  90. <select class='form-control' id="tplCategory" name='tplCategory' style="width: 100%">
  91. <option value="crud" th:field="*{tplCategory}">单表(增删改查)</option>
  92. <option value="tree" th:field="*{tplCategory}">树表(增删改查)</option>
  93. <option value="sub" th:field="*{tplCategory}">主子表(增删改查)</option>
  94. </select>
  95. </div>
  96. </div>
  97. </div>
  98. <div class="col-sm-6">
  99. <div class="form-group">
  100. <label class="col-sm-4 control-label is-required" title="生成在哪个java包下,例如 com.bzd.project.system">生成包路径:<i class="fa fa-question-circle-o"></i></label>
  101. <div class="col-sm-8">
  102. <input name="packageName" class="form-control" type="text" placeholder="请输入生成包路径" maxlength="100" th:field="*{packageName}" required>
  103. </div>
  104. </div>
  105. </div>
  106. </div>
  107. <div class="row">
  108. <div class="col-sm-6">
  109. <div class="form-group">
  110. <label class="col-sm-4 control-label is-required" title="可理解为子系统名,例如 system">生成模块名:<i class="fa fa-question-circle-o"></i></label>
  111. <div class="col-sm-8">
  112. <input name="moduleName" class="form-control" type="text" placeholder="请输入生成模块名" maxlength="30" th:field="*{moduleName}" required>
  113. </div>
  114. </div>
  115. </div>
  116. <div class="col-sm-6">
  117. <div class="form-group">
  118. <label class="col-sm-4 control-label is-required" title="可理解为功能英文名,例如 user">生成业务名:<i class="fa fa-question-circle-o"></i></label>
  119. <div class="col-sm-8">
  120. <input name="businessName" class="form-control" type="text" placeholder="请输入生成业务名" maxlength="50" th:field="*{businessName}" required>
  121. </div>
  122. </div>
  123. </div>
  124. </div>
  125. <div class="row">
  126. <div class="col-sm-6">
  127. <div class="form-group">
  128. <label class="col-sm-4 control-label is-required" title="用作类描述,例如 用户">生成功能名:<i class="fa fa-question-circle-o"></i></label>
  129. <div class="col-sm-8">
  130. <input name="functionName" class="form-control" type="text" placeholder="请输入生成功能名" maxlength="50" th:field="*{functionName}" required>
  131. </div>
  132. </div>
  133. </div>
  134. <div class="col-sm-6">
  135. <div class="form-group">
  136. <label class="col-sm-4 control-label is-required" title="选择表单的栅格布局方式">表单布局:<i class="fa fa-question-circle-o"></i></label>
  137. <div class="col-sm-8">
  138. <select class='form-control' id="formColNum" name='formColNum' style="width: 100%">
  139. <option value="1" th:field="*{formColNum}">单列</option>
  140. <option value="2" th:field="*{formColNum}">双列</option>
  141. <option value="3" th:field="*{formColNum}">三列</option>
  142. </select>
  143. </div>
  144. </div>
  145. </div>
  146. </div>
  147. <div class="row">
  148. <div class="col-sm-6">
  149. <div class="form-group">
  150. <label class="col-sm-4 control-label" title="默认为zip压缩包下载,也可以自定义生成路径">生成代码方式:<i class="fa fa-question-circle-o"></i></label>
  151. <div class="col-sm-8">
  152. <label class="radio-box"> <input type="radio" name="genType" value="0" th:field="*{genType}" /> zip压缩包 </label>
  153. <label class="radio-box"> <input type="radio" name="genType" value="1" th:field="*{genType}" /> 自定义路径</label>
  154. </div>
  155. </div>
  156. </div>
  157. <div class="col-sm-6">
  158. <div class="form-group">
  159. <label class="col-sm-4 control-label is-required" title="分配到指定菜单下,例如 系统管理">上级菜单:<i class="fa fa-question-circle-o"></i></label>
  160. <div class="col-sm-8">
  161. <input id="parentMenuId" name="params[parentMenuId]" type="hidden" th:value="*{parentMenuId}"/>
  162. <div class="input-group">
  163. <input id="parentMenuName" name="params[parentMenuName]" class="form-control" type="text" onclick="selectMenuTree()" placeholder="请选择上级菜单" maxlength="50" th:value="*{parentMenuName}" required>
  164. <span class="input-group-addon"><i class="fa fa-search"></i></span>
  165. </div>
  166. </div>
  167. </div>
  168. </div>
  169. </div>
  170. <div class="hidden row" id="pathinfo">
  171. <div class="col-sm-12">
  172. <div class="form-group">
  173. <label class="col-xs-2 control-label" title="填写磁盘绝对路径,若不填写,则生成到当前Web项目下">生成基础路径:<i class="fa fa-question-circle-o"></i></label>
  174. <div class="col-xs-10">
  175. <div class="input-group input-group-sm">
  176. <input id="genPath" name="genPath" class="form-control" type="text" th:field="*{genPath}" placeholder="请输入项目路径" maxlength="200">
  177. <div class="input-group-btn">
  178. <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown">最近路径快速选择 <span class="caret"></span></button>
  179. <ul class="dropdown-menu dropdown-menu-right" role="menu">
  180. <li><a href="javascript:$('#genPath').val('/')"><i class="fa fa-refresh"></i>恢复默认的生成基础路径</a></li>
  181. </ul>
  182. </div>
  183. </div>
  184. </div>
  185. </div>
  186. </div>
  187. </div>
  188. <div class="hidden" id="subInfo">
  189. <h4 class="form-header h4">关联信息</h4>
  190. <div class="row">
  191. <div class="col-sm-6">
  192. <div class="form-group">
  193. <label class="col-sm-4 control-label is-required" title="关联子表的表名, 如:sys_user">关联子表的表名:<i class="fa fa-question-circle-o"></i></label>
  194. <div class="col-sm-8">
  195. <select class='type form-control' id="subTableName" name='subTableName' th:attr='data-value=*{subTableName}' style="width: 100%">
  196. <option value="">---请选择---</option>
  197. </select>
  198. </div>
  199. </div>
  200. </div>
  201. <div class="col-sm-6">
  202. <div class="form-group">
  203. <label class="col-sm-4 control-label is-required" title="子表关联的外键名, 如:user_id">子表关联的外键名:<i class="fa fa-question-circle-o"></i></label>
  204. <div class="col-sm-8">
  205. <select class='router form-control' id="subTableFkName" name='subTableFkName' th:attr='data-value=*{subTableFkName}' style="width: 100%">
  206. <option value="">---请选择---</option>
  207. </select>
  208. </div>
  209. </div>
  210. </div>
  211. </div>
  212. </div>
  213. <div class="hidden" id="otherInfo">
  214. <h4 class="form-header h4">其他信息</h4>
  215. <div class="row">
  216. <div class="col-sm-6">
  217. <div class="form-group">
  218. <label class="col-sm-4 control-label is-required" title="树显示的编码字段名, 如:dept_id">树编码字段:<i class="fa fa-question-circle-o"></i></label>
  219. <div class="col-sm-8">
  220. <select class='form-control' id="treeCode" name='params[treeCode]' style="width: 100%">
  221. <option value="">---请选择---</option>
  222. <option th:each="column : ${table.columns}" th:text="${column.columnName + ':' + column.columnComment}" th:value="${column.columnName}" th:field="*{treeCode}"></option>
  223. </select>
  224. </div>
  225. </div>
  226. </div>
  227. <div class="col-sm-6">
  228. <div class="form-group">
  229. <label class="col-sm-4 control-label is-required" title="树显示的父编码字段名, 如:parent_Id">树父编码字段:<i class="fa fa-question-circle-o"></i></label>
  230. <div class="col-sm-8">
  231. <select class='form-control' id="treeParentCode" name='params[treeParentCode]' style="width: 100%">
  232. <option value="">---请选择---</option>
  233. <option th:each="column : ${table.columns}" th:text="${column.columnName + ':' + column.columnComment}" th:value="${column.columnName}" th:field="*{treeParentCode}"></option>
  234. </select>
  235. </div>
  236. </div>
  237. </div>
  238. </div>
  239. <div class="row">
  240. <div class="col-sm-6">
  241. <div class="form-group">
  242. <label class="col-sm-4 control-label is-required" title="树节点的显示名称字段名, 如:dept_name">树名称字段:<i class="fa fa-question-circle-o"></i></label>
  243. <div class="col-sm-8">
  244. <select class='form-control' id="treeName" name='params[treeName]' style="width: 100%">
  245. <option value="">---请选择---</option>
  246. <option th:each="column : ${table.columns}" th:text="${column.columnName + ':' + column.columnComment}" th:value="${column.columnName}" th:field="*{treeName}"></option>
  247. </select>
  248. </div>
  249. </div>
  250. </div>
  251. </div>
  252. </div>
  253. </div>
  254. </div>
  255. </form>
  256. </div>
  257. </div>
  258. <div class="box-footer">
  259. <div class="col-sm-offset-5 col-sm-6">
  260. <button type="button" class="btn btn-sm btn-primary" onclick="submitHandler()"><i class="fa fa-check"></i>保 存</button>&nbsp;
  261. <button type="button" class="btn btn-sm btn-danger" onclick="closeItem()"><i class="fa fa-reply-all"></i>关 闭 </button>
  262. </div>
  263. </div>
  264. </div>
  265. </div>
  266. </div>
  267. </section>
  268. <th:block th:include="include :: footer" />
  269. <th:block th:include="include :: select2-js" />
  270. <th:block th:include="include :: bootstrap-table-reorder-rows-js" />
  271. <script th:src="@{/js/jquery.tmpl.js}"></script>
  272. <th:block th:include="include :: jquery-cxselect-js" />
  273. <script th:inline="javascript">
  274. /* 用户信息-修改 */
  275. $("#form-table-edit").validate({
  276. rules: {
  277. tableName: {
  278. required: true,
  279. },
  280. },
  281. focusCleanup: true
  282. });
  283. /* 表级联信息 */
  284. var data = [[${data}]];
  285. $('#subInfo').cxSelect({
  286. selects: ['type', 'router'],
  287. jsonValue: 'v',
  288. data: data
  289. });
  290. function submitHandler() {
  291. if ($.validate.form()) {
  292. $.operate.saveTab(prefix + "/edit", $("#form-gen-edit").serializeArray());
  293. }
  294. }
  295. var prefix = ctx + "tool/gen";
  296. $(function() {
  297. var options = {
  298. url: prefix + "/column/list",
  299. sidePagination: "client",
  300. sortName: "sort",
  301. sortOrder: "desc",
  302. height: $(window).height() - 166,
  303. pagination: false,
  304. showSearch: false,
  305. showRefresh: false,
  306. showToggle: false,
  307. showColumns: false,
  308. onLoadSuccess: onLoadSuccess,
  309. onReorderRow: onReorderRow,
  310. columns: [{
  311. title: "序号",
  312. width: "5%",
  313. formatter: function (value, row, index) {
  314. // 编号隐藏域
  315. var columnIdHtml = $.common.sprintf("<input type='hidden' name='columns[%s].columnId' value='%s'>", index, row.columnId);
  316. // 排序隐藏域
  317. var sortHtml = $.common.sprintf("<input type='hidden' name='columns[%s].sort' value='%s' id='columns_sort_%s'>", index, row.sort, row.columnId);
  318. return columnIdHtml + sortHtml + $.table.serialNumber(index);
  319. },
  320. cellStyle: function(value, row, index) {
  321. return { css: { "cursor": "move" } };
  322. }
  323. },
  324. {
  325. field: 'columnName',
  326. title: '字段列名',
  327. width: "10%",
  328. class: "nodrag",
  329. cellStyle: function(value, row, index) {
  330. return { css: { "cursor": "default" } };
  331. }
  332. },
  333. {
  334. field: 'columnComment',
  335. title: '字段描述',
  336. width: "10%",
  337. formatter: function (value, row, index) {
  338. var html = $.common.sprintf("<input class='form-control' type='text' name='columns[%s].columnComment' value='%s'>", index, value);
  339. return html;
  340. }
  341. },
  342. {
  343. field: 'columnType',
  344. title: '物理类型',
  345. width: "10%",
  346. class: "nodrag",
  347. cellStyle: function(value, row, index) {
  348. return { css: { "cursor": "default" } };
  349. }
  350. },
  351. {
  352. field: 'javaType',
  353. title: 'Java类型',
  354. width: "10%",
  355. formatter: function (value, row, index) {
  356. var data = [{ index: index, javaType: value }];
  357. return $("#javaTypeTpl").tmpl(data).html();
  358. }
  359. },
  360. {
  361. field: 'javaField',
  362. title: 'Java属性',
  363. width: "10%",
  364. formatter: function (value, row, index) {
  365. var html = $.common.sprintf("<input class='form-control' type='text' name='columns[%s].javaField' value='%s' required>", index, value);
  366. return html;
  367. }
  368. },
  369. {
  370. field: 'isInsert',
  371. title: '插入',
  372. width: "5%",
  373. formatter: function (value, row, index) {
  374. var isCheck = value == 1 ? 'checked' : '';
  375. var html = $.common.sprintf("<label class='check-box'><input type='checkbox' name='columns[%s].isInsert' value='1' %s></label>", index, isCheck);
  376. return html;
  377. }
  378. },
  379. {
  380. field: 'isEdit',
  381. title: '编辑',
  382. width: "5%",
  383. formatter: function (value, row, index) {
  384. var isCheck = value == 1 ? 'checked' : '';
  385. var html = $.common.sprintf("<label class='check-box'><input type='checkbox' name='columns[%s].isEdit' value='1' %s></label>", index, isCheck);
  386. return html;
  387. }
  388. },
  389. {
  390. field: 'isList',
  391. title: '列表',
  392. width: "5%",
  393. formatter: function (value, row, index) {
  394. var isCheck = value == 1 ? 'checked' : '';
  395. var html = $.common.sprintf("<label class='check-box'><input type='checkbox' name='columns[%s].isList' value='1' %s></label>", index, isCheck);
  396. return html;
  397. }
  398. },
  399. {
  400. field: 'isQuery',
  401. title: '查询',
  402. width: "5%",
  403. formatter: function (value, row, index) {
  404. var isCheck = value == 1 ? 'checked' : '';
  405. var html = $.common.sprintf("<label class='check-box'><input type='checkbox' name='columns[%s].isQuery' value='1' %s></label>", index, isCheck);
  406. return html;
  407. }
  408. },
  409. {
  410. field: 'queryType',
  411. title: '查询方式',
  412. width: "10%",
  413. formatter: function (value, row, index) {
  414. var data = [{ index: index, queryType: value }];
  415. return $("#queryTypeTpl").tmpl(data).html();
  416. }
  417. },
  418. {
  419. field: 'isRequired',
  420. title: '必填',
  421. width: "5%",
  422. formatter: function (value, row, index) {
  423. var isCheck = value == 1 ? 'checked' : '';
  424. var html = $.common.sprintf("<label class='check-box'><input type='checkbox' name='columns[%s].isRequired' value='1' %s></label>", index, isCheck);
  425. return html;
  426. }
  427. },
  428. {
  429. field: 'htmlType',
  430. title: '显示类型',
  431. width: "12%",
  432. formatter: function (value, row, index) {
  433. var data = [{ index: index, htmlType: value }];
  434. return $("#htmlTypeTpl").tmpl(data).html();
  435. }
  436. },
  437. {
  438. field: 'dictType',
  439. title: '字典类型',
  440. width: "13%",
  441. formatter: function (value, row, index) {
  442. var html = $.common.sprintf("<input class='form-control' type='text' name='columns[%s].dictType' value='%s' id='columns_dict_%s'>", index, (value === undefined ? '' : value), row.columnId);
  443. return "<div class='input-group'>" + html + "<span class='input-group-addon input-sm' onclick='selectDictTree(" + row.columnId + ", this)'><i class='fa fa-search'></i></span></div>";
  444. },
  445. cellStyle: function(value, row, index) {
  446. return { css: { "cursor": "default" } };
  447. }
  448. }]
  449. };
  450. $.table.init(options);
  451. });
  452. // 当所有数据被加载时触发处理函数
  453. function onLoadSuccess(data){
  454. $.fn.select2.defaults.set( "theme", "bootstrap" );
  455. $("select.form-control").each(function () {
  456. $(this).select2().on("change", function () {
  457. $(this).valid();
  458. })
  459. })
  460. $(".check-box").each(function() {
  461. $(this).iCheck({
  462. checkboxClass: 'icheckbox-blue'
  463. })
  464. })
  465. }
  466. // 当拖拽结束后处理函数
  467. function onReorderRow(data) {
  468. for (var i = 0; i < data.length; i++) {
  469. $("#columns_sort_" + data[i].columnId).val(i+1);
  470. }
  471. }
  472. $(function() {
  473. var tplCategory = $("#tplCategory option:selected").val();
  474. tplCategoryVisible(tplCategory);
  475. var genType = $('input[name="genType"]:checked').val();
  476. pathInfoVisible(genType);
  477. });
  478. $('#tplCategory').on('select2:select', function (event) {
  479. var tplCategory = $(event.target).val();
  480. tplCategoryVisible(tplCategory);
  481. });
  482. function tplCategoryVisible(tplCategory) {
  483. if("crud" == tplCategory){
  484. $("#treeCode").select2("val", [""]);
  485. $("#treeParentCode").select2("val", [""]);
  486. $("#treeName").select2("val", [""]);
  487. $("#otherInfo").addClass("hidden");
  488. $("#subInfo").addClass("hidden");
  489. } else if("tree" == tplCategory){
  490. $("#otherInfo").removeClass("hidden");
  491. $("#treeCode").attr("required", "true");
  492. $("#treeParentCode").attr("required", "true");
  493. $("#treeName").attr("required", "true");
  494. $("#subInfo").addClass("hidden");
  495. } else if("sub" == tplCategory){
  496. $("#subInfo").removeClass("hidden");
  497. $("#treeCode").select2("val", [""]);
  498. $("#treeParentCode").select2("val", [""]);
  499. $("#treeName").select2("val", [""]);
  500. $("#subTableName").attr("required", "true");
  501. $("#subTableFkName").attr("required", "true");
  502. $("#otherInfo").addClass("hidden");
  503. }
  504. }
  505. $('input').on('ifChecked', function(event){
  506. var genType = $(event.target).val();
  507. pathInfoVisible(genType);
  508. });
  509. function pathInfoVisible(genType) {
  510. if("0" == genType){
  511. $("#genPath").val("/");
  512. $("#pathinfo").addClass("hidden");
  513. } else if("1" == genType){
  514. $("#pathinfo").removeClass("hidden");
  515. }
  516. }
  517. // 选择字典处理函数
  518. function selectDictTree(columnId, obj) {
  519. var dictType = $.common.nullToStr($(obj).parent().find("input").val());
  520. var url = ctx + "system/dict/selectDictTree/" + columnId + "/" + dictType;
  521. var options = {
  522. title: '选择字典类型',
  523. width: "380",
  524. url: url,
  525. callBack: doDictSubmit
  526. };
  527. $.modal.openOptions(options);
  528. }
  529. // 选择菜单处理函数
  530. function selectMenuTree() {
  531. var parentMenuId = $("#parentMenuId").val();
  532. var menuId = parentMenuId > 0 ? parentMenuId : 1;
  533. var url = ctx + "system/menu/selectMenuTree/" + menuId;
  534. var options = {
  535. title: '菜单选择',
  536. width: "380",
  537. url: url,
  538. callBack: doMenuSubmit
  539. };
  540. $.modal.openOptions(options);
  541. }
  542. function doDictSubmit(index, layero){
  543. var body = $.modal.getChildFrame(index);
  544. var columnId = body.find('#columnId').val();
  545. var dictType = body.find('#dictType').val();
  546. $.modal.close(index);
  547. $("#columns_dict_" + columnId).val(dictType);
  548. }
  549. function doMenuSubmit(index, layero){
  550. var body = $.modal.getChildFrame(index);
  551. $("#parentMenuId").val(body.find('#treeId').val());
  552. $("#parentMenuName").val(body.find('#treeName').val());
  553. $.modal.close(index);
  554. }
  555. </script>
  556. </body>
  557. </html>
  558. <!-- java类型 -->
  559. <script id="javaTypeTpl" type="text/x-jquery-tmpl">
  560. <div>
  561. <select class='form-control' name='columns[${index}].javaType'>
  562. <option value="Long" {{if javaType==="Long"}}selected{{/if}}>Long</option>
  563. <option value="String" {{if javaType==="String"}}selected{{/if}}>String</option>
  564. <option value="Integer" {{if javaType==="Integer"}}selected{{/if}}>Integer</option>
  565. <option value="Double" {{if javaType==="Double"}}selected{{/if}}>Double</option>
  566. <option value="BigDecimal" {{if javaType==="BigDecimal"}}selected{{/if}}>BigDecimal</option>
  567. <option value="Date" {{if javaType==="Date"}}selected{{/if}}>Date</option>
  568. </select>
  569. </div>
  570. </script>
  571. <!-- 查询方式 -->
  572. <script id="queryTypeTpl" type="text/x-jquery-tmpl">
  573. <div>
  574. <select class='form-control' name='columns[${index}].queryType'>
  575. <option value="EQ" {{if queryType==="EQ"}}selected{{/if}}>=</option>
  576. <option value="NE" {{if queryType==="NE"}}selected{{/if}}>!=</option>
  577. <option value="GT" {{if queryType==="GT"}}selected{{/if}}>></option>
  578. <option value="GTE" {{if queryType==="GTE"}}selected{{/if}}>>=</option>
  579. <option value="LT" {{if queryType==="LT"}}selected{{/if}}><</option>
  580. <option value="LTE" {{if queryType==="LTE"}}selected{{/if}}><=</option>
  581. <option value="LIKE" {{if queryType==="LIKE"}}selected{{/if}}>Like</option>
  582. <option value="BETWEEN" {{if queryType==="BETWEEN"}}selected{{/if}}>Between</option>
  583. </select>
  584. </div>
  585. </script>
  586. <!-- 显示类型 -->
  587. <script id="htmlTypeTpl" type="text/x-jquery-tmpl">
  588. <div>
  589. <select class='form-control' name='columns[${index}].htmlType'>
  590. <option value="input" {{if htmlType==="input"}}selected{{/if}}>文本框</option>
  591. <option value="textarea" {{if htmlType==="textarea"}}selected{{/if}}>文本域</option>
  592. <option value="select" {{if htmlType==="select"}}selected{{/if}}>下拉框</option>
  593. <option value="radio" {{if htmlType==="radio"}}selected{{/if}}>单选框</option>
  594. <option value="checkbox" {{if htmlType==="checkbox"}}selected{{/if}}>复选框</option>
  595. <option value="summernote" {{if htmlType==="summernote"}}selected{{/if}}>富文本</option>
  596. <option value="datetime" {{if htmlType==="datetime"}}selected{{/if}}>日期控件</option>
  597. <option value="upload" {{if htmlType==="upload"}}selected{{/if}}>上传控件</option>
  598. </select>
  599. </div>
  600. </script>