uptime-kuma/src/components/PublicGroupList.vue

153 lines
4.4 KiB
Vue
Raw Normal View History

2021-09-13 11:21:39 +00:00
<template>
<!-- Group List -->
<Draggable
v-model="$root.publicGroupList"
:disabled="!editMode"
item-key="id"
:animation="100"
>
2021-09-15 06:34:30 +00:00
<template #item="group">
2021-09-17 06:42:19 +00:00
<div class="mb-5 ">
2021-09-14 15:27:11 +00:00
<!-- Group Title -->
2021-09-17 06:42:19 +00:00
<h2 class="group-title">
2021-09-15 06:34:30 +00:00
<font-awesome-icon v-if="editMode && showGroupDrag" icon="arrows-alt-v" class="action drag me-3" />
<font-awesome-icon v-if="editMode" icon="times" class="action remove me-3" @click="removeGroup(group.index)" />
<Editable v-model="group.element.name" :contenteditable="editMode" tag="span" />
2021-09-14 15:27:11 +00:00
</h2>
2021-09-13 11:21:39 +00:00
<div class="shadow-box monitor-list mt-4 position-relative">
2021-09-15 06:34:30 +00:00
<div v-if="group.element.monitorList.length === 0" class="text-center no-monitor-msg">
2021-09-13 11:21:39 +00:00
{{ $t("No Monitors") }}
</div>
<!-- Monitor List -->
2021-09-15 06:34:30 +00:00
<!-- animation is not working, no idea why -->
2021-09-13 11:21:39 +00:00
<Draggable
2021-09-15 06:34:30 +00:00
v-model="group.element.monitorList"
2021-09-13 11:21:39 +00:00
class="monitor-list"
group="same-group"
:disabled="!editMode"
:animation="100"
2021-09-14 06:12:27 +00:00
item-key="id"
2021-09-13 11:21:39 +00:00
>
2021-09-15 06:34:30 +00:00
<template #item="monitor">
2021-09-13 11:21:39 +00:00
<div class="item">
<div class="row">
<div class="col-9 col-md-8 small-padding d-flex align-items-center flex-wrap">
<div class="info d-flex align-items-center gap-3 w-100">
2021-09-15 12:40:26 +00:00
<font-awesome-icon v-if="editMode" icon="arrows-alt-v" class="action drag me-3" />
2021-09-15 06:34:30 +00:00
<font-awesome-icon v-if="editMode" icon="times" class="action remove me-3" @click="removeMonitor(group.index, monitor.index)" />
<Uptime :monitor="monitor.element" type="24" :pill="true" />
{{ monitor.element.name }}
2021-10-28 01:53:27 +00:00
</div>
<div v-if="showTags && monitor.element.tags.length > 0" class="tags">
2021-10-27 10:06:06 +00:00
<Tag v-for="tag in monitor.element.tags" :key="tag" :item="tag" :size="'sm'" />
2021-09-13 11:21:39 +00:00
</div>
</div>
<div :key="$root.userHeartbeatBar" class="col-3 col-md-4 d-flex align-items-center">
2021-09-15 06:34:30 +00:00
<HeartbeatBar size="small" :monitor-id="monitor.element.id" />
2021-09-13 11:21:39 +00:00
</div>
</div>
</div>
</template>
</Draggable>
</div>
</div>
</template>
</Draggable>
</template>
<script>
import Draggable from "vuedraggable";
import HeartbeatBar from "./HeartbeatBar.vue";
import Uptime from "./Uptime.vue";
2021-10-27 10:06:06 +00:00
import Tag from "./Tag.vue";
2021-09-13 11:21:39 +00:00
export default {
components: {
Draggable,
HeartbeatBar,
Uptime,
2021-10-27 10:06:06 +00:00
Tag,
2021-09-13 11:21:39 +00:00
},
props: {
editMode: {
type: Boolean,
required: true,
},
2022-03-18 09:56:46 +00:00
showTags: {
type: Boolean,
}
2021-09-13 11:21:39 +00:00
},
data() {
return {
2021-09-17 06:42:19 +00:00
};
2021-09-13 11:21:39 +00:00
},
2021-09-15 06:34:30 +00:00
computed: {
showGroupDrag() {
return (this.$root.publicGroupList.length >= 2);
}
},
2021-09-13 11:21:39 +00:00
created() {
2021-09-15 06:34:30 +00:00
},
methods: {
removeGroup(index) {
this.$root.publicGroupList.splice(index, 1);
},
removeMonitor(groupIndex, index) {
this.$root.publicGroupList[groupIndex].monitorList.splice(index, 1);
},
2021-09-13 11:21:39 +00:00
}
2021-09-17 06:42:19 +00:00
};
2021-09-13 11:21:39 +00:00
</script>
<style lang="scss" scoped>
2021-09-15 06:34:30 +00:00
@import "../assets/vars";
2021-09-13 11:21:39 +00:00
2021-09-15 06:34:30 +00:00
.no-monitor-msg {
position: absolute;
width: 100%;
top: 20px;
left: 0;
}
2021-09-13 11:21:39 +00:00
2021-09-15 06:34:30 +00:00
.monitor-list {
min-height: 46px;
}
2021-09-13 11:21:39 +00:00
2021-09-15 06:34:30 +00:00
.flip-list-move {
transition: transform 0.5s;
}
.no-move {
transition: transform 0s;
}
.drag {
color: #bbb;
cursor: grab;
}
.remove {
color: $danger;
}
2021-09-16 14:48:28 +00:00
.group-title {
span {
display: inline-block;
min-width: 15px;
}
}
2021-09-23 08:31:45 +00:00
.mobile {
.item {
padding: 13px 0 10px;
2021-09-23 08:31:45 +00:00
}
}
2021-09-13 11:21:39 +00:00
</style>