ソースを参照

Merging changes

master
Kobus 6年前
コミット
d2a21f3b19

+ 54
- 2
package-lock.json ファイルの表示

@@ -3737,8 +3737,7 @@
3737 3737
     "deep-equal": {
3738 3738
       "version": "1.0.1",
3739 3739
       "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.0.1.tgz",
3740
-      "integrity": "sha1-9dJgKStmDghO/0zbyfCK0yR0SLU=",
3741
-      "dev": true
3740
+      "integrity": "sha1-9dJgKStmDghO/0zbyfCK0yR0SLU="
3742 3741
     },
3743 3742
     "deep-is": {
3744 3743
       "version": "0.1.3",
@@ -5026,6 +5025,11 @@
5026 5025
       "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz",
5027 5026
       "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk="
5028 5027
     },
5028
+    "fast-diff": {
5029
+      "version": "1.1.2",
5030
+      "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.1.2.tgz",
5031
+      "integrity": "sha512-KaJUt+M9t1qaIteSvjc6P3RbMdXsNhK61GRftR6SNxqmhthcd9MGIi4T+o0jD8LUSpSnSKXE20nLtJ3fOHxQig=="
5032
+    },
5029 5033
     "fast-glob": {
5030 5034
       "version": "2.2.7",
5031 5035
       "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-2.2.7.tgz",
@@ -8498,6 +8502,11 @@
8498 8502
         "no-case": "^2.2.0"
8499 8503
       }
8500 8504
     },
8505
+    "parchment": {
8506
+      "version": "1.1.4",
8507
+      "resolved": "https://registry.npmjs.org/parchment/-/parchment-1.1.4.tgz",
8508
+      "integrity": "sha512-J5FBQt/pM2inLzg4hEWmzQx/8h8D0CiDxaG3vyp9rKrQRSDgBlhjdP5jQGgosEajXPSQouXGHOmVdgo7QmJuOg=="
8509
+    },
8501 8510
     "parent-module": {
8502 8511
       "version": "1.0.1",
8503 8512
       "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
@@ -9456,6 +9465,41 @@
9456 9465
       "integrity": "sha512-w7fLxIRCRT7U8Qu53jQnJyPkYZIaR4n5151KMfcJlO/A9397Wxb1amJvROTK6TOnp7PfoAmg/qXiNHI+08jRfA==",
9457 9466
       "dev": true
9458 9467
     },
9468
+    "quill": {
9469
+      "version": "1.3.7",
9470
+      "resolved": "https://registry.npmjs.org/quill/-/quill-1.3.7.tgz",
9471
+      "integrity": "sha512-hG/DVzh/TiknWtE6QmWAF/pxoZKYxfe3J/d/+ShUWkDvvkZQVTPeVmUJVu1uE6DDooC4fWTiCLh84ul89oNz5g==",
9472
+      "requires": {
9473
+        "clone": "^2.1.1",
9474
+        "deep-equal": "^1.0.1",
9475
+        "eventemitter3": "^2.0.3",
9476
+        "extend": "^3.0.2",
9477
+        "parchment": "^1.1.4",
9478
+        "quill-delta": "^3.6.2"
9479
+      },
9480
+      "dependencies": {
9481
+        "clone": {
9482
+          "version": "2.1.2",
9483
+          "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz",
9484
+          "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18="
9485
+        },
9486
+        "eventemitter3": {
9487
+          "version": "2.0.3",
9488
+          "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-2.0.3.tgz",
9489
+          "integrity": "sha1-teEHm1n7XhuidxwKmTvgYKWMmbo="
9490
+        }
9491
+      }
9492
+    },
9493
+    "quill-delta": {
9494
+      "version": "3.6.3",
9495
+      "resolved": "https://registry.npmjs.org/quill-delta/-/quill-delta-3.6.3.tgz",
9496
+      "integrity": "sha512-wdIGBlcX13tCHOXGMVnnTVFtGRLoP0imqxM696fIPwIf5ODIYUHIvHbZcyvGlZFiFhK5XzDC2lpjbxRhnM05Tg==",
9497
+      "requires": {
9498
+        "deep-equal": "^1.0.1",
9499
+        "extend": "^3.0.2",
9500
+        "fast-diff": "1.1.2"
9501
+      }
9502
+    },
9459 9503
     "randombytes": {
9460 9504
       "version": "2.1.0",
9461 9505
       "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz",
@@ -11898,6 +11942,14 @@
11898 11942
         "trix": "^1.1.1"
11899 11943
       }
11900 11944
     },
