popufare_admin.js 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858
  1. // example usage:
  2. //
  3. // api_req({"ui_function":"manage_card.find", "api_function":"CardInfo", "data":[ ["action","search"],["mag_token","370000000007015"]]})
  4. //
  5. function api_req(ctx) {
  6. var xhr;
  7. xhr = new XMLHttpRequest();
  8. if (!xhr) { return false; }
  9. var param_val = [];
  10. for (var idx=0; idx<ctx.data.length; idx++) {
  11. param_val.push(ctx.data[idx][0] + '=' + ctx.data[idx][1]);
  12. }
  13. var api_func = "nop";
  14. if ("api_function" in ctx) { api_func = ctx["api_function"]; }
  15. var req_str = "api/v1/" + api_func + "?" + param_val.join("&");
  16. xhr.onreadystatechange = (function(_x,_f) {
  17. return function(v) { api_resp(_x, {"ui_function":_f}); }
  18. })(xhr, ctx["ui_function"])
  19. xhr.open("GET", req_str);
  20. xhr.send()
  21. }
  22. function update_message(ui_id, msg_type, msg_text) {
  23. var ele = document.getElementById(ui_id);
  24. if (msg_type === "error") { ele.style.color = "#f00"; }
  25. else { ele.style.color = "#007"; }
  26. ele.innerHTML = msg_text;
  27. }
  28. function api_resp(xhr,extra) {
  29. if (xhr.readyState === XMLHttpRequest.DONE) {
  30. if (xhr.status === 200) {
  31. var dat = JSON.parse(xhr.responseText);
  32. console.log(dat);
  33. if (extra["ui_function"] === "manage_card.find") {
  34. console.log("manage_card.find", dat);
  35. if (dat["result"] == "fail") {
  36. manage_card_find_fill({});
  37. update_message("ui.manage_card.message", "error", dat["api_comment"]);
  38. return;
  39. }
  40. if (("cards"in dat) &&
  41. (dat.cards.length>0)) {
  42. update_message("ui.manage_card.message", "success", "");
  43. manage_card_find_fill(dat.cards[0]);
  44. }
  45. else {
  46. manage_card_find_fill({});
  47. update_message("ui.manage_card.message", "error", "no cards");
  48. }
  49. }
  50. else if (extra["ui_function"] === "manage_card.findone") {
  51. console.log("... manage_card.findone", dat);
  52. if (dat["result"] == "fail") {
  53. update_message("ui.manage_card.message", "error", dat["api_comment"]);
  54. manage_card_find_fill({});
  55. }
  56. else {
  57. update_message("ui.manage_card.message", "success", "");
  58. manage_card_find_fill(dat);
  59. }
  60. }
  61. else if (extra["ui_function"] === "manage_card.update") {
  62. console.log("issuing 'manage_card.update'");
  63. if (dat["result"] == "fail") {
  64. update_message("ui.manage_card.message", "error", dat["api_comment"]);
  65. }
  66. else {
  67. update_message("ui.manage_card.message", "success", "");
  68. var cardid = _get_input_field("ui.manage_card.logical_card_id");
  69. api_req({"api_function":"CardInfo", "ui_function":"manage_card.findone", "data":[["logical_card_id",cardid]]});
  70. }
  71. }
  72. else if (extra["ui_function"] === "create_user.finish") {
  73. if (dat["result"] === "success") {
  74. update_message("ui.manage_user.message", "success", "");
  75. _redirect( "manage_user?" + "action=get&userid=" + dat["userid"]);
  76. }
  77. else {
  78. update_message("ui.create_user.message", "error", dat.api_comment);
  79. console.log("FAIL:", dat);
  80. }
  81. }
  82. else if (extra["ui_function"] === "manage_user.find") {
  83. console.log("manage_user.find:", dat);
  84. if (dat["result"] === "success") {
  85. update_message("ui.manage_user.message", "success", "");
  86. manage_user_find_fill(dat);
  87. }
  88. else {
  89. update_message("ui.manage_user.message", "error", dat.api_comment);
  90. }
  91. }
  92. else if (extra["ui_function"] === "manage_user.update") {
  93. var userid = _get_input_field("ui.manage_user.userid");
  94. console.log("manage_user.update resp:", dat);
  95. if (dat["result"] === "success") {
  96. // After we've associated the card to the user, re-get user information to re-fill
  97. // page
  98. //
  99. update_message("ui.manage_user.message", "success", "")
  100. update_message("ui.manage_user.password_message", "success", "")
  101. update_message("ui.manage_user.card_message", "success", "")
  102. api_req({"api_function":"UserInfo", "ui_function":"manage_user.find", "data":[["userid",userid]]});
  103. }
  104. else {
  105. update_message("ui.manage_user.message", "error", dat.api_comment);
  106. }
  107. }
  108. else if (extra["ui_function"] === "manage_user.associate_card") {
  109. if (dat["result"] === "success") {
  110. // After we've associated the card to the user, re-get user information to re-fill
  111. // page
  112. //
  113. update_message("ui.manage_user.message", "success", "")
  114. update_message("ui.manage_user.password_message", "success", "")
  115. update_message("ui.manage_user.card_message", "success", "")
  116. api_req({"api_function":"UserInfo", "ui_function":"manage_user.find", "data":[["userid",userid]]});
  117. }
  118. else {
  119. update_message("ui.manage_user.card_message", "error", dat.api_comment);
  120. }
  121. }
  122. else if (extra["ui_function"] === "group") {
  123. }
  124. //else if (extra["ui_function"] === "manage_card.find") { manage_card_find_fill(dat); }
  125. }
  126. else {
  127. console.log("xhr error:", xhr);
  128. }
  129. }
  130. }
  131. function _param2hash(p) {
  132. var h = {};
  133. p = p.substring(1);
  134. var tokval = p.split("&");
  135. for (var idx=0; idx<tokval.length; idx++) {
  136. pv = tokval[idx].split("=");
  137. h[pv[0]] = pv[1];
  138. }
  139. return h;
  140. }
  141. function _attach_button(btn_id, cb) {
  142. ele = document.getElementById(btn_id);
  143. if (ele) { ele.onclick = cb; }
  144. }
  145. function _redirect(rel_str) {
  146. console.log("redirect", rel_str);
  147. window.location.href = rel_str;
  148. }
  149. function _fill_input_field(fid, fdata) {
  150. var ele = document.getElementById(fid);
  151. if (ele) {
  152. if (ele.nodeName === "DIV") { ele.innerHTML = fdata; }
  153. else { ele.value = fdata; }
  154. }
  155. }
  156. function _get_input_field(fid) {
  157. var ele = document.getElementById(fid);
  158. if (ele) { return ele.value; }
  159. return null;
  160. }
  161. function _get_select(fid) {
  162. var ele = document.getElementById(fid);
  163. if (ele) {
  164. return ele.options[ele.selectedIndex].value;
  165. }
  166. return null;
  167. }
  168. function _date_only(s) {
  169. if (!s) { return s; }
  170. if (s.length > 0) {
  171. return s.split(" ")[0];
  172. }
  173. return s;
  174. }
  175. function _create_pass_row(dat) {
  176. var pass_table = document.getElementById("ui.manage_card.list_passes");
  177. var _cb = "<input type='checkbox' id='xxx' name='xxx'>";
  178. while (pass_table.firstChild) {
  179. pass_table.removeChild(pass_table.lastChild);
  180. }
  181. var row = document.createElement("div");
  182. row.classList.add("row");
  183. row.classList.add("rowpop");
  184. row.classList.add("row-shade");
  185. var fields_width = [1,1,1,1,2,2,2,2];
  186. //var fields = ["x", "Type", "Original", "Remain", "Exp.", "Issued", "First Used", "Last Used"];
  187. var fields = ['', "Type", "Original", "Remain", "Exp.", "Issued", "First Used", "Last Used"];
  188. for (var idx=0; idx<fields.length; idx++) {
  189. var cell = document.createElement("div");
  190. cell.innerHTML = fields[idx];
  191. cell.classList.add("col-" + fields_width[idx]);
  192. row.appendChild(cell);
  193. }
  194. pass_table.appendChild(row);
  195. for (var idx=0; idx<dat["pass"].length; idx++) {
  196. var pass_data = dat["pass"][idx];
  197. var passid = pass_data["user_pass_id"];
  198. var pass_type = "unk";
  199. var pass_rule = pass_data["rule"];
  200. var pass_orig = "";
  201. var pass_remain = "";
  202. var pass_exp = "";
  203. if (pass_rule.search(/NRIDE/) >= 0) {
  204. pass_type = "NRide";
  205. pass_orig = pass_data["nrides_orig"];
  206. pass_remain = pass_data["nrides_remain"];
  207. pass_exp = "";
  208. }
  209. else if (pass_rule.search(/NDAY/) >= 0) {
  210. pass_type = "NDay";
  211. pass_orig = pass_data["nday_orig"];
  212. pass_remain = "";
  213. pass_exp = pass_data["nday_expiration"];
  214. }
  215. else {
  216. pass_type = "Other";
  217. }
  218. var pass_firstused = "";
  219. var pass_lastused = "";
  220. if ( (typeof pass_data["firstused"] !== "undefined") &&
  221. (pass_data["firstused"]) ) {
  222. pass_firstused = pass_data["firstused"];
  223. }
  224. if ( (typeof pass_data["lastused"] !== "undefined") &&
  225. (pass_data["lastused"]) ) {
  226. pass_lastused = pass_data["lastused"];
  227. }
  228. row = document.createElement("div");
  229. row.classList.add("row");
  230. row.classList.add("rowpop");
  231. if ((idx%2)==1) {
  232. row.classList.add("row-shade");
  233. }
  234. //var cell = document.createElement("div");
  235. //cell.innerHTML = "x";
  236. var cell = document.createElement("input");
  237. cell.setAttribute('type', 'checkbox');
  238. cell.setAttribute('value', '');
  239. cell.setAttribute('id', "ui.manage_card.cb_" + idx + "_pass");
  240. cell.classList.add("col-" + fields_width[0]);
  241. row.appendChild(cell);
  242. //cell.classList.add("col-" + fields_width[0]);
  243. //row.appendChild(cell);
  244. cell = document.createElement("div");
  245. cell.innerHTML = pass_type;
  246. cell.classList.add("col-" + fields_width[1]);
  247. row.appendChild(cell);
  248. cell = document.createElement("div");
  249. cell.innerHTML = pass_orig;
  250. cell.classList.add("col-" + fields_width[2]);
  251. row.appendChild(cell);
  252. cell = document.createElement("div");
  253. cell.innerHTML = pass_remain;
  254. cell.classList.add("col-" + fields_width[3]);
  255. row.appendChild(cell);
  256. cell = document.createElement("div");
  257. //cell.innerHTML = pass_exp;
  258. cell.innerHTML = _date_only(pass_exp);
  259. cell.classList.add("col-" + fields_width[4]);
  260. row.appendChild(cell);
  261. cell = document.createElement("div");
  262. //cell.innerHTML = pass_data["issued"];
  263. cell.innerHTML = _date_only(pass_data["issued"]);
  264. cell.classList.add("col-" + fields_width[5]);
  265. row.appendChild(cell);
  266. cell = document.createElement("div");
  267. //cell.innerHTML = pass_firstused;
  268. cell.innerHTML = _date_only(pass_firstused);
  269. cell.classList.add("col-" + fields_width[6]);
  270. row.appendChild(cell);
  271. cell = document.createElement("div");
  272. cell.innerHTML = pass_lastused;
  273. cell.classList.add("col-" + fields_width[7]);
  274. row.appendChild(cell);
  275. cell = document.createElement("div");
  276. cell.innerHTML = passid;
  277. cell.setAttribute('id', "ui.manage_card.row_" + idx + "_pass");
  278. cell.style.display = "none";
  279. row.appendChild(cell);
  280. pass_table.appendChild(row);
  281. }
  282. }
  283. function manage_card_find_fill(data) {
  284. var fields = [ "logical_card_id", "group", "mag_token", "rfid_token"];
  285. var user_fields = [ "userid", "username", "first_name", "last_name",
  286. "email", "phone", "address", "city", "state", "zip", "group" ];
  287. console.log("manage_card_find_fill:", data);
  288. for (var idx=0; idx<fields.length; idx++) {
  289. _fill_input_field("ui.manage_card." + fields[idx], "");
  290. }
  291. _fill_input_field("ui.manage_card.disp_userid", "");
  292. for (var idx=0; idx<fields.length; idx++) {
  293. if (fields[idx] in data) {
  294. _fill_input_field("ui.manage_card." + fields[idx], data[fields[idx]])
  295. }
  296. }
  297. for (_user_key in user_fields) {
  298. _fill_input_field("ui.manage_card." + user_fields[_user_key], "");
  299. }
  300. if ("user" in data) {
  301. for (_key in data["user"]) {
  302. _fill_input_field("ui.manage_card." + _key, data["user"][_key]);
  303. }
  304. if ("userid" in data["user"]) {
  305. _fill_input_field("ui.manage_card.disp_userid", data["user"]["userid"]);
  306. }
  307. }
  308. console.log("cp0");
  309. if ("pass" in data) {
  310. _create_pass_row(data);
  311. }
  312. window.history.replaceState({}, document.title, "/manage_card");
  313. }
  314. function manage_card_find_cardid() {
  315. var cardid = _get_input_field("ui.manage_card.logical_card_id");
  316. console.log("??", cardid);
  317. api_req({"api_function":"CardInfo", "ui_function":"manage_card.find", "data": [ ["action","search"], ["logical_card_id",cardid] ] });
  318. }
  319. function manage_card_find_magstripe() {
  320. var mag = _get_input_field("ui.manage_card.mag_token");
  321. api_req({"api_function":"CardInfo", "ui_function":"manage_card.find", "data": [ ["action","search"],["mag_token",mag] ] });
  322. }
  323. function manage_card_find_rfid() {
  324. var rfid = _get_input_field("ui.manage_card.rfid_token");
  325. api_req({"api_function":"CardInfo", "ui_function":"manage_card.find", "data": [ ["action","search"],["rfid_token",rfid] ] });
  326. }
  327. function manage_user_find_fill(data) {
  328. var fields = [ "userid", "username", "first_name", "last_name",
  329. "email", "phone", "address", "city", "state", "zip",
  330. "shipping_name", "shipping_city", "shipping_state", "shipping_address",
  331. "shipping_country_code", "shipping_country_name",
  332. "shipping_zip", "password"];
  333. for (_user_key in fields) {
  334. _fill_input_field("ui.manage_card." + _user_key, "");
  335. }
  336. if ("user" in data) {
  337. var user_data = data["user"];
  338. for (var idx=0; idx<fields.length; idx++) {
  339. if (fields[idx] in user_data) {
  340. _fill_input_field("ui.manage_user." + fields[idx], user_data[fields[idx]])
  341. }
  342. }
  343. }
  344. if ("card" in data) {
  345. var card_table = document.getElementById("ui.manage_user.list_cards");
  346. while (card_table.firstChild) {
  347. card_table.removeChild(card_table.lastChild);
  348. }
  349. var row = document.createElement("div");
  350. row.classList.add("row");
  351. row.classList.add("rowpop");
  352. row.classList.add("row-shade");
  353. var cell = document.createElement("div");
  354. cell.innerHTML = "Card Id";
  355. cell.classList.add("col-4");
  356. row.appendChild(cell);
  357. cell = document.createElement("div");
  358. cell.innerHTML = "Mag Stripe";
  359. cell.classList.add("col-4");
  360. row.appendChild(cell);
  361. cell = document.createElement("div");
  362. cell.innerHTML = "RFID";
  363. cell.classList.add("col-4");
  364. row.appendChild(cell);
  365. card_table.appendChild(row);
  366. var card_data = data["card"];
  367. for (var idx=0; idx<card_data.length; idx++) {
  368. var cardid = card_data[idx]["logical_card_id"];
  369. var magid = card_data[idx]["mag_token"];
  370. var rfid = card_data[idx]["rfid_token"];
  371. row = document.createElement("div");
  372. row.classList.add("row");
  373. row.classList.add("rowpop");
  374. if ((idx % 2) == 1) {
  375. row.classList.add("row-shade");
  376. }
  377. cell = document.createElement("div");
  378. cell.innerHTML = "<a href='/manage_card?logical_card_id=" + cardid + "'>" + cardid + "</a>";
  379. cell.classList.add("col-4");
  380. row.appendChild(cell);
  381. cell = document.createElement("div");
  382. cell.innerHTML = "<a href='/manage_card?logical_card_id=" + cardid + "'>" + magid + "</a>";
  383. cell.classList.add("col-4");
  384. row.appendChild(cell);
  385. cell = document.createElement("div");
  386. cell.innerHTML = "<a href='/manage_card?logical_card_id=" + cardid + "'>" + rfid + "</a>";
  387. cell.classList.add("col-4");
  388. row.appendChild(cell);
  389. card_table.appendChild(row);
  390. console.log("card", idx,
  391. card_data[idx]["logical_card_id"],
  392. card_data[idx]["mag_token"],
  393. card_data[idx]["rfid_token"] );
  394. }
  395. }
  396. window.history.replaceState({}, document.title, "/manage_user");
  397. }
  398. // --------------------------------------
  399. // --------------------------------------
  400. // --------------------------------------
  401. // --------------------------------------
  402. // --------------------------------------
  403. function manage_card_redirect_manage_user() {
  404. var userid = _get_input_field("ui.manage_card.userid");
  405. _redirect( "manage_user?" + "action=get&userid=" + userid);
  406. }
  407. function manage_card_reissue() {
  408. var cardid = _get_input_field("ui.manage_card.logical_card_id");
  409. _redirect( "reissue_card?" + "action=get&logical_card_id=" + cardid);
  410. }
  411. function manage_card_add_pass(pass_type) {
  412. //var cardid = _get_input_field("ui.manage_card.logical_card_id");
  413. console.log("manage_card_add_pass:", cardid, pass_type);
  414. var dat = {
  415. "api_function":"Pass",
  416. "ui_function":"manage_card.update",
  417. "data": [
  418. ["logical_card_id",cardid],
  419. ["nrides_orig", 3],
  420. ["nrides_remain", 2],
  421. ["nday_orig", 5],
  422. ["rule", "ORIG-NRIDE"]
  423. ]};
  424. api_req(dat);
  425. }
  426. function manage_card_add_pass_nride() {
  427. var cardid = _get_input_field("ui.manage_card.logical_card_id");
  428. var nrides_orig = _get_input_field("ui.manage_card.pass_nride_other");
  429. if (nrides_orig.length == 0) {
  430. nrides_orig = _get_select("ui.manage_card.pass_nride_orig");
  431. }
  432. var rule = "ORG";
  433. rule += "-" + _get_select("ui.manage_card.pass_nride_type");
  434. rule += "-" + _get_select("ui.manage_card.pass_nride_region");
  435. var api_data = {
  436. "api_function":"Pass",
  437. "ui_function":"manage_card.update",
  438. "data" : [
  439. ["action","add"],
  440. ["logical_card_id" , cardid],
  441. ["nrides_orig" , nrides_orig],
  442. ["nrides_remain" , nrides_orig],
  443. ["rule" , rule]
  444. ]
  445. };
  446. //DEBUG
  447. console.log(">>nride++", api_data);
  448. api_req(api_data);
  449. }
  450. function manage_card_add_pass_nday() {
  451. var cardid = _get_input_field("ui.manage_card.logical_card_id");
  452. var nday_orig = _get_input_field("ui.manage_card.pass_nday_other");
  453. if (nday_orig.length == 0) {
  454. nday_orig = _get_select("ui.manage_card.pass_nday_orig");
  455. }
  456. var rule = "ORG";
  457. rule += "-" + _get_select("ui.manage_card.pass_nday_type");
  458. rule += "-" + _get_select("ui.manage_card.pass_nday_region");
  459. var api_data = {
  460. "api_function":"Pass",
  461. "ui_function":"manage_card.update",
  462. "data" : [
  463. ["action","add"],
  464. ["logical_card_id" , cardid],
  465. ["nday_orig" , nday_orig],
  466. ["rule" , rule]
  467. ]
  468. };
  469. //DEBUG
  470. console.log(">>nday++", api_data);
  471. api_req(api_data);
  472. }
  473. function manage_card_add_pass_other() {
  474. var cardid = _get_input_field("ui.manage_card.logical_card_id");
  475. var ui_ele = document.getElementById("ui.manage_card.pass_other");
  476. var rule = ui_ele.options[ui_ele.selectedIndex].id;
  477. var api_data = {
  478. "api_function":"Pass",
  479. "ui_function":"manage_card.update",
  480. "data" : [
  481. ["action","add"],
  482. ["logical_card_id" , cardid],
  483. ["rule" , rule]
  484. ]
  485. };
  486. //DEBUG
  487. console.log(">>other++", api_data);
  488. api_req(api_data);
  489. }
  490. function manage_card_delete_pass() {
  491. var cardid = _get_input_field("ui.manage_card.logical_card_id");
  492. var ele = document.getElementById("ui.manage_card.list_passes");
  493. var n = ele.children.length;
  494. n-=1;
  495. for (var ii=0; ii<n; ii++) {
  496. var cb = document.getElementById("ui.manage_card.cb_" + ii + "_pass");
  497. if (!cb.checked) { continue; }
  498. var v = document.getElementById("ui.manage_card.row_"+ ii + "_pass");
  499. var passid = v.innerHTML;
  500. console.log("deleting pass", passid, "(card:", cardid,")");
  501. if (cb.checked) {
  502. var dat = {
  503. "api_function":"Pass",
  504. "ui_function":"manage_card.update",
  505. "data": [
  506. ["action", "deactivate"],
  507. ["logical_card_id",cardid],
  508. ["user_pass_id", passid]
  509. ]};
  510. api_req(dat);
  511. }
  512. }
  513. }
  514. function manage_card_toggle_pass_select() {
  515. var ele = document.getElementById("ui.manage_card.list_passes");
  516. var n = ele.children.length;
  517. n-=1;
  518. for (var ii=0; ii<n; ii++) {
  519. var cb = document.getElementById("ui.manage_card.cb_" + ii + "_pass");
  520. if (cb.checked) { cb.checked = false; }
  521. else { cb.checked = true; }
  522. }
  523. }
  524. // --------------------------------------
  525. // --------------------------------------
  526. function manage_user_find_userid() {
  527. var userid = _get_input_field("ui.manage_user.userid");
  528. api_req({"api_function":"UserInfo", "ui_function":"manage_user.find", "data": [ ["userid",userid] ] });
  529. }
  530. function manage_user_find_username() {
  531. var ele = document.getElementById("ui.manage_user.username");
  532. var username = ele.value;
  533. api_req({"api_function":"UserInfo", "ui_function":"manage_user.find", "data":[["username",username]]});
  534. }
  535. function manage_user_update_user() {
  536. var ele = document.getElementById("ui.manage_user.userid");
  537. var userid = ele.value;
  538. var user_data = [["action","update"],["userid", userid]];
  539. var fields = ["username", "lookup_userid", "lookup_username", "first_name", "last_name", "email", "phone",
  540. "address", "city", "state", "zip", "shipping_name", "shipping_address", "shipping_city",
  541. "shipping_state", "shipping_country_code", "shipping_country_name", "shipping_zip" ];
  542. for (var idx=0; idx<fields.length; idx++) {
  543. var _e = document.getElementById("ui.manage_user." + fields[idx]);
  544. if (!_e) { continue; }
  545. user_data.push([fields[idx],_e.value]);
  546. }
  547. var req_data = {"api_function":"User", "ui_function":"manage_user.update_finish", "data":user_data};
  548. api_req(req_data);
  549. }
  550. function manage_user_associate_card(data) {
  551. var ele = document.getElementById("ui.manage_user.userid");
  552. var userid = ele.value;
  553. var ele = document.getElementById("ui.manage_user.logical_card_id");
  554. var cardid = ele.value;
  555. ele = document.getElementById("ui.manage_user.mag_token");
  556. var mag = ele.value;
  557. ele = document.getElementById("ui.manage_user.rfid_token");
  558. var rfid = ele.value;
  559. var req_dat = { "api_function":"Card", "ui_function":"manage_user.associate_card",
  560. "data": [
  561. ["action","update"],
  562. ["userid", userid],
  563. ["logical_card_id",cardid],
  564. ["mag_token",mag],
  565. ["rfid_token",rfid]
  566. ] };
  567. api_req(req_dat);
  568. }
  569. function manage_user_reset_password(data) {
  570. var ele = undefined;
  571. ele = document.getElementById("ui.manage_user.userid");
  572. var userid = ele.value;
  573. if ((userid === "") || (typeof userid === "undefined") || isNaN(userid)) {
  574. update_message("ui.manage_user.password_message", "error", "Please provide userid");
  575. return;
  576. }
  577. ele = document.getElementById("ui.manage_user.new_password");
  578. var pw0 = ele.value;
  579. if ((pw0 === "") || (typeof pw0 === "undefined")) {
  580. update_message("ui.manage_user.password_message", "error", "Please provide password");
  581. return;
  582. }
  583. ele = document.getElementById("ui.manage_user.confirm_password");
  584. var pw1 = ele.value;
  585. if ((pw1 === "") || (typeof pw1 === "undefined")) {
  586. update_message("ui.manage_user.password_message", "error", "Please provide confirmation password");
  587. return;
  588. }
  589. if (pw0 !== pw1) {
  590. update_message("ui.manage_user.password_message", "error", "Passwords must match");
  591. return;
  592. }
  593. var req_dat = { "api_function":"User", "ui_function":"manage_user.update",
  594. "data": [
  595. ["action","update"],
  596. ["userid", userid],
  597. ["password",pw0]
  598. ] };
  599. api_req(req_dat);
  600. }
  601. // --------------------------------------
  602. // --------------------------------------
  603. function create_user_process_button() {
  604. var val_names = ["username", "first_name", "last_name",
  605. "email", "phone", "address", "city", "state", "zip",
  606. "shipping_name", "shipping_address",
  607. "shipping_city", "shipping_state",
  608. "shipping_country_code", "shipping_country_name",
  609. "shipping_zip",
  610. "password"];
  611. var req_dat = { "api_function":"User", "ui_function":"create_user.finish",
  612. "data":[ ["action","add"]] };
  613. for (var idx=0; idx<val_names.length; idx++) {
  614. var v = _get_input_field("create_user:" + val_names[idx]);
  615. if (v) {
  616. req_dat.data.push([val_names[idx],v]);
  617. }
  618. }
  619. api_req(req_dat);
  620. }
  621. // --------------------------------------
  622. // --------------------------------------
  623. // --------------------------------------
  624. // --------------------------------------
  625. // --------------------------------------
  626. function admin_api_init() {
  627. var ele;
  628. var _func = location.pathname.substring(1);
  629. console.log("...init", _func);
  630. console.log(window.location.search);
  631. var _h = _param2hash(window.location.search);
  632. if (_func === "create_user") {
  633. _attach_button("create_user:button_create", create_user_process_button);
  634. }
  635. else if (_func === "manage_user") {
  636. _attach_button( "ui.manage_user.lookup_userid", manage_user_find_userid);
  637. _attach_button( "ui.manage_user.lookup_username", manage_user_find_username);
  638. _attach_button( "ui.manage_user.update_user", manage_user_update_user);
  639. _attach_button( "ui.manage_user.associate_card", manage_user_associate_card);
  640. _attach_button( "ui.manage_user.reset_password", manage_user_reset_password);
  641. if ("userid" in _h) {
  642. console.log("sending manage_user.find request");
  643. api_req({"api_function":"UserInfo", "ui_function":"manage_user.find", "data":[["userid",_h["userid"]]]});
  644. }
  645. }
  646. else if (_func === "manage_card") {
  647. _attach_button( "ui.manage_card.lookup_logical_card_id", manage_card_find_cardid);
  648. _attach_button( "ui.manage_card.lookup_mag_token", manage_card_find_magstripe);
  649. _attach_button( "ui.manage_card.lookup_rfid_token", manage_card_find_rfid);
  650. _attach_button( "ui.manage_card.manage_user", manage_card_redirect_manage_user);
  651. _attach_button( "ui.manage_card.reissue", manage_card_reissue);
  652. _attach_button( "ui.manage_card.add_pass_nride", manage_card_add_pass_nride);
  653. _attach_button( "ui.manage_card.add_pass_nday", manage_card_add_pass_nday);
  654. _attach_button( "ui.manage_card.add_pass_other", manage_card_add_pass_other);
  655. _attach_button( "ui.manage_card.delete_pass", manage_card_delete_pass);
  656. _attach_button( "ui.manage_card.toggle_pass_all", manage_card_toggle_pass_select);
  657. if ("logical_card_id" in _h) {
  658. console.log("sending manage_card.find request");
  659. api_req({
  660. "api_function":"CardInfo",
  661. "ui_function":"manage_card.find",
  662. "data": [
  663. ["action","search"],
  664. ["logical_card_id",_h["logical_card_id"] ]
  665. ]
  666. });
  667. }
  668. }
  669. }
  670. admin_api_init();