This commit is contained in:
Samuel Elliott 2018-07-19 22:21:20 +01:00
parent 007637a557
commit a95b97b3c0
No known key found for this signature in database
GPG Key ID: 8420C7CDE43DC4D6
7 changed files with 51 additions and 43 deletions

View File

@ -324,6 +324,15 @@ export default class PluginApi {
showWarningToast(message, options = {}) {
return Toasts.warning(message, options);
}
get Toasts() {
return {
push: this.showToast.bind(this),
success: this.showSuccessToast.bind(this),
error: this.showErrorToast.bind(this),
info: this.showInfoToast.bind(this),
warning: this.showWarningToast.bind(this)
};
}
/**

View File

@ -1,4 +1,4 @@
bd-toasts {
.bd-toasts {
display: flex;
position: fixed;
top: 0;
@ -25,7 +25,6 @@ bd-toasts {
font-size: 14px;
margin-top: 10px;
&.bd-toast-error {
background: #f04747;
}

View File

@ -43,11 +43,11 @@ export default class {
static injectUi() {
DOM.createElement('div', null, 'bd-settings').appendTo(DOM.bdBody);
DOM.createElement('div', null, 'bd-modals').appendTo(DOM.bdModals);
DOM.createElement('div', null, 'bd-toasts').appendTo(DOM.bdToasts);
DOM.createElement('bd-tooltips').appendTo(DOM.bdBody);
DOM.createElement('bd-toasts').appendTo(DOM.bdBody);
const toasts = new Vue({
el: 'bd-toasts',
this.toasts = new Vue({
el: '#bd-toasts',
components: { BdToasts },
template: '<BdToasts />'
});

View File

@ -1,5 +1,5 @@
/**
* BetterDiscord Modals Component
* BetterDiscord Toasts Component
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
@ -9,9 +9,9 @@
*/
<template>
<bd-toasts>
<div class="bd-toasts">
<Toast v-for="(toast, index) in toasts" :message="toast.message" :type="toast.type" :icon="toast.icon" :closing="toast.closing" :key="`${toast.id}`"></Toast>
</bd-toasts>
</div>
</template>
<script>
// Imports

View File

@ -1,5 +1,5 @@
/**
* BetterDiscord Modal Component
* BetterDiscord Toast Component
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
@ -9,7 +9,7 @@
*/
<template>
<div :class="['bd-toast', {'bd-toast-has-icon': type != 'basic' || icon}, 'bd-toast-' + type, {'bd-toast-closing': closing}]">
<div :class="['bd-toast', 'bd-toast-' + type, {'bd-toast-has-icon': type != 'basic' || icon, 'bd-toast-closing': closing}]">
<div class="bd-toast-icon" v-if="type != 'basic' || icon">
<img v-if="icon" :src="icon" width="20" height="20" />
<MiSuccess v-else-if="type == 'success'" size="20" />
@ -32,7 +32,7 @@
message: String,
icon: String,
type: {
default: "basic",
default: 'basic',
validator: function (value) {
return ['success', 'warning', 'error', 'info', 'basic'].indexOf(value) !== -1
}

View File

@ -1,5 +1,5 @@
/**
* BetterDiscord Modals
* BetterDiscord Toasts
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
@ -21,7 +21,7 @@ export default class Toasts {
* @returns {Promise} This promise resolves when the toast is removed from the DOM.
*/
static async push(message, options = {}) {
const {type = "basic", icon, timeout = 3000} = options;
const {type = 'basic', icon, timeout = 3000} = options;
const toast = {id: Math.random(), message, type, icon, closing: false};
this.stack.push(toast);
await new Promise(resolve => setTimeout(resolve, timeout));
@ -34,7 +34,7 @@ export default class Toasts {
* This is a shortcut for `type = "success"` in {@link Toasts#push}. The parameters and options are the same.
*/
static async success(message, options = {}) {
options.type = "success";
options.type = 'success';
return this.push(message, options);
}
@ -42,7 +42,7 @@ export default class Toasts {
* This is a shortcut for `type = "error"` in {@link Toasts#push}. The parameters and options are the same.
*/
static async error(message, options = {}) {
options.type = "error";
options.type = 'error';
return this.push(message, options);
}
@ -50,7 +50,7 @@ export default class Toasts {
* This is a shortcut for `type = "info"` in {@link Toasts#push}. The parameters and options are the same.
*/
static async info(message, options = {}) {
options.type = "info";
options.type = 'info';
return this.push(message, options);
}
@ -58,7 +58,7 @@ export default class Toasts {
* This is a shortcut for `type = "warning"` in {@link Toasts#push}. The parameters and options are the same.
*/
static async warning(message, options = {}) {
options.type = "warning";
options.type = 'warning';
return this.push(message, options);
}