<!-- Insert the vue core before vue-toasted -->
<script src="./dist/bgs-admin-lte-vue-ui-components.umd.js"></script>
<link rel="stylesheet" href="./bgs-admin-lte-vue-ui-components.css" />
<script>
Vue.use(window.bgsAdminLteVueUIComponents);
</script>
<bgs-widget-stats-card
header="header"
subheader="subheader"
:loader="loader"
class="col-xs-12 col-sm-4 col-md-3"
@bgs-widget-stats-item-click="itemClick"
@bgs-widget-stats-collapse="collapse"
>
<template v-slot:employee-card>
<!-- Слот для карточки со статистикой для сотрудника -->
</template>
<template v-slot:buttons>
<!-- Слот для кнопок -->
<span
role="button"
title="Show detailed statistics"
class="info-box-toolbar-button hover-translucent employee-statistics-show-details-button"
>
<i class="fa fa-list"></i>
</span>
</template>
<template>
<!-- Слот основного контента -->
</template>
</bgs-widget-stats-card>
Property | Description |
---|---|
header | Заголовок |
subheader | Подпись |
loader | Загрузчик |
@bgs-widget-stats-item-click | Событие по клику на аватарку |
@bgs-widget-stats-collapse | Событие при разворачивании/разворачивании подчинённых |
<bgs-widget-stats-employee-card
:header="30001"
icon="eye"
:link="{href: 'link'}"
class="bg-maroon"
@bgs-widget-stats-employee-card-click="clickCard"
>
<template v-slot:subheader>
<!-- Слот подписи -->
<p>
Last modified 2 month ago
<br />on LNG
</p>
</template>
</bgs-widget-stats-employee-card>
Property | Description |
---|---|
header | Заголовок |
icon | ion иконка |
link | Объект ссылка ( {link: 'http://link.eu', title: 'Заголовок'} ) |
@bgs-widget-stats-employee-card-click | Событие по клику на аватарку |
<bgs-widget-stats-employees :items="items"></bgs-widget-stats-employees>
Property | Description |
---|---|
items | Определённого вида массив объектов (сотрудников) |
<template>
<div id="app">
<bgs-widget-payment-by-contract-expire
:employees="employees"
:loader="loader"
:card="card"
@bgs-widget-stats-item-click="itemClick"
@bgs-widget-stats-collapse="collapse"
@bgs-widget-stats-employee-card-click="cardClick"
@bgs-widget-stats-refresh="refresh"
></bgs-widget-payment-by-contract-expire>
</div>
</template>
<script>
import axios from "axios";
let token = "";
axios.defaults.headers.common = { Authorization: `Bearer ${token}` };
export default {
name: "app",
data() {
return {
card: null,
employees: {
items: []
},
loader: false,
date: new Date().toISOString().split("T")[0],
userId: 1
};
},
async mounted() {
await this.load();
},
methods: {
itemClick() {},
collapse() {},
cardClick() {},
error(message) {
this.card = {
header: `Error: ${message}`,
type: "error"
};
},
refresh() {
this.load();
},
async load() {
this.loader = true;
try {
let response = await axios.get(
`http://bgs-auth.local/api/widget/payment-by-contract-expire/${
this.userId
}`,
{
params: {
"filter[paid]": false,
"filter[date_of_payment_by_contract_before]": this.date
}
}
);
if (response.status === 200) {
let { card, items } = response.data.data;
this.employees.items = items;
if (card) {
this.card = {
header: card.value,
subheader: "Total overdue sum",
type: card.value ? "danger" : null
};
}
}
} catch (error) {
this.error(error.response.statusText);
}
this.loader = false;
}
}
};
</script>
<template>
<bgs-widget-stats-card
header="header"
subheader="subheader"
:loader="loader"
class="col-xs-12 col-sm-4 col-md-3"
@bgs-widget-stats-item-click="itemClick"
@bgs-widget-stats-collapse="collapse"
>
<template v-slot:employee-card>
<bgs-widget-stats-employee-card
:header="30001"
icon="eye"
:link="{href: 'link'}"
class="bg-maroon"
@bgs-widget-stats-employee-card-click="clickCard"
>
<template v-slot:subheader>
<p>
Last modified 2 month ago
<br />on LNG
</p>
</template>
</bgs-widget-stats-employee-card>
</template>
<template v-slot:buttons>
<span
role="button"
title="Show detailed statistics"
class="info-box-toolbar-button hover-translucent employee-statistics-show-details-button"
>
<i class="fa fa-list"></i>
</span>
<span
role="button"
title="Set plan"
class="info-box-toolbar-button hover-translucent employee-statistics-show-planning-button"
>
<i class="fa fa-gears"></i>
</span>
<span
role="button"
title="Refresh"
class="info-box-toolbar-button hover-translucent employee-statistics-refresh-button"
>
<i class="fa fa-refresh"></i>
</span>
</template>
<template>
<bgs-widget-stats-employees :items="items"></bgs-widget-stats-employees>
</template>
</bgs-widget-stats-card>
</template>
<script>
import { setTimeout } from "timers";
export default {
mounted() {
//загрузчик
this.loader = true;
//пример получения данных
setTimeout(() => {
this.items = this.getItems();
this.loader = false;
}, 5000);
},
data() {
return {
// Загрузчик
loader: false,
items: null
};
},
methods: {
//Клик по аватарке
itemClick(item) {},
//Событие при развороте
collapse(item) {},
//Клик по карте
clickCard(e) {
// Отключить стандартное поведение клика
e.preventDefault();
},
getItems() {
return [
{
id: 1, // уникальный id
active: true, // флаг активности
collapsed: false, // показывать развёрнутым (показывать список сотрудников)
avatar: "foto.jpg", // Аватарка
name: "Name 1", // Имя
data: "Data", // Данные для показа
collapsed_data: "expanded", // Данные, которые будут показаны при раскрытом списке сотрудников
other: [1, 2, 3], // любые другие данные, необязательно other
items: [
// Вложенные элементы
{
id: 2,
active: false,
collapsed: false,
avatar: "cb59bc5fefe8bab6abf2fbc2e93eb208/gDAc5YF0mgY.jpg",
name: "Name 12",
data: "text"
},
{
id: 3,
active: true,
collapsed: false,
avatar: "MAKJOEIRd9c.jpg",
name: "Name 13",
data: "text"
}
],
// группа элементов вне иерархии, элементы, которые под чертой
disabledItems: [
{
id: 122, // уникальный id
avatar: "MAKJOEIRd9c.jpg", // Аватарка
name: "Name" // Имя
}
]
},
{
id: 51,
active: true,
collapsed: false,
avatar: "IMG_1402.png",
name: "Name 14",
data: "data",
items: [
{
id: 52,
active: true,
collapsed: false,
avatar: "%D0%BE%D0%B3.png",
name: "Name 15",
data: "data",
items: [
{
id: 53,
active: true,
collapsed: false,
avatar: "xgFmfkZaEHg.jpg",
name: "Name 152",
data: "data"
},
{
id: 54,
active: false,
collapsed: false,
avatar: "IMG_0257-10-09-18-02-17.JPG",
name: "Name 1ваы",
data: "data"
}
]
}
]
}
];
}
}
};
</script>