Home.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. import {getTemplateUsers} from "./Templates.js";
  2. import {getTemplateRegistration} from "./Templates.js";
  3. import {bindEvents, dEvent} from "../libs/helper.js";
  4. import {f} from "../libs/helper.js"
  5. export default class Home extends HTMLElement {
  6. constructor() {
  7. super();
  8. this.user = null;
  9. this.registrations = null;
  10. this.bind();
  11. this.rendered = false;
  12. this.data = {
  13. name:"",
  14. price:"",
  15. description:"",
  16. position:"",
  17. }
  18. this.s = {
  19. service: null
  20. };
  21. }
  22. connectedCallback() {
  23. if (!this.rendered && this.user) {
  24. this.render();
  25. }
  26. }
  27. bind() {
  28. bindEvents("UserHomeLogin", "user-login", (e) => {
  29. this.user = e.detail;
  30. this.render();
  31. })
  32. bindEvents("UserHomeOut", "user-logout", (e) => {
  33. this.user = null;
  34. this.innerHTML = "";
  35. })
  36. }
  37. async render() {
  38. this.innerHTML = "";
  39. if (!this.user) return;
  40. this.rendered = true;
  41. let res = (await f("service", "get", this.user.user_token)).data;
  42. console.log(res)
  43. this.registrations = res;
  44. for (let reg of this.registrations) {
  45. this.innerHTML += (getTemplateUsers(reg))
  46. }
  47. this.attachModel();
  48. }
  49. attachModel() {
  50. this.querySelectorAll("input")
  51. .forEach(el=>el.addEventListener("input",e =>this.inputText(e)))
  52. this.querySelectorAll('.button')
  53. .forEach(el => el.addEventListener('click', e => this.clickButton(e)))
  54. }
  55. inputText(e) {
  56. if (this.data[e.target.dataset.model] !== undefined) {
  57. this.data[e.target.dataset.model] = e.target.value;
  58. }
  59. }
  60. clickButton(e) {
  61. if (this[e.target.dataset.click]) {
  62. this[e.target.dataset.click](e);
  63. }
  64. }
  65. async register(e) {
  66. this.s.service = e.target.dataset.service
  67. let res = await f("servicerecord", "post", this.user.user_token, this.s)
  68. console.log(res)
  69. e.target.innerHTML = "Записано"
  70. e.target.classList.add("disabled")
  71. dEvent("user-cab",{status: "update"});
  72. }
  73. async restore(e) {
  74. let id = e.target.dataset.id;
  75. let res = await f(`service/${id}`, "delete", this.user.user_token, null);
  76. console.log(res)
  77. let el = document.getElementById(id);
  78. el.classList.add("disabled-block");
  79. dEvent("user-cab",{status: "update"});
  80. }
  81. put(e) {
  82. let id = e.target.dataset.id;
  83. let el = this.registrations.find(reg=>reg.id == id)
  84. let div = document.createElement("div");
  85. div.classList = "my-div";
  86. div.innerHTML = getTemplateRegistration(el);
  87. this.append(div);
  88. this.attachModel();
  89. }
  90. async change(e) {
  91. console.log(this.data)
  92. let id = e.target.dataset.id;
  93. let res = await f(`service/${id}`, "put", this.user.user_token, this.data);
  94. console.log(res);
  95. if (res.error) {
  96. this.querySelector('.message').innerHTML = 'Данные введены некорректно';
  97. this.querySelector('.message').innerHTML+=`<style>.message {background:crimson}</style>`
  98. return;
  99. }
  100. let div = document.getElementsByClassName("my-div")[0];
  101. div.classList.add("none");
  102. dEvent("user-cab",{status: "update"});
  103. }
  104. }