فهرست منبع

Better alert handling

Pitu 6 سال پیش
والد
کامیت
a7c1855ce5
1فایلهای تغییر یافته به همراه18 افزوده شده و 19 حذف شده
  1. 18 19
      src/site/layouts/default.vue

+ 18 - 19
src/site/layouts/default.vue

@@ -2,38 +2,37 @@
 	<nuxt />
 </template>
 <script>
-import Vue from 'vue';
 export default {
 	computed: {
 		config() {
 			return this.$store.state.config;
+		},
+		alert() {
+			return this.$store.state.alert;
 		}
 	},
-	mounted() {
-		console.log(`%c lolisafe %c v${this.config.version} %c`, 'background:#35495e ; padding: 1px; border-radius: 3px 0 0 3px;  color: #fff', 'background:#ff015b; padding: 1px; border-radius: 0 3px 3px 0;  color: #fff', 'background:transparent');
-	},
-	created() {
-		Vue.prototype.$onPromiseError = (error, logout = false) => {
-			if (error.response && error.response.data && error.response.data.message) {
-				this.$showToast(error.response.data.message, true, 5000);
-			} else {
-				console.error(error);
-				this.$showToast('Something went wrong, please check the console :(', true, 5000);
-			}
-		};
+	watch: {
+		alert() {
+			if (!this.alert) return;
 
-		Vue.prototype.$showToast = (text, error, duration) => {
 			this.$toast.open({
-				duration: duration || 2500,
-				message: text,
+				duration: 3500,
+				message: this.alert.text,
 				position: 'is-bottom',
-				type: error ? 'is-danger' : 'is-success'
+				type: this.alert.error ? 'is-danger' : 'is-success'
 			});
-		};
+
+			setTimeout(() => {
+				this.$store.dispatch('alert', null);
+			}, 3500);
+		}
+	},
+	mounted() {
+		console.log(`%c lolisafe %c v${this.config.version} %c`, 'background:#35495e ; padding: 1px; border-radius: 3px 0 0 3px;  color: #fff', 'background:#ff015b; padding: 1px; border-radius: 0 3px 3px 0;  color: #fff', 'background:transparent');
 	}
 };
 </script>
 <style lang="scss">
 	@import "~/assets/styles/style.scss";
-	@import "~assets/styles/icons.min.css";
+	@import "~/assets/styles/icons.min.css";
 </style>