add checks and lint fixes

This commit is contained in:
Jiiks 2018-08-29 23:02:41 +03:00
parent cff425f916
commit ddda5b3cc1
5 changed files with 44 additions and 12 deletions

View File

@ -36,5 +36,5 @@ export default new class TwentyFourHour extends BuiltinModule {
if (matched[3] === 'AM') return returnValue.replace(matched[0], `${matched[1] === '12' ? '00' : matched[1].padStart(2, '0')}:${matched[2]}`)
return returnValue.replace(matched[0], `${parseInt(matched[1]) + 12}:${matched[2]}`)
}
}

View File

@ -3,6 +3,7 @@ import asar from 'asar';
import { Modals } from 'ui';
import { Utils } from 'common';
import PluginManager from './pluginmanager';
export default class extends EventListener {
@ -46,7 +47,7 @@ export default class extends EventListener {
];
*/
// Show install modal
const modalResult = await Modals.installModal(`Install BetterDiscord ${isPlugin ? 'Plugin' : 'Theme'}`, config).promise;
const modalResult = await Modals.installModal(isPlugin ? 'plugin' : 'theme', config).promise;
if (modalResult === 0) {
// Upload it instead

View File

@ -23,7 +23,7 @@
}
.bd-installModalIcon {
background: url();
background: url('');
background-size: 100% 100%;
flex-shrink: 0;
width: 100px;
@ -70,7 +70,7 @@
.bd-permScope {
&:last-child {
.bd-permInner {
border: none;
border: 0;
}
}
}
@ -84,12 +84,16 @@
padding: 10px;
background: rgba(0, 0, 0, .1);
.bd-installModalStatus {
color: #fff;
font-weight: 600;
}
.bd-button {
font-size: 16px;
padding: 10px;
border-radius: 3px;
min-width: 100px;
background: #fff;
background: #3ecc9c;
transition: opacity .2s ease-in-out;

View File

@ -27,25 +27,52 @@
</div>
</div>
</div>
<div slot="footer" class="bd-installModalFooter">
<div v-if="verifying" slot="footer" class="bd-installModalFooter">
<span class="bd-installModalStatus">Verifying {{this.modal.contentType}}</span>
</div>
<div v-else-if="alreadyInstalled && upToDate" slot="footer" class="bd-installModalFooter">
<span class="bd-installModalStatus">Up to date version already installed!</span>
</div>
<div v-else slot="footer" class="bd-installModalFooter">
<div class="bd-button bd-ok" @click="modal.confirm(0); modal.close();">Upload</div>
<div class="bd-button bd-ok" @click="modal.confirm(); modal.close();">Install</div>
<div class="bd-button bd-ok" @click="modal.confirm(); modal.close();">{{ !alreadyInstalled ? 'Install' : 'Update' }}</div>
</div>
</Modal>
</template>
<script>
// Imports
import { Modal, MiExtension } from '../../common';
import { PluginManager, ThemeManager } from 'modules';
export default {
data() {
return {
installing: false
installing: false,
verifying: true,
alreadyInstalled: false,
upToDate: true
}
},
props: ['modal'],
components: {
Modal, MiExtension
},
mounted() {
const { contentType, config } = this.modal;
const alreadyInstalled = contentType === 'plugin' ? PluginManager.getPluginById(config.info.id) : ThemeManager.getContentById(config.info.id);
if (alreadyInstalled) {
this.alreadyInstalled = true;
if (config.version > alreadyInstalled.version) {
this.upDoDate = false;
}
}
// TODO Verify
setTimeout(() => {
this.verifying = false;
}, 2000);
}
}
</script>

View File

@ -191,12 +191,12 @@ export default class Modals {
return new Modal(modal, InputModal);
}
static installModal(title, config) {
return this.add(this.createInstallModal(title, config));
static installModal(contentType, config) {
return this.add(this.createInstallModal(contentType, config));
}
static createInstallModal(title, config) {
const modal = { title, config };
static createInstallModal(contentType, config) {
const modal = { contentType, config };
modal.promise = new Promise((resolve, reject) => {
modal.confirm = value => resolve(value);
modal.beforeClose = () => reject();