Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

propertySearchFields.vue 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <template>
  2. <div>
  3. <div class="col-md-6 mb-2">
  4. <div class="form-group">
  5. <label for="city">For:</label>
  6. <select
  7. class="form-control form-control-lg form-control-a"
  8. id="forSelector"
  9. v-model="selectedType"
  10. @change="TypeSelected"
  11. >
  12. <option value="Sale">Sale</option>
  13. <option value="Rent">Rent</option>
  14. </select>
  15. </div>
  16. <div class="form-group" v-if="propertyType === 'Residential'">
  17. <label for="city">Property Type</label>
  18. <select
  19. class="form-control form-control-lg form-control-a"
  20. id="forSelector"
  21. v-model="selectedPropertyTypeRes"
  22. @change="PropertyTypeSelected"
  23. >
  24. <option>All</option>
  25. <option
  26. v-for="(propertyType, i) in propertyTypesRes"
  27. :key="i"
  28. >{{ propertyType.description }}</option>
  29. </select>
  30. </div>
  31. <div v-else class="form-group">
  32. <label for="city">Property Type</label>
  33. <select
  34. class="form-control form-control-lg form-control-a"
  35. id="forSelector"
  36. v-model="selectedPropertyTypeCom"
  37. @change="PropertyTypeSelected"
  38. >
  39. <option>All</option>
  40. <option
  41. v-for="(propertyType, i) in propertyTypesCom"
  42. :key="i"
  43. >{{ propertyType.description }}</option>
  44. </select>
  45. </div>
  46. <div class="form-group">
  47. <label for="city">Province</label>
  48. <select
  49. class="form-control form-control-lg form-control-a"
  50. id="provinceselector"
  51. @change="ProvinceSelected"
  52. v-model="selectedProvince"
  53. >
  54. <option>All</option>
  55. <option v-for="(province, i) in provinces" :key="i">{{ province.description }}</option>
  56. </select>
  57. </div>
  58. </div>
  59. <div class="col-md-6 mb-2">
  60. <div class="form-group">
  61. <label for="city">City</label>
  62. <select
  63. class="form-control form-control-lg form-control-a"
  64. id="cityselector"
  65. @change="CitySelected"
  66. v-model="selectedCity"
  67. >
  68. <option>All</option>
  69. <option v-for="(city, i) in cities" :key="i">{{ city.description }}</option>
  70. </select>
  71. </div>
  72. </div>
  73. <div class="col-md-6 mb-2">
  74. <div class="form-group">
  75. <label for="city">Suburb</label>
  76. <select
  77. class="form-control form-control-lg form-control-a"
  78. id="suburbselector"
  79. v-model="selectedSuburb"
  80. @change="SuburbSelected"
  81. >
  82. <option>All</option>
  83. <option v-for="(suburb, i) in suburbs" :key="i">{{ suburb.description }}</option>
  84. </select>
  85. </div>
  86. </div>
  87. </div>
  88. </template>
  89. <script>
  90. import { mapState, mapActions } from 'vuex';
  91. export default {
  92. props: {
  93. propertyType: String,
  94. },
  95. data() {
  96. return {
  97. selectedType: 'Sale',
  98. selectedProvince: 'All',
  99. selectedCity: 'All',
  100. selectedSuburb: 'All',
  101. selectedPropertyTypeRes: 'All',
  102. selectedPropertyTypeCom: 'All',
  103. };
  104. },
  105. mounted() {
  106. this.getProvince();
  107. this.$emit('TypeSelectedUpdated', this.selectedType);
  108. this.getPropertyTypesRes();
  109. this.getPropertyTypesCom();
  110. },
  111. computed: {
  112. ...mapState('searchTab', ['provinces', 'cities', 'suburbs']),
  113. ...mapState('property', ['propertyTypesRes', 'propertyTypesCom']),
  114. },
  115. methods: {
  116. ...mapActions('searchTab', ['getProvince', 'getCities', 'getSuburbs']),
  117. ...mapActions('property', ['getPropertyTypesRes', 'getPropertyTypesCom']),
  118. TypeSelected(item) {
  119. this.$emit('TypeSelectedUpdated', item.target.value);
  120. },
  121. PropertyTypeSelected(item) {
  122. this.$emit('PropertyTypeSelectedUpdated', item.target.value);
  123. },
  124. ProvinceSelected(item) {
  125. if (item.target.value !== 'All') {
  126. this.getCities(Object.assign({}, { province: this.selectedProvince }));
  127. }
  128. this.$emit('ProvinceSelectedUpdated', item.target.value);
  129. },
  130. CitySelected(item) {
  131. if (item.target.value !== 'All') {
  132. this.getSuburbs(
  133. Object.assign(
  134. {},
  135. { province: this.selectedProvince, city: this.selectedCity },
  136. ),
  137. );
  138. }
  139. this.$emit('CitySelectedUpdated', item.target.value);
  140. },
  141. SuburbSelected(item) {
  142. this.$emit('SuburbSelectedUpdated', item.target.value);
  143. },
  144. },
  145. };
  146. </script>