11945
+    "vue2-editor": {
11946
+      "version": "2.10.2",
11947
+      "resolved": "https://registry.npmjs.org/vue2-editor/-/vue2-editor-2.10.2.tgz",
11948
+      "integrity": "sha512-sjHTPdRoiB9VK9HLSOjFgubxBWHxRydvykqBCNaX7Sv+2KpdWu6AoyguvP5tyEp4ECX7z6PnbBluyD5M57QOng==",
11949
+      "requires": {
11950
+        "quill": "^1.3.6"
11951
+      }
11952
+    },
11901 11953
     "vuetify": {
11902 11954
       "version": "1.5.16",
11903 11955
       "resolved": "https://registry.npmjs.org/vuetify/-/vuetify-1.5.16.tgz",

+ 1
- 0
package.json ファイルの表示

@@ -28,6 +28,7 @@
28 28
     "vue-excel-export": "^0.1.3",
29 29
     "vue-router": "^3.0.7",
30 30
     "vue-trix": "^1.0.0",
31
+    "vue2-editor": "^2.10.2",
31 32
     "vuetify": "^1.5.5",
32 33
     "vuex": "^3.1.1"
33 34
   },

バイナリ
public/img/no-homes.png ファイルの表示


バイナリ
public/img/propertyListings.png ファイルの表示


+ 63
- 61
src/components/property/propertyCard.vue ファイルの表示

@@ -23,73 +23,75 @@
23 23
     </div>
24 24
     <div class="form-group row">
25 25
       <div class="col-md-4" v-for="currentProperty in properties" :key="currentProperty.id">
26
-        <div class="card-box-a card-shadow">
27
-          <div class="img-box-a">
28
-            <img
29
-              :src="currentProperty.displayImage"
30
-              alt
31
-              class="img-a img-fluid"
32
-              style="height:466px; width:350px; object-fit: cover;"
33
-            />
34
-          </div>
35
-          <div class="card-overlay">
36
-            <div class="card-overlay-a-content">
37
-              <div class="card-header-a">
38
-                <h4 class="card-title-a">
39
-                  <router-link
40
-                    :to="`/property/property/${currentProperty.id}`"
41
-                    class="link-a"
42
-                  >{{ currentProperty.shortDescription }}</router-link>
43
-                </h4>
44
-                <h4 class="card-title-c">
26
+        <router-link :to="`/property/property/${currentProperty.id}`">
27
+          <div class="card-box-a card-shadow">
28
+            <div class="img-box-a">
29
+              <img
30
+                :src="currentProperty.displayImage"
31
+                alt
32
+                class="img-a img-fluid"
33
+                style="height:466px; width:350px; object-fit: cover;"
34
+              />
35
+            </div>
36
+            <div class="card-overlay">
37
+              <div class="card-overlay-a-content">
38
+                <div class="card-header-a">
39
+                  <h4 class="card-title-a">
40
+                    <router-link
41
+                      :to="`/property/property/${currentProperty.id}`"
42
+                      class="link-a"
43
+                    >{{ currentProperty.shortDescription }}</router-link>
44
+                  </h4>
45
+                  <h4 class="card-title-c">
46
+                    <router-link :to="`/property/property/${currentProperty.id}`" class="link-a">
47
+                      {{ currentProperty.province }}
48
+                      <br />
49
+                      {{ currentProperty.city }}
50
+                      <br />
51
+                      {{ currentProperty.suburb }}
52
+                    </router-link>
53
+                  </h4>
54
+                </div>
55
+                <div class="card-body-a">
56
+                  <div class="price-box d-flex">
57
+                    <span
58
+                      v-if="currentProperty.isSale"
59
+                      class="price-a"
60
+                    >sale | {{ currentProperty.displayPrice }}</span>
61
+                    <span
62
+                      v-if="!currentProperty.isSale"
63
+                      class="price-a"
64
+                    >rent | {{ currentProperty.displayPrice }}</span>
65
+                  </div>
45 66
                   <router-link :to="`/property/property/${currentProperty.id}`" class="link-a">
46
-                    {{ currentProperty.province }}
47
-                    <br />
48
-                    {{ currentProperty.city }}
49
-                    <br />
50
-                    {{ currentProperty.suburb }}
67
+                    Click here to view
68
+                    <span class="ion-ios-arrow-forward"></span>
51 69
                   </router-link>
52
-                </h4>
53
-              </div>
54
-              <div class="card-body-a">
55
-                <div class="price-box d-flex">
56
-                  <span
57
-                    v-if="currentProperty.isSale"
58
-                    class="price-a"
59
-                  >sale | {{ currentProperty.displayPrice }}</span>
60
-                  <span
61
-                    v-if="!currentProperty.isSale"
62
-                    class="price-a"
63
-                  >rent | {{ currentProperty.displayPrice }}</span>
64 70
                 </div>
