Smsgw.cshtml 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494
  1. 
  2. @{
  3. ViewBag.Title = "Services";
  4. Layout = "~/Views/Shared/_Layout.cshtml";
  5. }
  6. @using ReportWeb.Models;
  7. @using SuperAdmin.Controllers;
  8. @model List<WebserviceObj>
  9. @functions {
  10. void StatusToText(int status)
  11. {
  12. if (status == 0)
  13. {
  14. <span>Inactive</span>
  15. }
  16. else if (status == 1)
  17. {
  18. <span>Active</span>
  19. }
  20. }
  21. }
  22. <style>
  23. </style>
  24. <div class="app-content content">
  25. <div class="content-wrapper">
  26. <div class="content-header row">
  27. <div class="content-header-left col-md-6 col-xs-12 mb-1">
  28. <h2 class="content-header-title">Smsgw Config</h2>
  29. </div>
  30. <div class="content-header-right breadcrumbs-right breadcrumbs-top col-md-6 col-xs-12">
  31. <div class="breadcrumb-wrapper col-xs-12">
  32. <ol class="breadcrumb">
  33. <li class="breadcrumb-item">
  34. <a href="Index">Admin</a>
  35. </li>
  36. <li class="breadcrumb-item">
  37. <a href="#">Smsgw</a>
  38. </li>
  39. </ol>
  40. </div>
  41. </div>
  42. </div>
  43. <div class="content-body">
  44. <!-- Basic form layout section start -->
  45. <section id="basic-form-layouts">
  46. <div class="row service-height">
  47. <div class="col-md-12">
  48. <div class="card">
  49. <div class="card-header">
  50. <h4 class="card-title" id="basic-layout-form">Search</h4>
  51. <a class="heading-elements-toggle"><i class="icon-ellipsis font-medium-3"></i></a>
  52. <div class="heading-elements">
  53. <ul class="list-inline mb-0">
  54. <li><a data-action="collapse"><i class="icon-minus4"></i></a></li>
  55. @*<li><a data-action="reload"><i class="icon-reload"></i></a></li>*@
  56. <li><a data-action="expand"><i class="icon-expand2"></i></a></li>
  57. @*<li><a data-action="close"><i class="icon-cross2"></i></a></li>*@
  58. </ul>
  59. </div>
  60. </div>
  61. <div class="card-content collapse show">
  62. <div class="card-body">
  63. <div class="card-block">
  64. <div class="form-body">
  65. @Html.AntiForgeryToken()
  66. @*<div class="row">
  67. <div class="col-md-4">
  68. <div class="form-group">
  69. <label for="teamName">Team</label>
  70. <input class="form-control" type="text" id="teamName" name="teamName">
  71. </div>
  72. </div>
  73. </div>*@
  74. <div class="row">
  75. <div class="col-md-12">
  76. <button type="button" class="btn btn-primary" onclick="searchSmsgw()" id="btnSearch">
  77. <i class="icon-search"></i> Search
  78. </button>
  79. <button type="button" class="btn btn-success" onclick="addSmsgw()">
  80. <i class="icon-plus-circle"></i> Add
  81. </button>
  82. @*<button type="button" class="btn btn-danger" onclick="deleteTable('exercise')">
  83. <i class="icon-bin"></i> Delete Data
  84. </button>*@
  85. </div>
  86. </div>
  87. </div>
  88. </div>
  89. </div>
  90. </div>
  91. </div>
  92. </div>
  93. <div class="col-12">
  94. <div class="card">
  95. <div class="card-content">
  96. <div class="col-md-12 table-responsive">
  97. <table class="table table-striped table-hover">
  98. <thead class="thead-inverse">
  99. <tr>
  100. <th scope="col">#</th>
  101. <th scope="col" class="text-center">Action</th>
  102. <th scope="col" class="text-center">Ws Name</th>
  103. <th scope="col" class="text-center">Ws Code</th>
  104. <th scope="col" class="text-center">Wsdl</th>
  105. <th scope="col" class="text-center">Message Template</th>
  106. <th scope="col" class="text-center">Status</th>
  107. </tr>
  108. </thead>
  109. <tbody id="gridbody">
  110. @if (Model != null)
  111. {
  112. for (int i = 0; i < Model.Count; i++)
  113. {
  114. WebserviceObj ws = Model[@i];
  115. <tr>
  116. <td scope="row">@(i + 1)</td>
  117. <td class="text-center">
  118. <span class="fa fa-edit cursor-pointer" onclick="editSmsgw('@ws.ws_id')"></span>
  119. @if (ws.status == 1)
  120. {
  121. <span class="fa fa-remove text-danger cursor-pointer" onclick="removeSmsgw('@ws.ws_id')"></span>
  122. }
  123. else
  124. {
  125. <span class="fa fa-undo text-primary cursor-pointer" onclick="enableSmsgw('@ws.ws_id')"></span>
  126. }
  127. </td>
  128. <td class="text-left">@ws.ws_name</td>
  129. <td class="text-left">@ws.ws_code</td>
  130. <td class="text-left">@ws.wsdl</td>
  131. <td class="text-center">@ws.msg_template</td>
  132. <td class="text-center">@{StatusToText(ws.status);}</td>
  133. </tr>
  134. }
  135. }
  136. </tbody>
  137. </table>
  138. </div>
  139. </div>
  140. </div>
  141. </div>
  142. </div>
  143. </section>
  144. <!-- // Basic form layout section end -->
  145. </div>
  146. <div class="modal fade text-xs-left" id="modal-add-service" tabindex="-1" role="dialog" aria-labelledby="myModalLabel17" style="display: none;" aria-hidden="true">
  147. <div class="modal-dialog modal-lg" role="document">
  148. <div class="modal-content">
  149. <div class="modal-header">
  150. <h4 class="modal-title" id="modalLabelService">New Smsgw</h4>
  151. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  152. <span aria-hidden="true">×</span>
  153. </button>
  154. </div>
  155. <input type="hidden" id="id" />
  156. <div class="modal-body">
  157. <div class="row">
  158. <div class="col-md-6">
  159. <div class="form-group">
  160. <label for="wsName">Name</label>
  161. <input class="form-control" type="text" id="wsName" name="wsName" autocomplete="on">
  162. </div>
  163. </div>
  164. <div class="col-md-6">
  165. <div class="form-group">
  166. <label for="team1">Code</label>
  167. <input class="form-control" type="text" id="wsCode" name="wsCode" autocomplete="on">
  168. </div>
  169. </div>
  170. <div class="col-md-6">
  171. <div class="form-group">
  172. <label for="wsdl">WSDL</label>
  173. <input class="form-control" type="text" id="wsdl" name="wsdl" autocomplete="on">
  174. </div>
  175. </div>
  176. <div class="col-md-12">
  177. <div class="form-group">
  178. <label for="msgTemplate">Message Template</label>
  179. <textarea class="form-control" id="msgTemplate" name="msgTemplate" autocomplete="off" rows="15"></textarea>
  180. </div>
  181. </div>
  182. </div>
  183. </div>
  184. <div class="modal-footer">
  185. <button type="button" class="btn grey btn-outline-secondary" data-dismiss="modal">Close</button>
  186. <button type="button" id="btnAddService" class="btn btn-outline-primary" onclick="addNewSmsgw()">Add</button>
  187. <button type="button" id="btnUpdateInfo" class="btn btn-outline-primary" onclick="saveChangeSmsgw()">Save Info</button>
  188. </div>
  189. </div>
  190. </div>
  191. </div>
  192. </div>
  193. </div>
  194. @section Scripts {
  195. <script>
  196. $(document).ready(function () {
  197. searchSmsgw();
  198. });
  199. // Smsgw
  200. function searchSmsgw() {
  201. console.log("Search");
  202. startSpinner('btnSearch');
  203. $.ajax({
  204. url: subDomain + "/Admin/SearchSmsgw",
  205. data: {
  206. },
  207. type: "POST",
  208. success: function (data) {
  209. stopSpinner('btnSearch');
  210. console.log(data);
  211. if (data.error != "0") {
  212. setTimeout(function () {
  213. showModal('message-dialog');
  214. $('#message-content').html(data.content.split("\n").join("<br />"));
  215. }, 1000);
  216. } else {
  217. updateGridData(data.listSmsgw);
  218. }
  219. },
  220. error: function (data) {
  221. stopSpinner('btnSearch');
  222. console.log(data.error);
  223. }
  224. })
  225. }
  226. function addNewSmsgw() {
  227. // Checking whether FormData is available in browser
  228. if (window.FormData !== undefined) {
  229. // Create FormData object
  230. var formData = new FormData();
  231. // Adding one more key to FormData object
  232. formData.append('wsName', $("#wsName").val());
  233. formData.append('wsCode', $("#wsCode").val());
  234. formData.append('wsdl', $("#wsdl").val());
  235. var msgTemplate = $("#msgTemplate").val();
  236. var blob = new Blob([msgTemplate], { type: "text/xml" });
  237. formData.append("msgTemplate", blob);
  238. $.ajax({
  239. url: subDomain + '/Admin/AddSmsgw',
  240. type: "POST",
  241. contentType: false, // Not to set any content header
  242. processData: false, // Not to process data
  243. data: formData,
  244. success: function (result) {
  245. if (result.error == '0') {
  246. swal("Success!", "Add SMSGW success!", "success").
  247. then((result) => {
  248. hideModal("modal-add-service");
  249. searchSmsgw();
  250. });
  251. //alert('Import success: ' + result.content);
  252. } else {
  253. swal("Add SMSGW failed!", result.content, "error");
  254. //alert('Import failed: ' + result.content);
  255. }
  256. },
  257. error: function (err) {
  258. swal("Add SMSGW failed!", err.statusText, "error");
  259. //alert(err.statusText);
  260. }
  261. });
  262. } else {
  263. swal("Failed!", "FormData is not supported.", "error");
  264. //alert("FormData is not supported.");
  265. }
  266. }
  267. function saveChangeSmsgw() {
  268. // Checking whether FormData is available in browser
  269. if (window.FormData !== undefined) {
  270. var formData = new FormData();
  271. // Adding one more key to FormData object
  272. formData.append('id', $("#id").val());
  273. formData.append('wsName', $("#wsName").val());
  274. formData.append('wsCode', $("#wsCode").val());
  275. formData.append('wsdl', $("#wsdl").val());
  276. var msgTemplate = $("#msgTemplate").val();
  277. var blob = new Blob([msgTemplate], { type: "text/xml" });
  278. formData.append("msgTemplate", blob);
  279. $.ajax({
  280. url: subDomain + '/Admin/UpdateSmsgw',
  281. type: "POST",
  282. contentType: false, // Not to set any content header
  283. processData: false, // Not to process data
  284. data: formData,
  285. success: function (result) {
  286. if (result.error == '0') {
  287. swal("Success!", "Update SMSGW success!", "success").
  288. then((result) => {
  289. hideModal("modal-add-service");
  290. searchSmsgw();
  291. });
  292. } else {
  293. swal("Update SMSGW failed!", result.content, "error");
  294. }
  295. },
  296. error: function (err) {
  297. swal("Update SMSGW failed!", err.statusText, "error");
  298. }
  299. });
  300. } else {
  301. swal("Failed!", "FormData is not supported.", "error");
  302. //alert("FormData is not supported.");
  303. }
  304. }
  305. function saveSmsgwStatus(status) {
  306. // Checking whether FormData is available in browser
  307. if (window.FormData !== undefined) {
  308. var formData = new FormData();
  309. // Adding one more key to FormData object
  310. formData.append('status', status);
  311. formData.append('id', $("#id").val());
  312. $.ajax({
  313. url: subDomain + '/Admin/UpdateSmsgwStatus',
  314. type: "POST",
  315. contentType: false, // Not to set any content header
  316. processData: false, // Not to process data
  317. data: formData,
  318. success: function (result) {
  319. if (result.error == '0') {
  320. swal("Success!", "Update SMSGW success!", "success").
  321. then((result) => {
  322. hideModal("modal-add-service");
  323. searchSmsgw();
  324. });
  325. } else {
  326. swal("Update SMSGW failed!", result.content, "error");
  327. }
  328. },
  329. error: function (err) {
  330. swal("Update SMSGW failed!", err.statusText, "error");
  331. }
  332. });
  333. } else {
  334. swal("Failed!", "FormData is not supported.", "error");
  335. //alert("FormData is not supported.");
  336. }
  337. }
  338. function addSmsgw() {
  339. // clear data
  340. $("#wsCode").val("sendmt");
  341. $("#wsName").val("sendmt");
  342. $("#msgTemplate").val("0");
  343. $("#btnAddService").show();
  344. $("#btnUpdateInfo").hide();
  345. // show modal
  346. showModal("modal-add-service");
  347. }
  348. function editSmsgw(id) {
  349. console.log(id);
  350. // get service info
  351. $.ajax({
  352. url: subDomain + "/Admin/GetSmsgwById",
  353. data: {
  354. id: id
  355. },
  356. type: "POST",
  357. success: function (data) {
  358. console.log(data);
  359. if (data.error != "0") {
  360. setTimeout(function () {
  361. showModal('message-dialog');
  362. $('#message-content').html(data.content.split("\n").join("<br />"));
  363. }, 1000);
  364. } else {
  365. var service = data.smsgw;
  366. // change data
  367. $("#wsCode").val(service.ws_code);
  368. $("#id").val(service.ws_id);
  369. $("#wsName").val(service.ws_name);
  370. $("#wsdl").val(service.wsdl);
  371. $("#msgTemplate").val(service.msg_template);
  372. $("#btnAddService").hide();
  373. $("#btnUpdateInfo").show();
  374. // show modal
  375. showModal("modal-add-service");
  376. }
  377. },
  378. error: function (data) {
  379. console.log(data.error);
  380. }
  381. })
  382. }
  383. function removeSmsgw(id) {
  384. console.log(id);
  385. // get service info
  386. $.ajax({
  387. url: subDomain + "/Admin/UpdateSmsgwStatus",
  388. data: {
  389. id: id,
  390. status: "0"
  391. },
  392. type: "POST",
  393. success: function (data) {
  394. console.log(data);
  395. if (data.error != "0") {
  396. setTimeout(function () {
  397. showModal('message-dialog');
  398. $('#message-content').html(data.content.split("\n").join("<br />"));
  399. }, 1000);
  400. } else {
  401. searchSmsgw();
  402. }
  403. },
  404. error: function (data) {
  405. console.log(data.error);
  406. }
  407. })
  408. }
  409. function enableSmsgw(id) {
  410. console.log(id);
  411. // get service info
  412. $.ajax({
  413. url: subDomain + "/Admin/UpdateSmsgwStatus",
  414. data: {
  415. id: id,
  416. status: "1"
  417. },
  418. type: "POST",
  419. success: function (data) {
  420. console.log(data);
  421. if (data.error != "0") {
  422. setTimeout(function () {
  423. showModal('message-dialog');
  424. $('#message-content').html(data.content.split("\n").join("<br />"));
  425. }, 1000);
  426. } else {
  427. searchSmsgw();
  428. }
  429. },
  430. error: function (data) {
  431. console.log(data.error);
  432. }
  433. })
  434. }
  435. function updateGridData(val) {
  436. console.log(val);
  437. $("#gridbody").html("");
  438. var html = "";
  439. if (val != undefined) {
  440. for (var i = 0; i < val.length; i++) {
  441. var service = val[i];
  442. html += "<tr>";
  443. html += "<td scope='row'>" + (i + 1) + "</td>";
  444. html += "<td class='text-center'><span class='fa fa-edit cursor-pointer' onclick='editSmsgw(\"" + service.ws_id + "\")'></span> "
  445. + (service.status == 1 ? "<span class='fa fa-remove text-danger cursor-pointer' onclick='removeSmsgw(\"" + service.ws_id + "\")'></span></td >"
  446. : "<span class='fa fa-undo text-primary cursor-pointer' onclick='enableSmsgw(\"" + service.ws_id + "\")'></span></td >");
  447. html += "<td class='text-left'>" + service.ws_name + "</td>";
  448. html += "<td class='text-left'>" + service.ws_code + "</td>";
  449. html += "<td class='text-left'>" + service.wsdl + "</td>";
  450. html += "<td class='text-left'>" + service.msg_template + "</td>";
  451. html += "<td class='text-center'>" + StatusToText(service.status) + "</td>";
  452. html += "</tr>";
  453. }
  454. }
  455. $("#gridbody").html(html);
  456. }
  457. </script>
  458. }