OrderItemDetail.cshtml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421
  1. @using Abp.Authorization
  2. @using ShwasherSys.Authorization.Permissions
  3. @using ShwasherSys.Models.Layout
  4. @using ShwasherSys.Models.Modal
  5. @model ShwasherSys.Order.Dto.OrderHeaderDto
  6. @{
  7. /**/
  8. ViewBag.ActiveMenu = PermissionNames.PagesOrderInfoOrderMg; //The menu item will be active for this page.
  9. ViewBag.Title = "订单信息详情";
  10. List<SelectListItem> MaterialSelect = ViewBag.MaterialSelect;
  11. List<SelectListItem> SurfaceColorSelect = ViewBag.SurfaceColorSelect;
  12. List<SelectListItem> RigiditySelect = ViewBag.RigiditySelect;
  13. string materialSelectOptions = "<option value=\"\" selected=\"selected\" ></option>\r\n";
  14. foreach (var mItem in MaterialSelect)
  15. {
  16. materialSelectOptions += string.Format("<option value=\"{0}\" >{1}</option>\r\n",mItem.Value,mItem.Text);
  17. }
  18. string surfaceColorSelectOptions = "<option value=\"\" selected=\"selected\"></option>\r\n";
  19. foreach (var mItem in SurfaceColorSelect)
  20. {
  21. surfaceColorSelectOptions += string.Format("<option value=\"{0}\" >{1}</option>\r\n", mItem.Value, mItem.Text);
  22. }
  23. string rigiditySelectOptions = "<option value=\"\" selected=\"selected\" ></option>\r\n";
  24. foreach (var mItem in RigiditySelect)
  25. {
  26. rigiditySelectOptions += string.Format("<option value=\"{0}\" >{1}</option>\r\n", mItem.Value, mItem.Text);
  27. }
  28. }
  29. @section css{
  30. <link href="~/Content/Plugins/bootstrap-datetimepicker/css/bootstrap-datetimepicker.min.css" rel="stylesheet" />
  31. <style>
  32. .queryFormLabel{
  33. padding-top: 2px;
  34. }
  35. .queryFormInput {
  36. height: 20px;
  37. }
  38. .invoice {
  39. margin: 10px 5px 0px;
  40. }
  41. .store-query > strong {
  42. width: 70px;
  43. text-align: right;
  44. }
  45. #storeQuantity, #orderQuantity {
  46. padding: 0 5px;
  47. color: red;
  48. }
  49. </style>
  50. }
  51. <section class="invoice">
  52. <!-- title row -->
  53. <div class="row">
  54. <div class="col-xs-12">
  55. <h2 class="page-header">
  56. <i class="fa fa-globe"></i> 订单信息
  57. </h2>
  58. </div>
  59. <!-- /.col -->
  60. </div>
  61. <!-- info row -->
  62. <div class="row invoice-info">
  63. <div class="col-sm-3 invoice-col">
  64. <b>流水号:</b>@Model.Id<br>
  65. <b>客户订单号:</b> @Model.StockNo<br>
  66. <b>订单状态:</b>@Model.OrderStatusName<br>
  67. </div>
  68. <!-- /.col -->
  69. <div class="col-sm-3 invoice-col">
  70. <b>客户编号:</b>@Model.CustomerId<br>
  71. <b>送货地址名称:</b>@Model.CustomerSendName<br>
  72. </div>
  73. <!-- /.col -->
  74. <div class="col-sm-3 invoice-col">
  75. <b>联系人:</b>@Model.LinkName<br>
  76. <b>电话:</b> @Model.Telephone<br>
  77. <b>传真:</b> @Model.Fax<br>
  78. </div>
  79. <!-- /.col -->
  80. <div class="col-sm-3 invoice-col">
  81. <b>订单日期</b>@Model.OrderDate<br>
  82. <b>送货地址:</b>@Model.SendAdress<br>
  83. </div>
  84. </div>
  85. <!-- /.row -->
  86. </section>
  87. <div class="table-box mr-4 iwb-bootstrap-table">
  88. <div class="btn-toolbar row" id="tableTool" role="toolbar" aria-label="Toolbar with button groups">
  89. <div class="col-sm-12 col-lg-12 pull-left" style="padding: 0">
  90. <div class="btn-group btn-group-sm" id="Tool1" role="group" aria-label="First group">
  91. @if (PermissionChecker.IsGranted(PermissionNames.PagesOrderInfoOrderMgCreateOrderItem))
  92. {
  93. <button type="button" class="btn btn-default" data-type="_btnCreate" data-url="/api/services/app/OrderItems/Create">
  94. <i class="iconfont icon-add">添加订单明细</i>
  95. </button>
  96. }
  97. @if (PermissionChecker.IsGranted(PermissionNames.PagesOrderInfoOrderMgUpdateOrderItem))
  98. {
  99. <button type="button" class="btn btn-default" data-type="btnUpdate" data-url="/api/services/app/OrderItems/Update">
  100. <i class="iconfont icon-edit">修改订单明细</i>
  101. </button>
  102. }
  103. @if (PermissionChecker.IsGranted(PermissionNames.PagesOrderInfoOrderMgDeleteOrderItem))
  104. {
  105. <button type="button" class="btn btn-default" data-type="btnDelete" data-url="/api/services/app/OrderItems/Delete">
  106. <i class="iconfont icon-delete">删除订单明细</i>
  107. </button>
  108. }
  109. </div>
  110. </div>
  111. </div>
  112. <table id="table"
  113. data-url="/api/services/app/OrderItems/GetAll"
  114. data-striped="true" data-id-field="id" data-unique-id="id"
  115. data-method="post"
  116. data-side-pagination="server"
  117. data-content-type="application/x-www-form-urlencoded; charset=UTF-8"
  118. data-cache="false"
  119. data-pagination="true" data-page-size="30" data-page-number="1" data-page-list="[30,50,100,200]" data-pagination-detail-h-align="right" data-pagination-h-align="left"
  120. data-query-params="QueryParams"
  121. data-response-handler="ResponseHandler"
  122. data-click-to-select="true"
  123. data-single-select="true">
  124. <thead>
  125. <tr class="row" id="header">
  126. <th data-field="state" data-checkbox="true"></th>
  127. <th data-align="center" data-field="orderNo">流水号</th>
  128. <th data-align="center" data-field="productNo">产品编号</th>
  129. <th data-align="center" data-field="quantity">数量</th>
  130. <th data-align="center" data-field="price">单价</th>
  131. <th data-align="center" data-field="sendDate">送货时间</th>
  132. </tr>
  133. </thead>
  134. </table>
  135. </div>
  136. @section modal{
  137. <section>
  138. <!--Main Modal-->
  139. <div class="modal fade" id="modal" role="dialog" tabindex="-1" aria-labelledby="ModalLabel" aria-hidden="true">
  140. <div class="modal-dialog modal-dialog-centered" role="document" >
  141. <div class="modal-content" style="width: 480px;">
  142. @Html.Partial("Modals/_ModalHeader", new ModalHeaderViewModel("订单明细"))
  143. <div class="modal-body container-fluid" style="padding: 0; padding-top: 15px;">
  144. <form class="pr-3 pl-3 form-horizontal" style="padding: 0 10px" id="form">
  145. <input type="hidden" id="id" name="id"/>
  146. <input type="hidden" id="orderNo" name="orderNo"/>
  147. <input type="hidden" id="currencyId" name="currencyId"/>
  148. <input type="hidden" id="orderUnitId" name="orderUnitId"/>
  149. <div class="form-group-sm row">
  150. <label class="iwb-label col-md-2 control-label iwb-label-required" for="productNo">产品编号</label>
  151. <div class="col-md-6">
  152. <div class="input-group">
  153. <select class="form-control" Required id="productNo" name="productNo" placeholder="请输入..." value="" style="width: 100%;" type="text" onchange="RefreshProductInfo()">
  154. @Html.Raw(ViewBag.CustomerDefaultProducts)
  155. </select>
  156. <div class="input-group-addon" onclick="ShowModal('query_Product_modal');">
  157. <i class="iconfont icon-search"></i>
  158. </div>
  159. </div></div>
  160. @*<div class="col-md-1" style="padding: 0 0">
  161. <button type="button" class="btn btn-info btn-flat" style="height: 30px; width: 40px;" onclick="showSelectProductDialog()"><i class="iconfont icon-search"></i></button>
  162. </div>*@
  163. <div class="col-md-4" style="padding: 0 5px;margin-top: -6px;">
  164. <span class="store-query"> <strong>库存量:</strong><span id="storeQuantity">0</span><span>千件</span></span>
  165. <br>
  166. <span class="store-query"><strong>被定量:</strong><span id="orderQuantity">0</span><span>千件</span></span>
  167. <br>
  168. </div>
  169. </div>
  170. <div class="form-group-sm row">
  171. <label class="iwb-label col-md-2 control-label iwb-label-required" for="SendDate">送货时间</label>
  172. <div class="col-md-4">
  173. <input class="form-control" Required id="sendDate" name="sendDate" placeholder="请输入..." value="" style="" type="text">
  174. </div>
  175. <label class="iwb-label col-md-2 control-label" for="IsStandard">标准件</label>
  176. <div class="col-md-4">
  177. <input class="form-control required" style="width: 100%" id="IsStandard" disabled="disabled" name="IsStandard" placeholder="请输入..." value="" type="text">
  178. </div>
  179. </div>
  180. <div class="form-group-sm row">
  181. <label class="iwb-label col-md-2 control-label iwb-label-required" for="price">价格</label>
  182. <div class="col-md-4">
  183. <input class="form-control required number" Required style="width: 100%" id="price" name="price" placeholder="请输入..." value="" type="text">
  184. </div>
  185. <label class="iwb-label col-md-2 control-label iwb-label-required" for="quantity">数量</label>
  186. <div class="col-md-4">
  187. <input class="form-control required number" Required style="width: 100%" id="quantity" name="quantity" placeholder="请输入..." value="" type="text">
  188. </div>
  189. </div>
  190. <div class="form-group-sm row">
  191. <label class="iwb-label col-md-2 control-label" for="isReport">检验报告</label>
  192. <div class="col-md-4">
  193. <select class="form-control" style="width: 100%" id="isReport" name="isReport" placeholder="请输入..." value="" style="" type="text">
  194. <option value="Y" selected="selected">是</option>
  195. <option value="N">否</option>
  196. </select>
  197. </div>
  198. <label class="iwb-label col-md-2 control-label" for="isPartSend">部分送货</label>
  199. <div class="col-md-4">
  200. <select class="form-control" style="width: 100%" id="isPartSend" name="isPartSend" placeholder="请输入..." value="" style="" type="text">
  201. <option value="Y" selected="selected">是</option>
  202. <option value="N">否</option>
  203. </select>
  204. </div>
  205. </div>
  206. <div class="form-group-sm row">
  207. <label class="iwb-label col-md-2 control-label" for="Material">材质</label>
  208. <div class="col-md-4">
  209. <input class="form-control" id="Material" name="Material" placeholder="请输入..." value="" style="" type="text">
  210. </div>
  211. <label class="iwb-label col-md-2 control-label" for="Model">规格</label>
  212. <div class="col-md-4">
  213. <input class="form-control" id="Model" name="Model" placeholder="请输入..." value="" style="" type="text">
  214. </div>
  215. </div>
  216. <div class="form-group-sm row">
  217. <label class="iwb-label col-md-2 control-label" for="SurfaceColor">表色</label>
  218. <div class="col-md-4">
  219. <input class="form-control" id="SurfaceColor" name="surfaceColor" placeholder="请输入..." value="" style="" type="text">
  220. </div>
  221. <label class="iwb-label col-md-2 control-label" for="Rigidity">硬度</label>
  222. <div class="col-md-4">
  223. <input class="form-control" id="Rigidity" name="Rigidity" placeholder="请输入..." value="" style="" type="text">
  224. </div>
  225. </div>
  226. <div class="form-group-sm row">
  227. <label class="iwb-label col-md-2 control-label" for="ProductName">产品名称</label>
  228. <div class="col-md-4">
  229. <input class="form-control" id="ProductName" name="ProductName" placeholder="请输入..." value="" style="" type="text">
  230. </div>
  231. <label class="iwb-label col-md-2 control-label" for="partNo">零件号</label>
  232. <div class="col-md-4">
  233. <input class="form-control" id="partNo" name="partNo" placeholder="请输入..." value="" style="" type="text">
  234. </div>
  235. </div>
  236. <div class="form-group-sm row">
  237. <label class="iwb-label col-md-2 control-label" for="wareHouse">送货仓库</label>
  238. <div class="col-md-10">
  239. <input class="form-control" id="wareHouse" name="wareHouse" placeholder="请输入..." value="" style="" type="text">
  240. </div>
  241. </div>
  242. <div class="form-group-sm row">
  243. <label class="iwb-label col-md-2 control-label" for="orderItemDesc">描述</label>
  244. <div class="col-md-10">
  245. <textarea class="form-control" id="orderItemDesc" name="orderItemDesc" placeholder="请输入..." value="" style="" ></textarea>
  246. </div>
  247. </div>
  248. </form>
  249. </div>
  250. @Html.Partial("Modals/_ModalFooter", "0")
  251. </div>
  252. </div>
  253. </div>
  254. @Html.Partial("Modals/Query/_Product","productNo")
  255. </section>
  256. }
  257. @section scripts
  258. {
  259. <script src="~/Content/Plugins/bootstrap-datetimepicker/js/bootstrap-datetimepicker.min.js"></script>
  260. <script src="~/Content/Plugins/bootstrap-datetimepicker/js/locales/bootstrap-datetimepicker.zh-CN.js"></script>
  261. <script type="text/javascript">
  262. var datePickerOpt = {
  263. language: 'zh-CN',
  264. format: "yyyy-mm-dd",
  265. todayBtn: true,
  266. autoclose: true,
  267. startView: 2,
  268. minView: 2,
  269. maxView: 4
  270. //showSecond: true,
  271. //showHours: true,
  272. //minuteStep: 10
  273. };
  274. $(function() {
  275. //show完毕前执行
  276. $("#sendDate").datetimepicker(datePickerOpt).on('show',
  277. function(event) {
  278. event.preventDefault();
  279. event.stopPropagation();
  280. }).on('hide',
  281. function(event) {
  282. event.preventDefault();
  283. event.stopPropagation();
  284. });
  285. LoadTable();
  286. var funs = window.funs || { none: function() { console.log("No type"); } };
  287. funs["btnUpdate"] = function() {
  288. BtnUpdate({
  289. readonly: "IsStandard,ProductName,SurfaceColor,Rigidity,Material,Model"
  290. });
  291. $("#productNo").trigger("change");
  292. };
  293. // LoadTableQueryProduct();
  294. funs["btnCreate"] = function() {
  295. var firstProductNo = $("#productNo").find("option").first().attr("value");
  296. console.log('firstProductNo' + firstProductNo);
  297. BtnCreate({
  298. readonly: "IsStandard,ProductName,SurfaceColor,Rigidity,Material,Model",
  299. data: { orderNo: "@Model.Id", productNo: firstProductNo, orderUnitId: "4", currencyId: "CNY" }
  300. });
  301. $("#isReport").val("Y").select2();
  302. $("#isPartSend").val("Y").select2();
  303. }
  304. });
  305. function GetSearchList() {
  306. _searchList = [];
  307. _searchList.push({ KeyWords: "@Model.Id", KeyField: "orderNo", FieldType: "0", ExpType: "0" });
  308. var count = $("#SearchForm").find(".KeyWords").length;
  309. for (var i = 1; i <= count; i++) {
  310. var keyWords = $("#KeyWords-" + i).val();
  311. if (keyWords) {
  312. var keyField = $("#KeyField-" + i).val();
  313. var fieldType = $("#FieldType-" + i).val();
  314. var expType = $("#ExpType-" + i).val();
  315. _searchList.push({ KeyWords: keyWords, KeyField: keyField, FieldType: fieldType, ExpType: expType });
  316. }
  317. }
  318. }
  319. function Submit_query_Product_modal(row) {
  320. row = row || $("#query_Product_modal").find("table").bootstrapTable("getSelections")[0];
  321. if (row) {
  322. var productNo = row.id;
  323. //RefreshProductInfo(productNo);
  324. $("#productNo").append('<option value=\"' + productNo + '\">' + productNo + '</option>');
  325. $("#productNo").val(productNo);
  326. $("#productNo").trigger("change");
  327. $("#query_Product_modal").modal("hide");
  328. } else {
  329. abp.message.warn(abp.localization.localize("ChooseOneToOp"));
  330. }
  331. }
  332. function RefreshProductInfo() {
  333. var productNo = $("#productNo").val();
  334. if (!productNo) {
  335. return;
  336. }
  337. abp.ajax({
  338. url: window.appUrl + 'Query/GetProductById',
  339. data: { Id: productNo },
  340. async: true,
  341. type: "Post",
  342. contentType: 'application/x-www-form-urlencoded; charset=UTF-8',
  343. isValidate: false,
  344. dataType: "json",
  345. success: function(res) {
  346. if (res) {
  347. $("#ProductName").val(res.productName);
  348. $("#Model").val(res.model);
  349. $("#Material").val(res.material);
  350. $("#SurfaceColor").val(res.surfaceColor);
  351. $("#Rigidity").val(res.rigidity);
  352. $("#IsStandard").val(res.isStandard === "Y" ? "是" : "否");
  353. }
  354. }
  355. });
  356. RefreshCurrentStore();
  357. }
  358. function RefreshCurrentStore() {
  359. var productNo = $("#productNo").val();
  360. if (!productNo) {
  361. return;
  362. }
  363. SaveAjax({
  364. url: window.appUrl + "OrderItems/QueryCurrentProductNum",
  365. data: { Id: productNo },
  366. isAlert: false,
  367. isValidate: false,
  368. success: function(res) {
  369. if (res) {
  370. $("#storeQuantity").text(res.canUserQuantity ? Number(res.canUserQuantity ): 0);
  371. $("#orderQuantity").text(res.bookedQuantity ? Number(res.bookedQuantity) : 0);
  372. }
  373. }
  374. });
  375. }
  376. </script>
  377. }