popufare_admin.js 20 KB

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