65
-                <router-link :to="`/property/property/${currentProperty.id}`" class="link-a">
66
-                  Click here to view
67
-                  <span class="ion-ios-arrow-forward"></span>
68
-                </router-link>
69
-              </div>
70
-              <div class="card-footer-a" v-if="currentProperty.showFooter">
71
-                <ul class="card-info d-flex justify-content-around">
72
-                  <li v-if="currentProperty.area !== null">
73
-                    <h4 class="card-info-title">Area</h4>
74
-                    <span v-html="currentProperty.area"></span>
75
-                  </li>
76
-                  <li v-if="currentProperty.beds !== null">
77
-                    <h4 class="card-info-title">Beds</h4>
78
-                    <span>{{ currentProperty.beds }}</span>
79
-                  </li>
80
-                  <li v-if="currentProperty.baths !== null">
81
-                    <h4 class="card-info-title">Baths</h4>
82
-                    <span>{{ currentProperty.baths }}</span>
83
-                  </li>
84
-                  <li v-if="currentProperty.garages !== null">
85
-                    <h4 class="card-info-title">Garages</h4>
86
-                    <span>{{ currentProperty.garages }}</span>
87
-                  </li>
88
-                </ul>
71
+                <div class="card-footer-a" v-if="currentProperty.showFooter">
72
+                  <ul class="card-info d-flex justify-content-around">
73
+                    <li v-if="currentProperty.area !== null">
74
+                      <h4 class="card-info-title">Area</h4>
75
+                      <span v-html="currentProperty.area"></span>
76
+                    </li>
77
+                    <li v-if="currentProperty.beds !== null">
78
+                      <h4 class="card-info-title">Beds</h4>
79
+                      <span>{{ currentProperty.beds }}</span>
80
+                    </li>
81
+                    <li v-if="currentProperty.baths !== null">
82
+                      <h4 class="card-info-title">Baths</h4>
83
+                      <span>{{ currentProperty.baths }}</span>
84
+                    </li>
85
+                    <li v-if="currentProperty.garages !== null">
86
+                      <h4 class="card-info-title">Garages</h4>
87
+                      <span>{{ currentProperty.garages }}</span>
88
+                    </li>
89
+                  </ul>
90
+                </div>
89 91
               </div>
90 92
             </div>
91 93
           </div>
92
-        </div>
94
+        </router-link>
93 95
         <br />
94 96
       </div>
95 97
     </div>

+ 1
- 0
src/components/property/propertyImage.vue ファイルの表示

@@ -5,6 +5,7 @@
5 5
         Upload
6 6
         <input
7 7
           type="file"
8
+          accept=".jpeg, .jpg, .gif, .png"
8 9
           value="Upload Photo"
9 10
           style="width: 0px;height: 0px;overflow: hidden;"
10 11
           name="images[]"

+ 30
- 24
src/components/property/propertyList.vue ファイルの表示

@@ -12,15 +12,11 @@
12 12
           <div class="col-md-12 col-lg-8">
13 13
             <div class="title-box-d">
14 14
               <h1
15
-                v-if="user !== 'All'"
15
+                v-if="showAdmin"
16 16
                 class="title-d"
17 17
                 style="text-align:left; font-size: 250%"
18
-              >My {{ propertyType }} Properties</h1>
19
-              <h1
20
-                v-else
21
-                class="title-d"
22
-                style="text-align:left; font-size: 250%"
23
-              >All {{ propertyType }} Properties</h1>
18
+              >Admin Properties</h1>
19
+              <h1 v-else class="title-d" style="text-align:left; font-size: 250%">My Properties</h1>
24 20
             </div>
25 21
           </div>
26 22
         </div>
@@ -35,7 +31,9 @@
35 31
             <th>Property ID</th>
36 32
             <th>Size</th>
37 33
             <th>Price</th>
34
+            <th>Usage Type</th>
38 35
             <th>Type</th>
36
+            <th>Sale Type</th>
39 37
             <th>Publish</th>
40 38
             <th>Status</th>
41 39
             <th></th>
@@ -48,7 +46,9 @@
48 46
             <td>{{ item.id }}</td>
49 47
             <td v-html="item.size" />
50 48
             <td>{{ item.price }}</td>
49
+            <td>{{ item.usageType }}</td>
51 50
             <td>{{ item.type }}</td>
51
+            <td>{{ item.saleType }}</td>
52 52
             <!-- <td>{{ item.publish }}</td> -->
53 53
             <td></td>
54 54
             <td>{{ item.status }}</td>
@@ -58,7 +58,6 @@
58 58
                 @click="Edit(item)"
59 59
                 class="btn btn-b-n"
60 60
                 style="width: 85px; height:40px;"
61
-                disabled
62 61
               >Edit</button>
63 62
             </td>
64 63
             <td>
@@ -86,6 +85,7 @@ export default {
86 85
     return {
87 86
       propertyType: '',
88 87
       user: '',
88
+      showAdmin: false,
89 89
     };
90 90
   },
91 91
   methods: {
@@ -99,18 +99,21 @@ export default {
99 99
     },
100 100
   },
