refactor: move /audit into vue component (#3461)
This commit is contained in:
parent
8506199c2f
commit
82307c4839
10 changed files with 217 additions and 232 deletions
|
|
@ -1,201 +0,0 @@
|
||||||
{% if not ajax %} {% extends "base.html" %} {% endif %}
|
|
||||||
<!---->
|
|
||||||
{% from "macros.jinja" import window_vars with context %}
|
|
||||||
<!---->
|
|
||||||
{% block scripts %} {{ window_vars(user) }} {% endblock %} {% block page %}
|
|
||||||
<div class="row q-col-gutter-md q-mb-md">
|
|
||||||
<div class="col-12">
|
|
||||||
<q-card>
|
|
||||||
<div class="q-pa-sm q-pl-lg">
|
|
||||||
<div class="row items-center justify-between q-gutter-xs">
|
|
||||||
<div class="col">
|
|
||||||
<!-- Optional: Add content here if needed -->
|
|
||||||
</div>
|
|
||||||
<div>
|
|
||||||
<q-btn
|
|
||||||
v-if="g.user.admin"
|
|
||||||
flat
|
|
||||||
round
|
|
||||||
icon="settings"
|
|
||||||
to="/admin#audit"
|
|
||||||
>
|
|
||||||
<q-tooltip v-text="$t('admin_settings')"></q-tooltip>
|
|
||||||
</q-btn>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</q-card>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="row q-col-gutter-md justify-center q-mb-lg">
|
|
||||||
<div class="col-lg-3 col-md-6 col-sm-12 text-center">
|
|
||||||
<q-card class="q-pt-sm">
|
|
||||||
<strong v-text="$t('components')"></strong>
|
|
||||||
<div style="width: 250px" class="q-pa-sm">
|
|
||||||
<canvas v-if="chartsReady" ref="componentUseChart"></canvas>
|
|
||||||
</div>
|
|
||||||
</q-card>
|
|
||||||
</div>
|
|
||||||
<div class="col-lg-3 col-md-6 col-sm-12 text-center">
|
|
||||||
<q-card class="q-pt-sm">
|
|
||||||
<strong v-text="$t('long_running_endpoints')"></strong>
|
|
||||||
<div style="width: 250px; height: 250px" class="q-pa-sm">
|
|
||||||
<canvas v-if="chartsReady" ref="longDurationChart"></canvas>
|
|
||||||
</div>
|
|
||||||
</q-card>
|
|
||||||
</div>
|
|
||||||
<div class="col-lg-3 col-md-6 col-sm-12 text-center">
|
|
||||||
<q-card class="q-pt-sm">
|
|
||||||
<strong v-text="$t('http_request_methods')"></strong>
|
|
||||||
<div style="width: 250px; height: 250px" class="q-pa-sm">
|
|
||||||
<canvas v-if="chartsReady" ref="requestMethodChart"></canvas>
|
|
||||||
</div>
|
|
||||||
</q-card>
|
|
||||||
</div>
|
|
||||||
<div class="col-lg-3 col-md-6 col-sm-12 text-center">
|
|
||||||
<q-card class="q-pt-sm">
|
|
||||||
<strong v-text="$t('http_response_codes')"></strong>
|
|
||||||
<div style="width: 250px; height: 250px" class="q-pa-sm">
|
|
||||||
<canvas v-if="chartsReady" ref="responseCodeChart"></canvas>
|
|
||||||
</div>
|
|
||||||
</q-card>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="row q-col-gutter-md justify-center">
|
|
||||||
<div class="col">
|
|
||||||
<q-card class="q-pa-md">
|
|
||||||
<q-table
|
|
||||||
row-key="id"
|
|
||||||
:rows="auditEntries"
|
|
||||||
:columns="auditTable.columns"
|
|
||||||
v-model:pagination="auditTable.pagination"
|
|
||||||
:filter="auditTable.search"
|
|
||||||
:loading="auditTable.loading"
|
|
||||||
@request="fetchAudit"
|
|
||||||
>
|
|
||||||
<template v-slot:header="props">
|
|
||||||
<q-tr :props="props">
|
|
||||||
<q-th v-for="col in props.cols" :key="col.name" :props="props">
|
|
||||||
<q-input
|
|
||||||
v-if="['ip_address', 'user_id', 'path',].includes(col.name)"
|
|
||||||
v-model="searchData[col.name]"
|
|
||||||
@keydown.enter="searchAuditBy()"
|
|
||||||
@update:model-value="searchAuditBy()"
|
|
||||||
dense
|
|
||||||
type="text"
|
|
||||||
filled
|
|
||||||
clearable
|
|
||||||
:label="col.label"
|
|
||||||
>
|
|
||||||
<template v-slot:append>
|
|
||||||
<q-icon
|
|
||||||
name="search"
|
|
||||||
@click="searchAuditBy()"
|
|
||||||
class="cursor-pointer"
|
|
||||||
/>
|
|
||||||
</template>
|
|
||||||
</q-input>
|
|
||||||
|
|
||||||
<q-select
|
|
||||||
v-else-if="['component', 'response_code','request_method'].includes(col.name)"
|
|
||||||
v-model="searchData[col.name]"
|
|
||||||
:options="searchOptions[col.name]"
|
|
||||||
@update:model-value="searchAuditBy()"
|
|
||||||
:label="col.label"
|
|
||||||
clearable
|
|
||||||
style="width: 100px"
|
|
||||||
></q-select>
|
|
||||||
|
|
||||||
<span v-else v-text="col.label"></span>
|
|
||||||
</q-th>
|
|
||||||
</q-tr>
|
|
||||||
</template>
|
|
||||||
<template v-slot:body="props">
|
|
||||||
<q-tr auto-width :props="props">
|
|
||||||
<q-td v-for="col in props.cols" :key="col.name" :props="props">
|
|
||||||
<div v-if="col.name == 'created_at'">
|
|
||||||
<q-btn
|
|
||||||
icon="description"
|
|
||||||
:disable="!props.row.request_details"
|
|
||||||
size="sm"
|
|
||||||
flat
|
|
||||||
class="cursor-pointer q-mr-xs"
|
|
||||||
@click="showDetailsDialog(props.row)"
|
|
||||||
>
|
|
||||||
<q-tooltip
|
|
||||||
><span v-text="$t('request_details')"></span
|
|
||||||
></q-tooltip>
|
|
||||||
</q-btn>
|
|
||||||
|
|
||||||
<span v-text="formatDate(props.row.created_at)"></span>
|
|
||||||
<q-tooltip v-if="props.row.delete_at">
|
|
||||||
<span
|
|
||||||
v-text="'Will be deleted at: ' + formatDate(props.row.delete_at)"
|
|
||||||
></span>
|
|
||||||
</q-tooltip>
|
|
||||||
</div>
|
|
||||||
<div
|
|
||||||
v-else-if="['user_id', 'request_details'].includes(col.name)"
|
|
||||||
>
|
|
||||||
<q-btn
|
|
||||||
v-if="props.row[col.name]"
|
|
||||||
icon="content_copy"
|
|
||||||
size="sm"
|
|
||||||
flat
|
|
||||||
class="cursor-pointer q-mr-xs"
|
|
||||||
@click="copyText(props.row[col.name])"
|
|
||||||
>
|
|
||||||
<q-tooltip>Copy</q-tooltip>
|
|
||||||
</q-btn>
|
|
||||||
<span v-text="shortify(props.row[col.name])"> </span>
|
|
||||||
<q-tooltip>
|
|
||||||
<span v-text="props.row[col.name]"></span>
|
|
||||||
</q-tooltip>
|
|
||||||
</div>
|
|
||||||
<span
|
|
||||||
v-else
|
|
||||||
v-text="props.row[col.name]"
|
|
||||||
@click="searchAuditBy(col.name, props.row[col.name])"
|
|
||||||
class="cursor-pointer"
|
|
||||||
></span>
|
|
||||||
</q-td>
|
|
||||||
</q-tr>
|
|
||||||
</template>
|
|
||||||
</q-table>
|
|
||||||
</q-card>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<q-dialog v-model="auditDetailsDialog.show" position="top">
|
|
||||||
<q-card class="q-pa-md q-pt-md lnbits__dialog-card">
|
|
||||||
<strong v-text="$t('http_request_details')"></strong>
|
|
||||||
<q-input
|
|
||||||
filled
|
|
||||||
dense
|
|
||||||
v-model.trim="auditDetailsDialog.data"
|
|
||||||
type="textarea"
|
|
||||||
rows="25"
|
|
||||||
></q-input>
|
|
||||||
|
|
||||||
<div class="row q-mt-lg">
|
|
||||||
<q-btn
|
|
||||||
@click="copyText(auditDetailsDialog.data)"
|
|
||||||
icon="copy_content"
|
|
||||||
color="grey"
|
|
||||||
flat
|
|
||||||
v-text="$t('copy')"
|
|
||||||
></q-btn>
|
|
||||||
<q-btn
|
|
||||||
v-close-popup
|
|
||||||
flat
|
|
||||||
color="grey"
|
|
||||||
class="q-ml-auto"
|
|
||||||
v-text="$t('close')"
|
|
||||||
></q-btn>
|
|
||||||
</div>
|
|
||||||
</q-card>
|
|
||||||
</q-dialog>
|
|
||||||
|
|
||||||
{% endblock %}
|
|
||||||
|
|
@ -462,21 +462,6 @@ async def users_index(request: Request, user: User = Depends(check_admin)):
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@generic_router.get("/audit", response_class=HTMLResponse)
|
|
||||||
async def audit_index(request: Request, user: User = Depends(check_admin)):
|
|
||||||
if not settings.lnbits_audit_enabled:
|
|
||||||
raise HTTPException(HTTPStatus.NOT_FOUND, "Audit not enabled")
|
|
||||||
|
|
||||||
return template_renderer().TemplateResponse(
|
|
||||||
"audit/index.html",
|
|
||||||
{
|
|
||||||
"request": request,
|
|
||||||
"user": user.json(),
|
|
||||||
"ajax": _is_ajax_request(request),
|
|
||||||
},
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@generic_router.get("/payments", response_class=HTMLResponse)
|
@generic_router.get("/payments", response_class=HTMLResponse)
|
||||||
async def empty_index(request: Request, user: User = Depends(check_user_exists)):
|
async def empty_index(request: Request, user: User = Depends(check_user_exists)):
|
||||||
return template_renderer().TemplateResponse(
|
return template_renderer().TemplateResponse(
|
||||||
|
|
@ -488,6 +473,7 @@ async def empty_index(request: Request, user: User = Depends(check_user_exists))
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@generic_router.get("/audit", response_class=HTMLResponse)
|
||||||
@generic_router.get("/node", response_class=HTMLResponse)
|
@generic_router.get("/node", response_class=HTMLResponse)
|
||||||
async def empty_admin_index(request: Request, admin: User = Depends(check_admin)):
|
async def empty_admin_index(request: Request, admin: User = Depends(check_admin)):
|
||||||
return template_renderer().TemplateResponse(
|
return template_renderer().TemplateResponse(
|
||||||
|
|
@ -500,7 +486,7 @@ async def empty_admin_index(request: Request, admin: User = Depends(check_admin)
|
||||||
|
|
||||||
|
|
||||||
@generic_router.get("/node/public", response_class=HTMLResponse)
|
@generic_router.get("/node/public", response_class=HTMLResponse)
|
||||||
async def node_public(request: Request):
|
async def empty_public(request: Request):
|
||||||
return template_renderer().TemplateResponse(request, "empty_public.html")
|
return template_renderer().TemplateResponse(request, "empty_public.html")
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,6 @@ from http import HTTPStatus
|
||||||
import httpx
|
import httpx
|
||||||
from fastapi import APIRouter, Body, Depends, HTTPException
|
from fastapi import APIRouter, Body, Depends, HTTPException
|
||||||
from pydantic import BaseModel
|
from pydantic import BaseModel
|
||||||
from starlette.status import HTTP_503_SERVICE_UNAVAILABLE
|
|
||||||
|
|
||||||
from lnbits.decorators import check_admin, check_super_user, parse_filters
|
from lnbits.decorators import check_admin, check_super_user, parse_filters
|
||||||
from lnbits.settings import settings
|
from lnbits.settings import settings
|
||||||
|
|
@ -154,7 +153,7 @@ async def api_get_payments(
|
||||||
) -> Page[NodePayment] | None:
|
) -> Page[NodePayment] | None:
|
||||||
if not settings.lnbits_node_ui_transactions:
|
if not settings.lnbits_node_ui_transactions:
|
||||||
raise HTTPException(
|
raise HTTPException(
|
||||||
HTTP_503_SERVICE_UNAVAILABLE,
|
HTTPStatus.SERVICE_UNAVAILABLE,
|
||||||
detail="You can enable node transactions in the Admin UI",
|
detail="You can enable node transactions in the Admin UI",
|
||||||
)
|
)
|
||||||
return await node.get_payments(filters)
|
return await node.get_payments(filters)
|
||||||
|
|
@ -167,7 +166,7 @@ async def api_get_invoices(
|
||||||
) -> Page[NodeInvoice] | None:
|
) -> Page[NodeInvoice] | None:
|
||||||
if not settings.lnbits_node_ui_transactions:
|
if not settings.lnbits_node_ui_transactions:
|
||||||
raise HTTPException(
|
raise HTTPException(
|
||||||
HTTP_503_SERVICE_UNAVAILABLE,
|
HTTPStatus.SERVICE_UNAVAILABLE,
|
||||||
detail="You can enable node transactions in the Admin UI",
|
detail="You can enable node transactions in the Admin UI",
|
||||||
)
|
)
|
||||||
return await node.get_invoices(filters)
|
return await node.get_invoices(filters)
|
||||||
|
|
|
||||||
2
lnbits/static/bundle-components.min.js
vendored
2
lnbits/static/bundle-components.min.js
vendored
File diff suppressed because one or more lines are too long
|
|
@ -157,15 +157,6 @@ const routes = [
|
||||||
scripts: ['/static/js/users.js']
|
scripts: ['/static/js/users.js']
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
|
||||||
path: '/audit',
|
|
||||||
name: 'Audit',
|
|
||||||
component: DynamicComponent,
|
|
||||||
props: {
|
|
||||||
fetchUrl: '/audit',
|
|
||||||
scripts: ['/static/js/audit.js']
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
path: '/extensions',
|
path: '/extensions',
|
||||||
name: 'Extensions',
|
name: 'Extensions',
|
||||||
|
|
@ -216,6 +207,11 @@ const routes = [
|
||||||
path: '/payments',
|
path: '/payments',
|
||||||
name: 'Payments',
|
name: 'Payments',
|
||||||
component: PagePayments
|
component: PagePayments
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: '/audit',
|
||||||
|
name: 'Audit',
|
||||||
|
component: PageAudit
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,5 @@
|
||||||
window.AuditPageLogic = {
|
window.PageAudit = {
|
||||||
|
template: '#page-audit',
|
||||||
mixins: [window.windowMixin],
|
mixins: [window.windowMixin],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
|
@ -46,6 +46,7 @@
|
||||||
"js/pages/payments.js",
|
"js/pages/payments.js",
|
||||||
"js/pages/node.js",
|
"js/pages/node.js",
|
||||||
"js/pages/node-public.js",
|
"js/pages/node-public.js",
|
||||||
|
"js/pages/audit.js",
|
||||||
"js/components/lnbits-qrcode.js",
|
"js/components/lnbits-qrcode.js",
|
||||||
"js/components/lnbits-qrcode-lnurl.js",
|
"js/components/lnbits-qrcode-lnurl.js",
|
||||||
"js/components/lnbits-funding-sources.js",
|
"js/components/lnbits-funding-sources.js",
|
||||||
|
|
|
||||||
|
|
@ -1 +1,2 @@
|
||||||
{% include('pages/payments.vue') %} {% include('pages/node.vue') %}
|
{% include('pages/payments.vue') %} {% include('pages/node.vue') %} {%
|
||||||
|
include('pages/audit.vue') %}
|
||||||
|
|
|
||||||
201
lnbits/templates/pages/audit.vue
Normal file
201
lnbits/templates/pages/audit.vue
Normal file
|
|
@ -0,0 +1,201 @@
|
||||||
|
<template id="page-audit">
|
||||||
|
<div class="row q-col-gutter-md q-mb-md">
|
||||||
|
<div class="col-12">
|
||||||
|
<q-card>
|
||||||
|
<div class="q-pa-sm q-pl-lg">
|
||||||
|
<div class="row items-center justify-between q-gutter-xs">
|
||||||
|
<div class="col">
|
||||||
|
<!-- Optional: Add content here if needed -->
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<q-btn
|
||||||
|
v-if="g.user.admin"
|
||||||
|
flat
|
||||||
|
round
|
||||||
|
icon="settings"
|
||||||
|
to="/admin#audit"
|
||||||
|
>
|
||||||
|
<q-tooltip v-text="$t('admin_settings')"></q-tooltip>
|
||||||
|
</q-btn>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row q-col-gutter-md justify-center q-mb-lg">
|
||||||
|
<div class="col-lg-3 col-md-6 col-sm-12 text-center">
|
||||||
|
<q-card class="q-pt-sm">
|
||||||
|
<strong v-text="$t('components')"></strong>
|
||||||
|
<div style="width: 250px" class="q-pa-sm">
|
||||||
|
<canvas v-if="chartsReady" ref="componentUseChart"></canvas>
|
||||||
|
</div>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-3 col-md-6 col-sm-12 text-center">
|
||||||
|
<q-card class="q-pt-sm">
|
||||||
|
<strong v-text="$t('long_running_endpoints')"></strong>
|
||||||
|
<div style="width: 250px; height: 250px" class="q-pa-sm">
|
||||||
|
<canvas v-if="chartsReady" ref="longDurationChart"></canvas>
|
||||||
|
</div>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-3 col-md-6 col-sm-12 text-center">
|
||||||
|
<q-card class="q-pt-sm">
|
||||||
|
<strong v-text="$t('http_request_methods')"></strong>
|
||||||
|
<div style="width: 250px; height: 250px" class="q-pa-sm">
|
||||||
|
<canvas v-if="chartsReady" ref="requestMethodChart"></canvas>
|
||||||
|
</div>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-3 col-md-6 col-sm-12 text-center">
|
||||||
|
<q-card class="q-pt-sm">
|
||||||
|
<strong v-text="$t('http_response_codes')"></strong>
|
||||||
|
<div style="width: 250px; height: 250px" class="q-pa-sm">
|
||||||
|
<canvas v-if="chartsReady" ref="responseCodeChart"></canvas>
|
||||||
|
</div>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row q-col-gutter-md justify-center">
|
||||||
|
<div class="col">
|
||||||
|
<q-card class="q-pa-md">
|
||||||
|
<q-table
|
||||||
|
row-key="id"
|
||||||
|
:rows="auditEntries"
|
||||||
|
:columns="auditTable.columns"
|
||||||
|
v-model:pagination="auditTable.pagination"
|
||||||
|
:filter="auditTable.search"
|
||||||
|
:loading="auditTable.loading"
|
||||||
|
@request="fetchAudit"
|
||||||
|
>
|
||||||
|
<template v-slot:header="props">
|
||||||
|
<q-tr :props="props">
|
||||||
|
<q-th v-for="col in props.cols" :key="col.name" :props="props">
|
||||||
|
<q-input
|
||||||
|
v-if="['ip_address', 'user_id', 'path'].includes(col.name)"
|
||||||
|
v-model="searchData[col.name]"
|
||||||
|
@keydown.enter="searchAuditBy()"
|
||||||
|
@update:model-value="searchAuditBy()"
|
||||||
|
dense
|
||||||
|
type="text"
|
||||||
|
filled
|
||||||
|
clearable
|
||||||
|
:label="col.label"
|
||||||
|
>
|
||||||
|
<template v-slot:append>
|
||||||
|
<q-icon
|
||||||
|
name="search"
|
||||||
|
@click="searchAuditBy()"
|
||||||
|
class="cursor-pointer"
|
||||||
|
/>
|
||||||
|
</template>
|
||||||
|
</q-input>
|
||||||
|
|
||||||
|
<q-select
|
||||||
|
v-else-if="
|
||||||
|
['component', 'response_code', 'request_method'].includes(
|
||||||
|
col.name
|
||||||
|
)
|
||||||
|
"
|
||||||
|
v-model="searchData[col.name]"
|
||||||
|
:options="searchOptions[col.name]"
|
||||||
|
@update:model-value="searchAuditBy()"
|
||||||
|
:label="col.label"
|
||||||
|
clearable
|
||||||
|
style="width: 100px"
|
||||||
|
></q-select>
|
||||||
|
|
||||||
|
<span v-else v-text="col.label"></span>
|
||||||
|
</q-th>
|
||||||
|
</q-tr>
|
||||||
|
</template>
|
||||||
|
<template v-slot:body="props">
|
||||||
|
<q-tr auto-width :props="props">
|
||||||
|
<q-td v-for="col in props.cols" :key="col.name" :props="props">
|
||||||
|
<div v-if="col.name == 'created_at'">
|
||||||
|
<q-btn
|
||||||
|
icon="description"
|
||||||
|
:disable="!props.row.request_details"
|
||||||
|
size="sm"
|
||||||
|
flat
|
||||||
|
class="cursor-pointer q-mr-xs"
|
||||||
|
@click="showDetailsDialog(props.row)"
|
||||||
|
>
|
||||||
|
<q-tooltip
|
||||||
|
><span v-text="$t('request_details')"></span
|
||||||
|
></q-tooltip>
|
||||||
|
</q-btn>
|
||||||
|
|
||||||
|
<span v-text="formatDate(props.row.created_at)"></span>
|
||||||
|
<q-tooltip v-if="props.row.delete_at">
|
||||||
|
<span
|
||||||
|
v-text="
|
||||||
|
'Will be deleted at: ' + formatDate(props.row.delete_at)
|
||||||
|
"
|
||||||
|
></span>
|
||||||
|
</q-tooltip>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
v-else-if="['user_id', 'request_details'].includes(col.name)"
|
||||||
|
>
|
||||||
|
<q-btn
|
||||||
|
v-if="props.row[col.name]"
|
||||||
|
icon="content_copy"
|
||||||
|
size="sm"
|
||||||
|
flat
|
||||||
|
class="cursor-pointer q-mr-xs"
|
||||||
|
@click="copyText(props.row[col.name])"
|
||||||
|
>
|
||||||
|
<q-tooltip>Copy</q-tooltip>
|
||||||
|
</q-btn>
|
||||||
|
<span v-text="shortify(props.row[col.name])"> </span>
|
||||||
|
<q-tooltip>
|
||||||
|
<span v-text="props.row[col.name]"></span>
|
||||||
|
</q-tooltip>
|
||||||
|
</div>
|
||||||
|
<span
|
||||||
|
v-else
|
||||||
|
v-text="props.row[col.name]"
|
||||||
|
@click="searchAuditBy(col.name, props.row[col.name])"
|
||||||
|
class="cursor-pointer"
|
||||||
|
></span>
|
||||||
|
</q-td>
|
||||||
|
</q-tr>
|
||||||
|
</template>
|
||||||
|
</q-table>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<q-dialog v-model="auditDetailsDialog.show" position="top">
|
||||||
|
<q-card class="q-pa-md q-pt-md lnbits__dialog-card">
|
||||||
|
<strong v-text="$t('http_request_details')"></strong>
|
||||||
|
<q-input
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-model.trim="auditDetailsDialog.data"
|
||||||
|
type="textarea"
|
||||||
|
rows="25"
|
||||||
|
></q-input>
|
||||||
|
|
||||||
|
<div class="row q-mt-lg">
|
||||||
|
<q-btn
|
||||||
|
@click="copyText(auditDetailsDialog.data)"
|
||||||
|
icon="copy_content"
|
||||||
|
color="grey"
|
||||||
|
flat
|
||||||
|
v-text="$t('copy')"
|
||||||
|
></q-btn>
|
||||||
|
<q-btn
|
||||||
|
v-close-popup
|
||||||
|
flat
|
||||||
|
color="grey"
|
||||||
|
class="q-ml-auto"
|
||||||
|
v-text="$t('close')"
|
||||||
|
></q-btn>
|
||||||
|
</div>
|
||||||
|
</q-card>
|
||||||
|
</q-dialog>
|
||||||
|
</template>
|
||||||
|
|
@ -98,6 +98,7 @@
|
||||||
"js/pages/payments.js",
|
"js/pages/payments.js",
|
||||||
"js/pages/node.js",
|
"js/pages/node.js",
|
||||||
"js/pages/node-public.js",
|
"js/pages/node-public.js",
|
||||||
|
"js/pages/audit.js",
|
||||||
"js/components/lnbits-qrcode.js",
|
"js/components/lnbits-qrcode.js",
|
||||||
"js/components/lnbits-qrcode-lnurl.js",
|
"js/components/lnbits-qrcode-lnurl.js",
|
||||||
"js/components/lnbits-funding-sources.js",
|
"js/components/lnbits-funding-sources.js",
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue