Home.vue 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. <template>
  2. <div class="app">
  3. <main-header></main-header>
  4. <div class="modal" :class="{ 'is-active': isRegisterActive }">
  5. <div class="modal-background"></div>
  6. <div class="modal-card">
  7. <header class="modal-card-head">
  8. <p class="modal-card-title">Register</p>
  9. <button class="delete" @click="toggleModal('register')"></button>
  10. </header>
  11. <section class="modal-card-body">
  12. <!-- validation to check if exists http://bulma.io/documentation/elements/form/ -->
  13. <label class="label">Email</label>
  14. <p class="control">
  15. <input class="input" type="text" placeholder="Email..." v-model="$parent.register.email">
  16. </p>
  17. <label class="label">Username</label>
  18. <p class="control">
  19. <input class="input" type="text" placeholder="Username..." v-model="$parent.register.username">
  20. </p>
  21. <label class="label">Password</label>
  22. <p class="control">
  23. <input class="input" type="password" placeholder="Password..." v-model="$parent.register.password">
  24. </p>
  25. <div class="g-recaptcha" data-sitekey="6LdNCQcUAAAAANj_w5leQSrxnAmDp2ioh4alkUHg"></div>
  26. </section>
  27. <footer class="modal-card-foot">
  28. <a class="button is-primary" @click="submitModal('register')">Submit</a>
  29. </footer>
  30. </div>
  31. </div>
  32. <div class="modal" :class="{ 'is-active': isLoginActive }">
  33. <div class="modal-background"></div>
  34. <div class="modal-card">
  35. <header class="modal-card-head">
  36. <p class="modal-card-title">Login</p>
  37. <button class="delete" @click="toggleModal('login')"></button>
  38. </header>
  39. <section class="modal-card-body">
  40. <!-- validation to check if exists http://bulma.io/documentation/elements/form/ -->
  41. <label class="label">Email</label>
  42. <p class="control">
  43. <input class="input" type="text" placeholder="Email..." v-model="$parent.login.email">
  44. </p>
  45. <label class="label">Password</label>
  46. <p class="control">
  47. <input class="input" type="password" placeholder="Password..." v-model="$parent.login.password">
  48. </p>
  49. </section>
  50. <footer class="modal-card-foot">
  51. <a class="button is-primary" @click="submitModal('login')">Submit</a>
  52. </footer>
  53. </div>
  54. </div>
  55. <div class="group">
  56. <div class="group-title">Official Stations</div>
  57. <div class="group-stations">
  58. <div class="stations-station" v-for="station in $parent.stations.official" v-link="{ path: '/' + station.name }" @click="this.$dispatch('joinStation', station.id)">
  59. <img class="station-image" :src="station.playlist[station.currentSongIndex].thumbnail" />
  60. <div class="station-info">
  61. <div class="station-grid-left">
  62. <h3>{{ station.displayName }}</h3>
  63. <p>{{ station.description }}</p>
  64. </div>
  65. <div class="station-grid-right">
  66. <div>{{ station.userCount }}&nbsp;&nbsp;<i class="fa fa-user" aria-hidden="true"></i></div>
  67. </div>
  68. </div>
  69. </div>
  70. </div>
  71. </div>
  72. <div class="group" v-if="$parent.stations.community.length">
  73. <div class="group-title">Community Stations</div>
  74. <div class="group-stations">
  75. <div class="stations-station" v-for="station in $parent.stations.community" v-link="{ path: '/community/' + station.name }" @click="this.$dispatch('joinStation', station.id)">
  76. <img class="station-image" :src="station.playlist[station.currentSongIndex].thumbnail" />
  77. <div class="station-info">
  78. <div class="station-grid-left">
  79. <h3>{{ station.displayName }}</h3>
  80. <p>{{ station.description }}</p>
  81. </div>
  82. <div class="station-grid-right">
  83. <div>{{ station.userCount }}&nbsp;&nbsp;<i class="fa fa-user" aria-hidden="true"></i></div>
  84. </div>
  85. </div>
  86. </div>
  87. </div>
  88. </div>
  89. <main-footer></main-footer>
  90. </div>
  91. </template>
  92. <script>
  93. import MainHeader from '../MainHeader.vue'
  94. import MainFooter from '../MainFooter.vue'
  95. export default {
  96. data() {
  97. return {
  98. isRegisterActive: false,
  99. isLoginActive: false
  100. }
  101. },
  102. methods: {
  103. toggleModal: function(type) {
  104. switch(type) {
  105. case 'register':
  106. this.isRegisterActive = !this.isRegisterActive;
  107. break;
  108. case 'login':
  109. this.isLoginActive = !this.isLoginActive;
  110. break;
  111. }
  112. },
  113. submitModal: function(type) {
  114. switch(type) {
  115. case 'register':
  116. this.$dispatch('register');
  117. this.toggleModal('register');
  118. break;
  119. case 'login':
  120. this.$dispatch('login');
  121. this.toggleModal('login');
  122. break;
  123. }
  124. }
  125. },
  126. components: { MainHeader, MainFooter }
  127. }
  128. </script>
  129. <style lang="scss">
  130. @import 'theme.scss';
  131. * { box-sizing: border-box; font-family: Roboto, sans-serif; }
  132. html {
  133. width: 100%;
  134. height: 100%;
  135. color: rgba(0, 0, 0, 0.87);
  136. body {
  137. width: 100%;
  138. height: 100%;
  139. margin: 0;
  140. padding: 0;
  141. }
  142. }
  143. @media only screen and (min-width: 1200px) {
  144. html {
  145. font-size: 15px;
  146. }
  147. }
  148. @media only screen and (min-width: 992px) {
  149. html {
  150. font-size: 14.5px;
  151. }
  152. }
  153. @media only screen and (min-width: 0) {
  154. html {
  155. font-size: 14px;
  156. }
  157. }
  158. .label {
  159. display: flex;
  160. }
  161. .g-recaptcha {
  162. display: flex;
  163. justify-content: center;
  164. margin-top: 20px;
  165. }
  166. .group {
  167. width: 100%;
  168. height: 448px;
  169. margin: 64px 0 0 0;
  170. .group-title {
  171. float: left;
  172. clear: none;
  173. width: 100%;
  174. height: 64px;
  175. line-height: 48px;
  176. text-align: center;
  177. font-size: 48px;
  178. }
  179. .group-stations {
  180. white-space: nowrap;
  181. text-align: center;
  182. overflow: hidden;
  183. float: left;
  184. clear: none;
  185. width: 100%;
  186. height: 400px;
  187. .stations-station {
  188. position: relative;
  189. top: 16px;
  190. display: inline-block;
  191. clear: none;
  192. width: 256px;
  193. height: 370px;
  194. margin: 0 16px 0 16px;
  195. box-shadow: 0 1px 6px 2px rgba(0, 0, 0, 0.25);
  196. cursor: pointer;
  197. .station-info {
  198. display: flex;
  199. flex-direction: row;
  200. align-items: center;
  201. }
  202. .station-image {
  203. width: 100%;
  204. height: 256px;
  205. object-fit: cover;
  206. }
  207. .station-grid-left {
  208. display: flex;
  209. flex-direction: column;
  210. width: 75%;
  211. text-align: left;
  212. padding-left: 10px;
  213. h3 {
  214. color: $blue;
  215. margin: 0;
  216. white-space: normal;
  217. padding-top: 10px;
  218. }
  219. p {
  220. margin: 0;
  221. white-space: normal;
  222. padding-top: 10px;
  223. }
  224. }
  225. .station-grid-right {
  226. display: flex;
  227. flex-direction: column;
  228. width: 25%;
  229. i {
  230. color: $blue;
  231. }
  232. }
  233. }
  234. }
  235. }
  236. </style>