101 101
   mounted() {
102
-    this.propertyType = this.$route.params.propertyType;
103
-    this.user = this.$route.params.user;
104
-
105
-    if (this.user === 'MyListings') {
106
-      this.user = 'GeorgeW';
102
+    if (this.$route.params.by === 'my') {
103
+      // eslint-disable-next-line vue/no-side-effects-in-computed-properties
104
+      this.showAdmin = false;
105
+    } else {
106
+      // eslint-disable-next-line vue/no-side-effects-in-computed-properties
107
+      this.showAdmin = true;
107 108
     }
108 109
 
110
+    this.user = 28; // user id
111
+
109 112
     this.getProperties(
110 113
       Object.assign(
111 114
         {},
112 115
         {
113
-          propertyType: this.propertyType,
116
+          propertyType: this.showAdmin ? 'Admin' : 'My',
114 117
           user: this.user,
115 118
         },
116 119
       ),
@@ -118,26 +121,29 @@ export default {
118 121
   },
119 122
   computed: {
120 123
     ...mapState('propertyList', ['properties']),
121
-    TypeChanged() {
122
-      // eslint-disable-next-line vue/no-side-effects-in-computed-properties
123
-      this.propertyType = this.$route.params.propertyType;
124
-      // eslint-disable-next-line vue/no-side-effects-in-computed-properties
125
-      this.user = this.$route.params.user;
124
+    UserChanged() {
125
+      if (this.$route.params.by === 'my') {
126
+        // eslint-disable-next-line vue/no-side-effects-in-computed-properties
127
+        this.showAdmin = false;
128
+      } else {
129
+        // eslint-disable-next-line vue/no-side-effects-in-computed-properties
130
+        this.showAdmin = true;
131
+      }
126 132
       this.getProperties(
127 133
         Object.assign(
128 134
           {},
129 135
           {
130
-            propertyType: this.$route.params.propertyType,
131
-            user: this.$route.params.user,
136
+            propertyType: this.showAdmin ? 'Admin' : 'My',
137
+            user: this.user,
132 138
           },
133 139
         ),
134 140
       );
135
-      return this.propertyType;
141
+      return this.user;
136 142
     },
137 143
   },
138 144
   watch: {
139
-    TypeChanged() {
140
-      console.log(this.propertyType);
145
+    UserChanged() {
146
+      console.log(this.user);
141 147
     },
142 148
   },
143 149
 };

+ 1
- 1
src/components/property/propertyPage.vue ファイルの表示

@@ -127,7 +127,7 @@
127 127
                             name="MakeOffer"
128 128
                             :isMakeOffer="true"
129 129
                             :isProperty="true"
130
-                            :item="{id: property.id, shortDescription: property.shortDescription, description: property.description, price: property.price}"
130
+                            :item="{id: property.id, shortDescription: property.shortDescription, description: property.description, sellPrice: property.price}"
131 131
                           />
132 132
                         </div>
133 133
                       </div>

+ 26
- 10
src/components/property/propertySearchPage.vue ファイルの表示

@@ -1,6 +1,15 @@
1 1
 <template>
2 2
   <!-- eslint-disable max-len -->
3 3
   <div class="container">
4
+    <br />
5
+    <div class="row">
6
+      <div class="col-md-2 offset-4">
7
+        <button type="button" @click="SetType('Residential')" class="btn btn-b-n">Residential</button>
8
+      </div>
9
+      <div class="col-md-2">
10
+        <button type="button" @click="SetType('Commercial')" class="btn btn-b-n">Commercial</button>
11
+      </div>
12
+    </div>
4 13
     <div class="container col-md-12" v-if="propertySearch.propertyUsageType === 'Residential'">
5 14
       <div class="col-sm-12">
6 15
         <div class="about-img-box">
@@ -38,11 +47,11 @@
38 47
           </p>
39 48
           <p>
40 49
             Wish to RENT your property?
41
-            <router-link to="/property/Residential/Rental">Click Here</router-link>
50
+            <router-link to="/property/new/Residential/Rental">Click Here</router-link>
42 51
           </p>
43 52
           <p>
44 53
             Wish to SELL your property?
45
-            <router-link to="/property/Residential/Sale">Click Here</router-link>
54
+            <router-link to="/property/new/Residential/Sale">Click Here</router-link>
46 55
           </p>
47 56
         </div>
48 57
         <div class="col-md-4">
@@ -59,7 +68,7 @@
59 68
       <div>
60 69
         <propertyCard v-if="properties.length > 0" name="propertyholder" :properties="properties" />
61 70
         <div v-if="properties.length === 0">
62
-          <img src="../../../public/img/no-homes.gif" />
71
+          <img src="../../../public/img/no-homes.png" />
63 72
           <br />
64 73
           <br />
65 74
           <p>Sorry no listing where found matching your search</p>
@@ -103,11 +112,11 @@
103 112
           </p>
104 113
           <p>
105 114
             Wish to RENT your property?
106
-            <router-link to="/property/Commercial/Rental">Click Here</router-link>
115
+            <router-link to="/property/new/Commercial/Rental">Click Here</router-link>
107 116
           </p>
108 117
           <p>
109 118
             Wish to SELL your property?
110
-            <router-link to="/property/Commercial/Sale">Click Here</router-link>
119
+            <router-link to="/property/new/Commercial/Sale">Click Here</router-link>
111 120
           </p>
112 121
         </div>
113 122
         <div class="col-md-4">
@@ -124,7 +133,7 @@
124 133
       <div>
125 134
         <propertyCard v-if="properties.length > 0" name="propertyholder" :properties="properties" />
126 135
         <div v-if="properties.length === 0">
127
-          <img src="../../../public/img/no-homes.gif" />
136
+          <img src="../../../public/img/no-homes.png" />
128 137
           <br />
129 138
           <br />
130 139
           <p>Sorry no listing where found matching your search</p>
@@ -158,16 +167,24 @@ export default {
158 167
       },
159 168
     };
160 169
   },
170
+  mounted() {
171
+    if (typeof this.propertySearch.propertyUsageType === 'undefined') {
172
+      this.propertySearch.propertyUsageType = 'Residential';
173
+    }
174
+  },
161 175
   methods: {
162 176
     ...mapActions('propertySearch', ['searchProperties']),
177
+    SetType(item) {
178
+      this.propertySearch.propertyUsageType = item;
179
+    },
163 180
   },
164 181
   computed: {
165 182
     ...mapState('propertySearch', ['properties']),
166 183
     ParamsChanged() {
167
-      if (Object.keys(this.$route.params).length > 0) {
168
-        if (this.$route.params.propertyUsageType) {
184
+      if (Object.keys(this.$route.query).length === 0) {
185
+        if (this.propertySearch.propertyUsageType === 'All') {
169 186
           // eslint-disable-next-line vue/no-side-effects-in-computed-properties
170
-          this.propertySearch.propertyUsageType = this.$route.params.propertyUsageType;
187
+          this.propertySearch.propertyUsageType = 'Residential';
171 188
           // eslint-disable-next-line vue/no-side-effects-in-computed-properties
172 189
           this.propertySearch.keyword = 'All';
173 190
           // eslint-disable-next-line vue/no-side-effects-in-computed-properties
@@ -193,7 +210,6 @@ export default {
193 210
         // eslint-disable-next-line vue/no-side-effects-in-computed-properties
194 211
         this.propertySearch.keyword = 'All';
195 212
       }
196
-
197 213
       this.searchProperties(this.propertySearch);
198 214
       return null;
199 215
     },

+ 48
- 16
src/components/property/propertyeditPage.vue ファイルの表示

@@ -3,6 +3,7 @@
3 3
   <div>
4 4
     <div class="container">
5 5
       <div class="col-sm-12">
6
+        <br />
6 7
         <div class="tobuy-img-box">
7 8
           <img
8 9
             v-if="propertyType === 'Commercial'"
@@ -34,6 +35,26 @@
34 35
       <div class="row mb-3">
35 36
         <div class="container col-md-10" style="text-align:left">
36 37
           <form id="mainForm">
38
+            <div class="form-goup row">
39
+              <div class="col-md-4">
40
+                <label>Usage Type</label>
41
+                <div class="input-group-prepend">
42
+                  <span class="input-group-text" style="color: #60CBEB">
43
+                    <b>U</b>
44
+                  </span>
45
+                  <select
46
+                    class="form-control"
47
+                    name="propertyUsageType"
48
+                    id="propertyUsageType"
49
+                    v-model="propertyType"
50
+                    @change="TypeChanged"
51
+                  >
52
+                    <option value="Residential">Residential</option>
53
+                    <option value="Commercial">Commercial</option>
54
+                  </select>
55
+                </div>
56
+              </div>
57
+            </div>
37 58
             <div class="form-group row">
38 59
               <div class="col-md-4">
39 60
                 <label>Property Type</label>
@@ -240,12 +261,7 @@
240 261
             <div class="form-group row">
241 262
               <div class="col-md-12">
242 263
                 <label for="Property Description">Description</label>
243
-                <TextEditor
244
-                  name="description"
245
-                  v-model="property.description"
246
-                  id="description"
247
-                  style="text-align:left"
248
-                />
264
+                <vue-editor v-model="property.description" :editor-toolbar="customToolbar" />
249 265
                 <br />
250 266
                 <p>* A listing fee of R380 including VAT is payable to list your Property on the Uni-Vate website</p>
251 267
               </div>
@@ -258,7 +274,7 @@
258 274
               :id="1"
259 275
             ></UserField>
260 276
             <div class="form-group row" />
261
-            <div v-for="(item, i) in propertyFields" :key="item.id">
277
+            <div v-for="item in propertyFields" :key="item.id">
262 278
               <div class="row">
263 279
                 <div class="col-sm-12">
264 280
                   <div class="title-box-d">
@@ -302,7 +318,7 @@
302 318
 
303 319
 <script>
304 320
 import { mapState, mapActions } from 'vuex';
305
-import TextEditor from 'vue-trix';
321
+import { VueEditor } from 'vue2-editor';
306 322
 import { setTimeout } from 'timers';
307 323
 import UserField from './propertyUserField.vue';
308 324
 import ImageLoad from './propertyImage.vue';
@@ -312,7 +328,7 @@ export default {
312 328
   components: {
313 329
     UserField,
314 330
     ImageLoad,
315
-    TextEditor,
331
+    VueEditor,
316 332
   },
317 333
   data() {
318 334
     return {
@@ -324,6 +340,19 @@ export default {
324 340
       propertyFieldValues: [],
325 341
       defaultImage: 0,
326 342
       wait: false,
343
+      customToolbar: [
344
+        [{ header: [false, 1, 2, 3, 4, 5, 6] }],
345
+        ['bold', 'italic', 'underline', 'strike'],
346
+        [
347
+          { align: '' },
348
+          { align: 'center' },
349
+          { align: 'right' },
350
+          { align: 'justify' },
351
+        ],
352
+        [{ list: 'ordered' }, { list: 'bullet' }, { list: 'check' }],
353
+        [{ script: 'sub' }, { script: 'super' }],
354
+        [{ indent: '-1' }, { indent: '+1' }],
355
+      ],
327 356
     };
328 357
   },
329 358
   methods: {
@@ -342,6 +371,7 @@ export default {
342 371
       'getPropertySavedFields',
343 372
       'getSavedPropertyData',
344 373
     ]),
374
+    TypeChanged() {},
345 375
     SubmitData() {
346 376
       this.wait = true;
347 377
       if (this.salesType === 'Sale') {
@@ -363,7 +393,7 @@ export default {
363 393
 
364 394
       setTimeout(
365 395
         () => this.$router.push({
366
-            path: '/property/search',
396
+            path: '/property/Search',
367 397
             query: {
368 398
               salesType: this.salesType,
369 399
               propertyUsageType: this.propertyType,
@@ -434,10 +464,12 @@ export default {
434 464
       this.property.description = '';
435 465
     }
436 466
 
437
-    this.propertyType = this.$route.params.propType;
467
+    if (this.$route.params.propertyUsageType) {
468
+      this.propertyType = this.$route.params.propertyUsageType;
469
+    }
438 470
     this.salesType = this.$route.params.saleType;
439 471
 
440
-    this.getPropertyTypes(this.$route.params.propType);
472
+    this.getPropertyTypes(this.propertyType);
441 473
 
442 474
     this.getProvince();
443 475
     if (this.$route.query.id) {
@@ -447,7 +479,7 @@ export default {
447 479
       );
448 480
     } else {
449 481
       this.getPropertyOverviewFields();
450
-      this.getPropertyFields(this.$route.params.propType);
482
+      this.getPropertyFields(this.propertyType);
451 483
     }
452 484
     // if (this.$route.params.id) {
453 485
     //   this.getPropertyEditDisplay(4); // (this.$route.params.id);
@@ -483,12 +515,12 @@ export default {
483 515
     ]),
484 516
     SalesTypeChanged() {
485 517
       // eslint-disable-next-line vue/no-side-effects-in-computed-properties
486
-      this.propertyType = this.$route.params.propType;
518
+      // this.propertyType = this.$route.params.propType;
487 519
       // eslint-disable-next-line vue/no-side-effects-in-computed-properties
488 520
       this.salesType = this.$route.params.saleType;
489 521
       if (!this.$route.query.id) {
490
-        this.getPropertyTypes(this.$route.params.propType);
491
-        this.getPropertyFields(this.$route.params.propType);
522
+        this.getPropertyTypes(this.propertyType);
523
+        this.getPropertyFields(this.propertyType);
492 524
       }
493 525
 
494 526
       return this.propertyType;

+ 20
- 28
src/components/shared/navBar.vue ファイルの表示

@@ -81,41 +81,22 @@
81 81
               <div class="dropdown-menu" aria-labelledby="navbarDropdown">
82 82
                 <a
83 83
                   class="dropdown-item cursor-pointer"
84
-                  @click="routerGoTo('/property/Commercial/Search')"
85
-                >Search Commercial Properties</a>
84
+                  @click="routerGoTo('/property/Search')"
85
+                >Search</a>
86 86
                 <a
87 87
                   class="dropdown-item cursor-pointer"
88
-                  @click="routerGoTo('/property/Commercial/Sale')"
89
-                >To Sell Commercial Properties</a>
90
-                <a
91
-                  class="dropdown-item cursor-pointer"
92
-                  @click="routerGoTo('/property/Commercial/Rental')"
93
-                >To Rent Commercial Properties</a>
94
-                <hr />
95
-
96
-                <a
97
-                  class="dropdown-item cursor-pointer"
98
-                  @click="routerGoTo('/property/Residential/Search')"
99
-                >Search Residential Properties</a>
100
-                <a
101
-                  class="dropdown-item cursor-pointer"
102
-                  @click="routerGoTo('/property/Residential/Sale')"
103
-                >To Sell Residential Properties</a>
88
+                  @click="routerGoTo('/property/new/Sale')"
89
+                >To Sell</a>
104 90
                 <a
105 91
                   class="dropdown-item cursor-pointer"
106
-                  @click="routerGoTo('/property/Residential/Rental')"
107
-                >To Rent Residential Properties</a>
108
-                <hr v-if="isLoggedIn" />
92
+                  @click="routerGoTo('/property/new/Rental')"
93
+                >To Rent</a>
94
+                <hr v-if="showLogout" />
109 95
                 <a
110 96
                   v-if="isLoggedIn"
111 97
                   class="dropdown-item cursor-pointer"
112
-                  @click="routerGoTo('/property/list/Commercial/MyListings')"
113
-                >My Commercial Properties</a>
114
-                <a
115
-                  v-if="isLoggedIn"
116
-                  class="dropdown-item cursor-pointer"
117
-                  @click="routerGoTo('/property/list/Residential/MyListings')"
118
-                >My Residential Properties</a>
98
+                  @click="routerGoTo('/property/admin/list/my')"
99
+                >My Properties</a>
119 100
               </div>
120 101
             </li>
121 102
 
@@ -185,6 +166,17 @@
185 166
                 <a class="dropdown-item cursor-pointer" @click="routerGoTo('/Offers')">Offers</a>
186 167
               </div>
187 168
             </li>
169
+            <li v-if="isLoggedIn">
170
+              <a
171
+                class="nav-link"
172
+                @click="routerGoTo('/user/updateProfileInfo')"
173
+                id="navbarDropdown"
174
+                role="button"
175
+                data-toggle="dropdown"
176
+                aria-haspopup="true"
177
+                aria-expanded="false"
178
+              >Update Profile</a>
179
+            </li>
188 180
             <li class="nav-item dropdown" v-if="!isLoggedIn">
189 181
               <a
190 182
                 class="nav-link"

+ 4
- 0
src/components/timeshare/resort/resortImage.vue ファイルの表示

@@ -55,6 +55,10 @@ export default {
55 55
   padding-left: 15px;
56 56
   padding-right: 15px;
57 57
 }
58
+.nopadding {
59
+  margin: 0px;
60
+  padding: 0px;
61
+}
58 62
 .main-image {
59 63
   max-width: 80%;
60 64
   max-height: 412px;

+ 1
- 1
src/components/user/registerPage.vue ファイルの表示

@@ -119,7 +119,7 @@
119 119
                   class="form-control"
120 120
                   :type="isPasswordShown"
121 121
                   v-model="registerIndividual.password"
122
-                  id="password"
122
+                  id="confirmpassword"
123 123
                   placeholder="Confirm Password"
124 124
                   name="confirmpassword"
125 125
                   value

+ 71
- 0
src/components/user/updateProfileInfo.vue ファイルの表示

@@ -0,0 +1,71 @@
1
+<template>
2
+  <!-- eslint-disable max-len -->
3
+  <div class="container">
4
+    <br />
5
+    <div class="row">
6
+      <div class="col-md-12 col-lg-8">
7
+        <div class="title-box-d">
8
+          <h1 class="title-d" style="text-align:left; font-size: 250%">Update Profile Info</h1>
9
+        </div>
10
+      </div>
11
+    </div>
12
+    <div class="container">
13
+      <table class="table table-bordered">
14
+        <thead>
15
+          <tr>
16
+            <th>ID</th>
17
+            <th>Name</th>
18
+            <th>Surname</th>
19
+            <th>Cell Number</th>
20
+            <th>Telephone Number</th>
21
+            <th>Email</th>
22
+            <th>Role</th>
23
+            <th></th>
24
+          </tr>
25
+        </thead>
26
+        <tbody>
27
+          <tr v-for="(item, i) in individuals" :key="i">
28
+            <td>{{ item.id }}</td>
29
+            <td>{{ item.name }}</td>
30
+            <td>{{ item.surname }}</td>
31
+            <td>{{ item.cellNumber }}</td>
32
+            <td>{{ item.telephone }}</td>
33
+            <td>{{ item.email }}</td>
34
+            <td v-if="item.user">{{ item.user.role }}</td>
35
+            <td v-else></td>
36
+            <td>
37
+              <button
38
+                type="button"
39
+                @click="Edit(item)"
40
+                class="btn btn-b-n"
41
+                style="width: 85px; height:40px;"
42
+              >Edit</button>
43
+            </td>
44
+          </tr>
45
+        </tbody>
46
+      </table>
47
+    </div>
48
+    <br />
49
+  </div>
50
+</template>
51
+
52
+<script>
53
+import { mapState, mapActions } from 'vuex';
54
+// import axios from 'axios';
55
+
56
+export default {
57
+  name: 'UpdateInfo',
58
+  data() {
59
+    return {};
60
+  },
61
+  methods: {
62
+    ...mapActions('registerIndividual', ['getIndividuals']),
63
+  },
64
+  mounted() {
65
+    this.getIndividuals();
66
+  },
67
+  computed: {
68
+    ...mapState('registerIndividual', ['individuals']),
69
+  },
70
+};
71
+</script>

+ 10
- 4
src/router/index.js ファイルの表示

@@ -13,6 +13,7 @@ import MyWeeksPage from '../components/timeshare/myWeeksPage.vue';
13 13
 import Login from '../components/user/loginPage.vue';
14 14
 import PrivateIndividual from '../components/user/registerPage.vue';
15 15
 import Agency from '../components/user/registerAgencySection.vue';
16
+import UpdateInfo from '../components/user/updateProfileInfo.vue';
16 17
 
17 18
 import PropertySearch from '../components/property/propertySearchPage.vue';
18 19
 import PropertyPage from '../components/property/propertyPage.vue';
@@ -48,8 +49,8 @@ import TemplatePage from '../components/communication/templatePage.vue';
48 49
 
49 50
 Vue.use(Router);
50 51
 
51
-
52 52
 export default new Router({
53
+  // eslint-disable-next-line no-unused-vars
53 54
   scrollBehavior(to, from, savedPosition) {
54 55
     return {
55 56
       x: 0,
@@ -127,18 +128,23 @@ export default new Router({
127 128
     component: PropertySearch,
128 129
   },
129 130
   {
130
-    path: '/property/:propType/:saleType',
131
+    path: '/property/new/:saleType',
131 132
     name: 'PropertyNew',
132 133
     component: PropertyEdit,
133 134
   },
135
+  {
136
+    path: '/property/new/:propertyUsageType/:saleType',
137
+    name: 'PropertyNewFromSearch',
138
+    component: PropertyEdit,
139
+  },
134 140
   {
135 141
     path: '/property/edit/:id/:propType/:saleType',
136 142
     name: 'PropertyEdit',
137 143
     component: PropertyEdit,
138 144
   },
139 145
   {
140
-    path: '/property/list/:propertyType/:user',
141
-    name: 'PropertyList',
146
+    path: '/property/admin/list/:by',
147
+    name: 'PropertyListAdmin',
142 148
     component: PropertyList,
143 149
   },
144 150
   {

+ 2
- 1
src/store/modules/property/propertyLists.js ファイルの表示

@@ -13,8 +13,9 @@ export default {
13 13
   getters: {},
14 14
   actions: {
15 15
     getProperties({ commit }, item) {
16
+      console.log(`/api/property/${item.propertyType}/${item.user}`);
16 17
       axios
17
-        .get(`/api/property/${item.propertyType}/All`) // .get(`/api/property/${item.propertyType}/${item.user}`)
18
+        .get(`/api/property/${item.propertyType}/${item.user}`) // .get(`/api/property/${item.propertyType}/${item.user}`)
18 19
         .then(result => commit('setProperties', result.data))
19 20
         .catch(console.error);
20 21
     },

+ 0
- 56
src/store/modules/property/propertySearch.js ファイルの表示

@@ -35,62 +35,6 @@ export default {
35 35
       state.propertySearch[filter] = 'All';
36 36
     },
37 37
   },
38
-  // getters: {
39
-  //   filterProperties: (state) => {
40
-  //     let list = state.properties;
41
-  //     const { propertySearch } = state;
42
-  //     if (propertySearch) {
43
-  //       if (propertySearch.salesType === 'Sale') {
44
-  //         list = _.filter(list, x => x.isSale);
45
-  //       } else {
46
-  //         list = _.filter(list, x => !x.isSale);
47
-  //       }
48
-  //       if (propertySearch.propertyUsageType && propertySearch.propertyUsageType !== 'All') {
49
-  //         list = _.filter(list, x => x.propertyUsageType
50
-  //             .toUpperCase()
51
-  //             // eslint-disable-next-line comma-dangle
52
-  //             .includes(propertySearch.propertyUsageType.toUpperCase()));
53
-  //       }
54
-  //       if (propertySearch.propertyType && propertySearch.propertyType !== 'All') {
55
-  //         list = _.filter(list, x => x.propertyType
56
-  //             .toUpperCase()
57
-  //             // eslint-disable-next-line comma-dangle
58
-  //             .includes(propertySearch.propertyType.toUpperCase()));
59
-  //       }
60
-  //       if (propertySearch.province && propertySearch.province !== 'All') {
61
-  //         list = _.filter(list, x => x.province
62
-  //             .toUpperCase()
63
-  //             // eslint-disable-next-line comma-dangle
64
-  //             .includes(propertySearch.province.toUpperCase()));
65
-  //       }
66
-  //       if (propertySearch.city && propertySearch.city !== 'All') {
67
-  //         list = _.filter(list, x => x.city
68
-  //             .toUpperCase()
69
-  //             // eslint-disable-next-line comma-dangle
70
-  //             .includes(propertySearch.city.toUpperCase()));
71
-  //       }
72
-  //       if (propertySearch.suburb && propertySearch.suburb !== 'All') {
73
-  //         list = _.filter(list, x => x.suburb
74
-  //             .toUpperCase()
75
-  //             // eslint-disable-next-line comma-dangle
76
-  //             .includes(propertySearch.suburb.toUpperCase()));
77
-  //       }
78
-  //       if (propertySearch.suburb && propertySearch.suburb !== 'All') {
79
-  //         list = _.filter(list, x => x.suburb
80
-  //             .toUpperCase()
81
-  //             // eslint-disable-next-line comma-dangle
82
-  //             .includes(propertySearch.suburb.toUpperCase()));
83
-  //       }
84
-  //       if (propertySearch.minPrice) {
85
-  //         list = _.filter(list, x => x.price >= propertySearch.minPrice);
86
-  //       }
87
-  //       if (propertySearch.maxPrice) {
88
-  //         list = _.filter(list, x => x.price <= propertySearch.maxPrice);
89
-  //       }
90
-  //     }
91
-  //     return list;
92
-  //   },
93
-  // },
94 38
   actions: {
95 39
     clearFilter({ commit }, filter) {
96 40
       commit('onClearFilter', filter);

読み込み中…
キャンセル
保存