popufare_admin.js 17 KB

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