1
0
mirror of https://github.com/axllent/mailpit.git synced 2025-07-03 00:46:58 +02:00

Chore: Apply linting to all JavaScript/Vue files with eslint & prettier

This commit is contained in:
Ralph Slooten
2025-06-20 23:26:06 +12:00
parent 7dee371721
commit 3fff79e29f
45 changed files with 8690 additions and 3458 deletions

View File

@ -1,135 +1,142 @@
<script>
import { mailbox } from '../stores/mailbox'
import CommonMixins from '../mixins/CommonMixins'
import dayjs from 'dayjs'
import { mailbox } from "../stores/mailbox";
import CommonMixins from "../mixins/CommonMixins";
import dayjs from "dayjs";
import { pagination } from "../stores/pagination";
export default {
mixins: [
CommonMixins
],
mixins: [CommonMixins],
props: {
loadingMessages: Number, // use different name to `loading` as that is already in use in CommonMixins
// use different name to `loading` as that is already in use in CommonMixins
loadingMessages: {
type: Number,
default: 0,
},
},
data() {
return {
mailbox,
pagination,
}
};
},
created() {
const relativeTime = require('dayjs/plugin/relativeTime')
dayjs.extend(relativeTime)
const relativeTime = require("dayjs/plugin/relativeTime");
dayjs.extend(relativeTime);
},
mounted() {
this.refreshUI()
this.refreshUI();
},
methods: {
refreshUI() {
window.setTimeout(() => {
this.$forceUpdate()
this.refreshUI()
}, 30000)
this.$forceUpdate();
this.refreshUI();
}, 30000);
},
getRelativeCreated(message) {
const d = new Date(message.Created)
return dayjs(d).fromNow()
const d = new Date(message.Created);
return dayjs(d).fromNow();
},
getPrimaryEmailTo(message) {
for (let i in message.To) {
return message.To[i].Address
if (message.To && message.To.length > 0) {
return message.To[0].Address;
}
return '[ Undisclosed recipients ]'
return "[ Undisclosed recipients ]";
},
isSelected(id) {
return mailbox.selected.indexOf(id) != -1
return mailbox.selected.indexOf(id) !== -1;
},
toggleSelected(e, id) {
e.preventDefault()
e.preventDefault();
if (this.isSelected(id)) {
mailbox.selected = mailbox.selected.filter(function (ele) {
return ele != id
})
mailbox.selected = mailbox.selected.filter((ele) => {
return ele !== id;
});
} else {
mailbox.selected.push(id)
mailbox.selected.push(id);
}
},
selectRange(e, id) {
e.preventDefault()
e.preventDefault();
let selecting = false
let lastSelected = mailbox.selected.length > 0 && mailbox.selected[mailbox.selected.length - 1]
if (lastSelected == id) {
mailbox.selected = mailbox.selected.filter(function (ele) {
return ele != id
})
return
let selecting = false;
const lastSelected = mailbox.selected.length > 0 && mailbox.selected[mailbox.selected.length - 1];
if (lastSelected === id) {
mailbox.selected = mailbox.selected.filter((ele) => {
return ele !== id;
});
return;
}
if (lastSelected === false) {
mailbox.selected.push(id)
return
mailbox.selected.push(id);
return;
}
for (let d of mailbox.messages) {
for (const d of mailbox.messages) {
if (selecting) {
if (!this.isSelected(d.ID)) {
mailbox.selected.push(d.ID)
mailbox.selected.push(d.ID);
}
if (d.ID == lastSelected || d.ID == id) {
if (d.ID === lastSelected || d.ID === id) {
// reached backwards select
break
break;
}
} else if (d.ID == id || d.ID == lastSelected) {
} else if (d.ID === id || d.ID === lastSelected) {
if (!this.isSelected(d.ID)) {
mailbox.selected.push(d.ID)
mailbox.selected.push(d.ID);
}
selecting = true
selecting = true;
}
}
},
toTagUrl(t) {
if (t.match(/ /)) {
t = `"${t}"`
t = `"${t}"`;
}
const p = {
q: 'tag:' + t
q: "tag:" + t,
};
if (pagination.limit !== pagination.defaultLimit) {
p.limit = pagination.limit.toString();
}
if (pagination.limit != pagination.defaultLimit) {
p.limit = pagination.limit.toString()
}
const params = new URLSearchParams(p)
return '/search?' + params.toString()
const params = new URLSearchParams(p);
return "/search?" + params.toString();
},
}
}
},
};
</script>
<template>
<template v-if="mailbox.messages && mailbox.messages.length">
<div class="list-group my-2">
<RouterLink v-for="message in mailbox.messages" :to="'/view/' + message.ID" :key="message.ID"
<RouterLink
v-for="message in mailbox.messages"
:id="message.ID"
:key="'message_' + message.ID"
:to="'/view/' + message.ID"
class="row gx-1 message d-flex small list-group-item list-group-item-action border-start-0 border-end-0"
:class="message.Read ? 'read' : '', isSelected(message.ID) ? 'selected' : ''"
@click.meta="toggleSelected($event, message.ID)" @click.ctrl="toggleSelected($event, message.ID)"
@click.shift="selectRange($event, message.ID)">
:class="[message.Read ? 'read' : '', isSelected(message.ID) ? ' selected' : '']"
@click.meta="toggleSelected($event, message.ID)"
@click.ctrl="toggleSelected($event, message.ID)"
@click.shift="selectRange($event, message.ID)"
>
<div class="col-lg-3">
<div class="d-lg-none float-end text-muted text-nowrap small">
<i class="bi bi-paperclip h6 me-1" v-if="message.Attachments"></i>
<i v-if="message.Attachments" class="bi bi-paperclip h6 me-1"></i>
{{ getRelativeCreated(message) }}
</div>
<div v-if="message.From" class="overflow-x-hidden">
@ -142,30 +149,37 @@ export default {
<div class="overflow-x-hidden">
<div class="text-truncate text-muted small privacy">
To: {{ getPrimaryEmailTo(message) }}
<span v-if="message.To && message.To.length > 1">
[+{{ message.To.length - 1 }}]
</span>
<span v-if="message.To && message.To.length > 1"> [+{{ message.To.length - 1 }}] </span>
</div>
</div>
</div>
<div class="col-lg-6 col-xxl-7 mt-2 mt-lg-0">
<div class="subject text-truncate text-spaces-nowrap">
<b>{{ message.Subject != "" ? message.Subject : "[ no subject ]" }}</b>
<b>{{ message.Subject !== "" ? message.Subject : "[ no subject ]" }}</b>
</div>
<div v-if="message.Snippet != ''" class="small text-muted text-truncate">
<div v-if="message.Snippet !== ''" class="small text-muted text-truncate">
{{ message.Snippet }}
</div>
<div v-if="message.Tags.length">
<RouterLink class="badge me-1" v-for="t in message.Tags" :to="toTagUrl(t)"
v-on:click="pagination.start = 0"
:style="mailbox.showTagColors ? { backgroundColor: colorHash(t) } : { backgroundColor: '#6c757d' }"
:title="'Filter messages tagged with ' + t">
<RouterLink
v-for="t in message.Tags"
:key="t"
class="badge me-1"
:to="toTagUrl(t)"
:style="
mailbox.showTagColors
? { backgroundColor: colorHash(t) }
: { backgroundColor: '#6c757d' }
"
:title="'Filter messages tagged with ' + t"
@click="pagination.start = 0"
>
{{ t }}
</RouterLink>
</div>
</div>
<div class="d-none d-lg-block col-1 small text-end text-muted">
<i class="bi bi-paperclip float-start h6" v-if="message.Attachments"></i>
<i v-if="message.Attachments" class="bi bi-paperclip float-start h6"></i>
{{ getFileSize(message.Size) }}
</div>
<div class="d-none d-lg-block col-2 col-xxl-1 small text-end text-muted">
@ -176,10 +190,10 @@ export default {
</template>
<template v-else>
<p class="text-center mt-5">
<span v-if="loadingMessages > 0" class="text-muted">
Loading messages...
</span>
<template v-else-if="getSearch()">No results for <code>{{ getSearch() }}</code></template>
<span v-if="loadingMessages > 0" class="text-muted"> Loading messages... </span>
<template v-else-if="getSearch()"
>No results for <code>{{ getSearch() }}</code></template
>
<template v-else>No messages in your mailbox</template>
</p>
</template>