popufare_admin.js 28 KB

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