main.js 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. function reducer(state, {type, ШО, СКОКА,БАБОС}){ //объект action деструктуризируется на три переменных
  2. if (!state){ //начальная уборка в ларьке:
  3. return {
  4. пиво: {count: 100, price: 25},
  5. чипсы: {count: 100, price: 30},
  6. сиги: {count: 100, price: 32},
  7. сникерс: {count: 100, price: 40},
  8. касса: 0
  9. }
  10. }
  11. if (type === 'КУПИТЬ'){ //если тип action - КУПИТЬ, то:
  12. if(СКОКА > state[ШО].count){
  13. alert(`nety stoka ${state[ШО]}`);
  14. return state;
  15. }
  16. if(БАБОС < (state[ШО].price * СКОКА)){
  17. console.log('gde babki?')
  18. return state
  19. }
  20. return {
  21. ...state, //берем все что было из ассортимента
  22. [ШО]: {count:state[ШО].count - СКОКА, price:state[ШО].price},
  23. касса: state.касса + (+БАБОС),
  24. //и уменьшаем то, что покупается на количество
  25. }
  26. }
  27. return state //если мы не поняли, что от нас просят в `action` - оставляем все как есть
  28. }
  29. function createStore(reducer){
  30. let state = reducer(undefined, {}) //стартовая инициализация состояния, запуск редьюсера со state === undefined
  31. let cbs = [] //массив подписчиков
  32. const getState = () => state //функция, возвращающая переменную из замыкания
  33. const subscribe = cb => (cbs.push(cb), //запоминаем подписчиков в массиве
  34. () => cbs = cbs.filter(c => c !== cb)) //возвращаем функцию unsubscribe, которая удаляет подписчика из списка
  35. const dispatch = action => {
  36. const newState = reducer(state, action) //пробуем запустить редьюсер
  37. if (newState !== state){ //проверяем, смог ли редьюсер обработать action
  38. state = newState //если смог, то обновляем state
  39. for (let cb of cbs) cb() //и запускаем подписчиков
  40. }
  41. }
  42. return {
  43. getState, //добавление функции getState в результирующий объект
  44. dispatch,
  45. subscribe //добавление subscribe в объект
  46. }
  47. }
  48. const store = createStore(reducer);
  49. let productArr = Object.keys(store.getState())
  50. let select = document.getElementById('select');
  51. let numberOfProducts = document.getElementById('numberOfProducts');
  52. let money = document.getElementById('money');
  53. let buyButtton = document.getElementById('buy');
  54. for(let i = 0; i<productArr.length; i++){
  55. select.options[i] = new Option(productArr[i],productArr[i]);
  56. }
  57. function createTable(){
  58. let getStateObj = store.getState();
  59. let table = document.getElementById('table');
  60. table.innerHTML ='';
  61. /* for(let[key,value] of Object.entries(store.getState())){
  62. let rows = document.createElement('tr');
  63. table.append(rows)
  64. rows.append(document.createElement('td').innerText = key);
  65. rows.append(document.createElement('td').innerText = value);
  66. } */
  67. for(let key in getStateObj){
  68. let rows = document.createElement('tr');
  69. rows.innerHTML = `<td colspan="2">${key}</td>`;
  70. table.appendChild(rows);
  71. if(typeof getStateObj[key]=='object'){
  72. /* for(let keyinObj in getStateObj[key]){ // цикл для перебора внутринних полей вложенного обьекта но работатет кривовастенько*/
  73. let rows = document.createElement('tr');
  74. rows.innerHTML = `
  75. <td> count ${getStateObj[key].count} price ${getStateObj[key].price}</td>
  76. `
  77. table.appendChild(rows);
  78. /* table.append(rows);
  79. rows.append(document.createElement('td').innerText = `name of product ${key}`);
  80. if(keyinObj == 'count'){
  81. rows.append(document.createElement('td').innerText = ` amount of products${getStateObj[key][keyinObj]}`);
  82. }
  83. if(keyinObj == 'price'){
  84. rows.append(document.createElement('td').innerText = ` price${getStateObj[key][keyinObj]}`);
  85. }
  86. */
  87. /* rows.append(document.createElement('td').innerText = `price ${getStateObj[key][1][keyinObj]}`); */
  88. /* } */
  89. } else{
  90. rows = document.createElement('tr');
  91. rows.innerHTML= `<td>${getStateObj[key]}</td>`
  92. table.append(rows);
  93. /* rows.append(document.createElement('td').innerText = key);
  94. rows.append(document.createElement('td').innerText = ` ${getStateObj[key]}`); */
  95. }
  96. }
  97. }
  98. buyButtton.addEventListener("click",function buyProducts() {
  99. store.dispatch({type: 'КУПИТЬ', ШО:select.value,СКОКА:numberOfProducts.value,БАБОС:money.value})
  100. })
  101. store.subscribe(() => console.log(store.getState()));
  102. createTable(store.getState());
  103. store.subscribe(createTable);