popufare_admin.js 24 KB

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