You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

352 lines
14 KiB

  1. 
  2. @{
  3. ViewBag.Title = "Index";
  4. Layout = "~/Views/Shared/_Index.cshtml";
  5. }
  6. <link href="~/Content/js/select2/select2.min.css" rel="stylesheet" />
  7. <script src="~/Content/js/datepicker/WdatePicker.js"></script>
  8. <script src="~/Content/js/select2/select2.min.js"></script>
  9. <style>
  10. #Additem {
  11. margin-left: 45%;
  12. }
  13. #AddTemitem {
  14. margin-right: 45%;
  15. }
  16. </style>
  17. <script>
  18. var _Clos = new Array();
  19. var rfqcode = $.request("rfqcode");
  20. var ID = $.request("ID");
  21. $(function(){
  22. SetCols();
  23. if (ID=='') {
  24. $(".MOPick").css('display', 'none');
  25. }
  26. var Muser = '@NFine.Code.OperatorProvider.Provider.GetCurrent().UserCode'
  27. var now = new Date();
  28. var date = now.toLocaleDateString();
  29. $("#txtMUSER").val(Muser);
  30. $("#txtMTIME").val(date);
  31. InitControl();
  32. ClearTemp();
  33. reloadData();
  34. })
  35. function SetCols() {
  36. $.ajax({
  37. url: "/Print/SelectColumnName?" + Math.random(),
  38. dataType: "json",
  39. async: false,
  40. success: function (data) {
  41. var cols = new Array();
  42. var collast = { label: '主键', name: 'ID', width: 150, align: 'left', hidden: true, key: true };
  43. cols.push(collast);
  44. var collast = { label: 'ID', name: 'ID', width: 150, align: 'left', hidden: true };
  45. cols.push(collast);
  46. var collast = {
  47. label: '查看', width: 100, align: 'left',
  48. formatter: btnLook
  49. };
  50. cols.push(collast);
  51. var collast = { label: '料品编码', name: 'InvCode', width: 100, align: 'left' };
  52. cols.push(collast);
  53. var collast = { label: '料品名称', name: 'INVNAME', width: 100, align: 'left' };
  54. cols.push(collast);
  55. var collast = { label: '规格型号', name: 'InvStd', width: 100, align: 'left' };
  56. cols.push(collast);
  57. var collast = { label: '数量', name: 'Quantity', width: 100, align: 'left', editable: true, editrules: { number: true } };
  58. cols.push(collast);
  59. var collast = { label: '单位', name: 'InvUnit', width: 100, align: 'left' };
  60. cols.push(collast);
  61. var collast = { label: '已发数量', name: 'IssueNegQuantity', width: 100, align: 'left' };
  62. cols.push(collast);
  63. var collast = { label: '自由项ID', name: 'ExtensionID', hidden: true };
  64. cols.push(collast);
  65. if (data != null && data.length > 0) {
  66. DateList = data;
  67. for (var i = 0; i < data.length; i++) {
  68. var ColName = data[i].ColName;
  69. var ColCode = data[i].ColCode;
  70. var obj = new Array();
  71. obj = {
  72. label: ColName,
  73. name: ColCode,
  74. width: 80,
  75. align: "left",
  76. editable: true
  77. }
  78. cols.push(obj);
  79. }
  80. }
  81. _Clos = cols;
  82. }
  83. });
  84. }
  85. function reloadData() {
  86. $("#gridList").dataGrid({
  87. url: "/WMS/ICSMO/GetICSReturnTemporary?rfqno=" + $("#txtApplyNegCode").val() + "&" + Math.random(),
  88. //postData: { rfqno: $("#RFQNO").val() },
  89. height: $(window).height() - 200,
  90. width: $(window).width(),
  91. cellEdit: true,
  92. colModel: _Clos,
  93. // colModel: [
  94. //{ label: '主键', name: 'ID', width: 150, align: 'left', hidden: true, key: true },
  95. // { label: 'ID', name: 'ID', width: 150, align: 'left', hidden: true },
  96. // {
  97. // label: '查看', width: 100, align: 'left',
  98. // formatter: btnLook
  99. // },
  100. //{ label: '退料单号', name: 'ApplyNegCode', width: 150, align: 'left' },
  101. //{ label: '料品编码', name: 'InvCode', width: 100, align: 'left' },
  102. //{ label: '料品名称', name: 'InvName', width: 100, align: 'left' },
  103. //{ label: '规格型号', name: 'InvStd', width: 100, align: 'left' },
  104. //{ label: '数量', name: 'Quantity', width: 100, align: 'left', editable: true, editrules: { number: true } },
  105. //{ label: '辅计量数量', name: 'Amount', width: 150, align: 'left' },
  106. //{ label: '单位', name: 'InvUnit', width: 100, align: 'left' },
  107. //{ label: '已发数量', name: 'IssueNegQuantity', width: 100, align: 'left' },
  108. //{ label: '子件ID', name: 'ZJID', hidden: true },
  109. //{ label: '自由项ID', name: 'ExtensionID', width: 100, align: 'left' },
  110. // ],
  111. cellsubmit: "clientArray",
  112. width: "100%",
  113. autowidth: true,
  114. rownumbers: true,
  115. viewrecords: true,
  116. });
  117. }
  118. function btnLook(cellvalue, options, rowObject) {
  119. return cellvalue = "<a class=\"btn btn-primary dropdown-text\" onclick=\"UpLoadClick('" + rowObject.ID + "')\">查看</a>";
  120. }
  121. function UpLoadClick(ID) {
  122. $.modalOpen({
  123. id: "selectDeatil",
  124. title: "查看修改物料",
  125. url: "/WMS/ICSMO/SeachInventory?ID=" + ID + "&" + Math.random(),
  126. width: "1000px",
  127. height: "1000px",
  128. callBack: function (iframeId) {
  129. top.frames[iframeId].submitForm();
  130. top.frames[iframeId].Close();
  131. $("#gridList").jqGrid().setGridParam({ datatype: 'json' }, { postData: { rfqno: $("#RFQNO").val() } }).trigger('reloadGrid');
  132. }
  133. });
  134. }
  135. function guid() {
  136. return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
  137. var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
  138. return v.toString(16);
  139. });
  140. }
  141. //最后一行新增数据
  142. function AddRowToLast() {
  143. var obj = {
  144. ID: guid(),
  145. };
  146. $("#gridList").jqGrid('addRowData', obj.ID, obj, 'last');
  147. $(".unwritten").hide();
  148. }
  149. function DeleteRowToLast() {
  150. debugger;
  151. var rowid = $("#gridList").jqGridRowValue().ID
  152. $("#gridList").delRowData(rowid);
  153. }
  154. function InitControl() {
  155. var $VenCode = $("#sel_WHCode");
  156. $VenCode.select2({
  157. allowClear: true,
  158. escapeMarkup: function (m) {
  159. return m;
  160. }
  161. });
  162. $.ajax({
  163. url: "/WMS/ProductionIssue/GetWHCode" + "?" + Math.random(),
  164. dataType: "json",
  165. async: false,
  166. success: function (data) {
  167. $.each(data, function (index, item) {
  168. $VenCode.append("<option value='" + item.WarehouseCode + "'>&nbsp;" + item.WarehouseName + "</option>");
  169. });
  170. }
  171. });
  172. }
  173. function ClearTemp() {
  174. $.ajax({
  175. url: "/WMS/ProductionIssue/ClearTemp?" + Math.random(),
  176. datatype: "json",
  177. async: false
  178. })
  179. }
  180. function submitForm() {
  181. debugger;
  182. var WHCode = $("#sel_WHCode").val();
  183. var IDlist = "";
  184. var RoleEnCode = '@NFine.Code.OperatorProvider.Provider.GetCurrent().UserCode'
  185. var WorkPoint = '@NFine.Code.OperatorProvider.Provider.GetCurrent().Location'
  186. var myDate = new Date();
  187. var year = myDate.getFullYear(); //获取当前年
  188. var mon = myDate.getMonth() + 1 < 10 ? "0" + (myDate.getMonth() + 1) : myDate.getMonth() + 1; //获取当前月
  189. var dates = myDate.getDate() + 1 < 10 ? "0" + myDate.getDate() : myDate.getDate(); //获取当前日
  190. var hours = myDate.getHours() + 1 < 10 ? "0" + myDate.getHours() : myDate.getHours(); //获取当前小时
  191. var minutes = myDate.getMinutes() + 1 < 10 ? "0" + myDate.getMinutes() : myDate.getMinutes(); //获取当前分钟
  192. var seconds = myDate.getSeconds() + 1 < 10 ? "0" + myDate.getSeconds() : myDate.getSeconds(); //获取当前秒
  193. var date = year + "-" + mon + "-" + dates + ' ' + hours + ':' + minutes + ':' + seconds;
  194. var start = $("#txt_BeginDate").val() + ' ' + '00' + ':' + '00' + ':' + '00';
  195. var end = $("#txt_EndDate").val() + ' ' + '00' + ':' + '00' + ':' + '00';
  196. var ICSMODetail = [];
  197. var obj_vendor = $("#gridList");
  198. var rowIds_vendor = obj_vendor.getDataIDs();
  199. var arrayData_vendor = new Array();
  200. if (rowIds_vendor.length > 0) {
  201. for (var i = 0; i < rowIds_vendor.length; i++) {
  202. var vendorRowData = obj_vendor.getRowData(rowIds_vendor[i]);
  203. if (vendorRowData.Quantity == "" || vendorRowData.Quantity == 'undefined') {
  204. $.modalAlertNew("WMS00089");
  205. return;
  206. }
  207. var Quantity = Number(vendorRowData.Quantity);
  208. var IssueQuantity =Number(vendorRowData.IssueQuantity);
  209. if (Quantity > IssueQuantity) {
  210. $.modalAlertNew("WMS00090");
  211. return;
  212. }
  213. var obj = {
  214. Sequence: i + 1,
  215. InvCode: vendorRowData.InvCode,
  216. Quantity: vendorRowData.Quantity,
  217. User: RoleEnCode,
  218. MTIME: date,
  219. WorkPoint: WorkPoint,
  220. ProjectCode: vendorRowData.ProjectCode,
  221. BatchCode: vendorRowData.BatchCode,
  222. Version: vendorRowData.Version,
  223. Brand: vendorRowData.Brand,
  224. cFree1: vendorRowData.cFree1,
  225. cFree2: vendorRowData.cFree2,
  226. cFree3: vendorRowData.cFree3,
  227. cFree4: vendorRowData.cFree4,
  228. cFree5: vendorRowData.cFree5,
  229. cFree6: vendorRowData.cFree6,
  230. cFree7: vendorRowData.cFree7,
  231. cFree8: vendorRowData.cFree8,
  232. cFree9: vendorRowData.cFree9,
  233. cFree10: vendorRowData.cFree10,
  234. StartDate: start,
  235. EndDate: end,
  236. WHCODE: $("#sel_WHCode").val()
  237. };
  238. ICSMODetail.push(obj);
  239. }
  240. $.submitForm({
  241. url: "/WMS/ICSMO/SaveICSMOApplyNeg?" + Math.random(),
  242. param: { ICSASN: JSON.stringify(ICSMODetail) },
  243. success: function () {
  244. $.currentWindow().$("#gridList").trigger("reloadGrid");
  245. }
  246. })
  247. }
  248. }
  249. </script>
  250. <form id="form1">
  251. <div class="topPanel" style="height:10px">
  252. <div class="btn-group">
  253. @*<a id="AddItemLot" style="margin-left:3px;" class="btn btn-primary" onclick="btnCreate()"><i class="fa fa-pencil-square-o"></i>添加明细</a>
  254. <a id="refresh" class="btn btn-primary" style="margin-left:3px;" onclick="reloadData()"><span class="glyphicon glyphicon-refresh"></span></a>*@
  255. </div>
  256. </div>
  257. <div style="margin-right: 20px;">
  258. <table class="form">
  259. <thead>主表信息</thead>
  260. <tr>
  261. <th class="formTitle MOPick">退料单号:</th>
  262. <td class="formValue MOPick">
  263. <input type="text" id="txtApplyNegCode" class="form-control" />
  264. </td>
  265. <th class="formTitle">仓库编码:</th>
  266. <td class="formValue">
  267. <select id="sel_WHCode" name="sel_WHCode" class="form-control select2" style="width: 230px" placeholder="请选择供应商编码..."></select>
  268. <input type="hidden" id="hidetext" />
  269. </td>
  270. </tr>
  271. <tr>
  272. <th class="formTitle">开始时间:</th>
  273. <td class="formValue">
  274. <input type="text" name="txt_BeginDate" id="txt_BeginDate" class="form-control" style="" maxlength="10" onclick="WdatePicker({ dateFmt: 'yyyy-MM-dd', minDate: txtMTIME.value })" placeholder="开始日期" />
  275. </td>
  276. <th class="formTitle">结束时间:</th>
  277. <td class="formValue">
  278. <input type="text" name="txt_EndDate" id="txt_EndDate" class="form-control" style="" maxlength="10" onclick="WdatePicker({ dateFmt: 'yyyy-MM-dd', minDate: txt_BeginDate.value })" placeholder="结束日期" />
  279. </td>
  280. </tr>
  281. <tr>
  282. <th class="formTitle">维护人:</th>
  283. <td class="formValue">
  284. <input id="txtMUSER" type="text" readonly="readonly" class="form-control" />
  285. </td>
  286. <th class="formTitle">维护时间:</th>
  287. <td class="formValue">
  288. <input id="txtMTIME" type="text" readonly="readonly" class="form-control" />
  289. </td>
  290. </tr>
  291. </table>
  292. </div>
  293. <div class="gridPanel" style="margin-left:10px">
  294. <span><strong>子表信息</strong></span>
  295. <table id="gridList"></table>
  296. <div style="text-align:center">
  297. <button id="AddRow" class="btn btn-primary" type="button" onclick="AddRowToLast()">添加</button>
  298. <button id="DeleteRow" type="button" class="btn btn-primary" onclick="DeleteRowToLast()">删除</button>
  299. </div>
  300. </div>
  301. </form>