index.coffee 3.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. # app/pages/Home/index.coffee
  2. document.head.insertAdjacentHTML('beforeend','<style type="text/tailwindcss" page="Home">'+stylFns['app/pages/Home/index.styl']+'</style>')
  3. module.exports =
  4. name: 'Home'
  5. render: (new Function '_ctx', '_cache', renderFns['app/pages/Home/index.pug'])()
  6. data: ->
  7. heroSlides: [
  8. {
  9. id: 1,
  10. image: 'https://avesta.tj/wp-content/uploads/2018/03/10-22.jpg',
  11. title: 'Классическая музыка',
  12. description: 'Вечер симфонической музыки',
  13. cta: 'Купить билеты'
  14. },
  15. {
  16. id: 2,
  17. image: 'https://asiaplustj.info/sites/default/files/articles/176582/borbad.jpg',
  18. title: 'Фольклорные ансамбли',
  19. description: 'Традиционная музыка Таджикистана',
  20. cta: 'Подробнее'
  21. },
  22. {
  23. id: 3,
  24. image: 'https://asiaplustj.info/sites/default/files/articles/211528/vdushanbeprosheltadzhiksko-indiyskiyselskohozyaystvennyyforum.jpg',
  25. title: 'Современные исполнители',
  26. description: 'Лучшие артисты страны',
  27. cta: 'Узнать расписание'
  28. }
  29. ]
  30. events: [
  31. {
  32. id: 1,
  33. title: 'Концерт симфонического оркестра',
  34. date: '15 октября 2025',
  35. description: 'Произведения Чайковского и Рахманинова в исполнении Национального симфонического оркестра',
  36. image: 'https://avesta.tj/wp-content/uploads/2023/10/photo_2023-10-09_13-20-44.jpg',
  37. category: 'classical',
  38. price: 'от 50 сомони'
  39. },
  40. {
  41. id: 2,
  42. title: 'Вечер таджикской народной музыки',
  43. date: '20 октября 2025',
  44. description: 'Выступление фольклорного ансамбля "Шашмаком"',
  45. image: 'https://avatars.mds.yandex.net/get-altay/892711/2a0000018d08049ba81df206f02ee2ec7e1d/XXL_height',
  46. category: 'folk',
  47. price: 'от 30 сомони'
  48. },
  49. {
  50. id: 3,
  51. title: 'Джазовый фестиваль',
  52. date: '25 октября 2025',
  53. description: 'Международные джазовые коллективы в уникальной акустике зала',
  54. image: 'https://avatars.mds.yandex.net/get-altay/9822373/2a0000019377c5d52c95d3175340aab4a35a/XXL_height',
  55. category: 'jazz',
  56. price: 'от 70 сомони'
  57. }
  58. ]
  59. eventFilters: [
  60. { key: 'category', label: 'Категория', type: 'select', options: [
  61. { value: 'all', label: 'Все' },
  62. { value: 'classical', label: 'Классическая' },
  63. { value: 'folk', label: 'Фольклор' },
  64. { value: 'jazz', label: 'Джаз' },
  65. { value: 'pop', label: 'Поп-музыка' }
  66. ]}
  67. ]
  68. eventSortOptions: [
  69. { value: 'date-asc', label: 'По дате (сначала ближайшие)' },
  70. { value: 'date-desc', label: 'По дате (сначала дальние)' },
  71. { value: 'price-asc', label: 'По цене (сначала дешевые)' },
  72. { value: 'price-desc', label: 'По цене (сначала дорогие)' }
  73. ]
  74. filteredEvents: []
  75. mounted: ->
  76. @filteredEvents = [...@events]
  77. methods:
  78. handleFilterChange: (filteredItems) ->
  79. @filteredEvents = filteredItems
  80. handleSortChange: (sortedItems) ->
  81. @filteredEvents = sortedItems
  82. openEventModal: (event) ->
  83. @$root.$emit('open-modal', {
  84. component: 'EventDetailModal',
  85. props: { event }
  86. })
  87. components:
  88. 'imageslider': require 'app/shared/ImageSlider'
  89. 'formvalidator': require 'app/shared/FormValidator'
  90. 'filtersort': require 'app/shared/FilterSort'