1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-02 12:47:41 +02:00

Server: Display max size info in dashboard

This commit is contained in:
Laurent Cozic 2021-07-03 16:24:36 +01:00
parent 7447793e77
commit 3d18514c3c
6 changed files with 43 additions and 29 deletions

View File

@ -18,3 +18,16 @@ export function getMaxTotalItemSize(user: User): number {
const account = accountByType(user.account_type);
return user.max_total_item_size !== null ? user.max_total_item_size : account.max_total_item_size;
}
export function totalSizePercent(user: User): number {
const maxTotalSize = getMaxTotalItemSize(user);
if (!maxTotalSize) return 0;
return user.total_item_size / maxTotalSize;
}
export function totalSizeClass(user: User) {
const d = totalSizePercent(user);
if (d >= 1) return 'is-danger';
if (d >= .7) return 'is-warning';
return '';
}

View File

@ -5,8 +5,9 @@ import { AppContext } from '../../utils/types';
import { contextSessionId } from '../../utils/requestUtils';
import { ErrorMethodNotAllowed } from '../../utils/errors';
import defaultView from '../../utils/defaultView';
import { accountByType, accountTypeToString } from '../../models/UserModel';
import { formatMaxItemSize, yesOrNo } from '../../utils/strings';
import { accountTypeToString } from '../../models/UserModel';
import { formatMaxItemSize, formatMaxTotalSize, formatTotalSize, formatTotalSizePercent, yesOrNo } from '../../utils/strings';
import { getCanShareFolder, totalSizeClass } from '../../models/utils/user';
const router: Router = new Router(RouteType.Web);
@ -14,24 +15,35 @@ router.get('home', async (_path: SubPath, ctx: AppContext) => {
contextSessionId(ctx);
if (ctx.method === 'GET') {
const accountProps = accountByType(ctx.joplin.owner.account_type);
const user = ctx.joplin.owner;
const view = defaultView('home', 'Home');
view.content = {
userProps: [
{
label: 'Account Type',
value: accountTypeToString(accountProps.account_type),
value: accountTypeToString(user.account_type),
show: true,
},
{
label: 'Is Admin',
value: yesOrNo(ctx.joplin.owner.is_admin),
show: !!ctx.joplin.owner.is_admin,
value: yesOrNo(user.is_admin),
show: !!user.is_admin,
},
{
label: 'Max Item Size',
value: formatMaxItemSize(ctx.joplin.owner),
value: formatMaxItemSize(user),
show: true,
},
{
label: 'Total Size',
classes: [totalSizeClass(user)],
value: `${formatTotalSize(user)} (${formatTotalSizePercent(user)})`,
show: true,
},
{
label: 'Max Total Size',
value: formatMaxTotalSize(user),
show: true,
},
{
@ -41,7 +53,7 @@ router.get('home', async (_path: SubPath, ctx: AppContext) => {
},
{
label: 'Can Share Notebook',
value: yesOrNo(accountProps.can_share_folder),
value: yesOrNo(getCanShareFolder(user)),
show: true,
},
],

View File

@ -12,8 +12,8 @@ import { AclAction } from '../../models/BaseModel';
import { NotificationKey } from '../../models/NotificationModel';
import { accountTypeOptions, accountTypeToString } from '../../models/UserModel';
import uuidgen from '../../utils/uuidgen';
import { formatMaxItemSize, formatMaxTotalSize, formatTotalSize, yesOrNo } from '../../utils/strings';
import { getCanShareFolder, getMaxTotalItemSize } from '../../models/utils/user';
import { formatMaxItemSize, formatMaxTotalSize, formatTotalSize, formatTotalSizePercent, yesOrNo } from '../../utils/strings';
import { getCanShareFolder, totalSizeClass } from '../../models/utils/user';
import { yesNoDefaultOptions } from '../../utils/views/select';
interface CheckPasswordInput {
@ -84,19 +84,6 @@ function userIsMe(path: SubPath): boolean {
const router = new Router(RouteType.Web);
function totalSizePercent(user: User): number {
const maxTotalSize = getMaxTotalItemSize(user);
if (!maxTotalSize) return 0;
return user.total_item_size / maxTotalSize;
}
function totalSizeClass(user: User) {
const d = totalSizePercent(user);
if (d >= 1) return 'is-danger';
if (d >= .7) return 'is-warning';
return '';
}
router.get('users', async (_path: SubPath, ctx: AppContext) => {
const userModel = ctx.joplin.models.user();
await userModel.checkIfAllowed(ctx.joplin.owner, AclAction.List);
@ -117,7 +104,7 @@ router.get('users', async (_path: SubPath, ctx: AppContext) => {
formattedItemMaxSize: formatMaxItemSize(user),
formattedTotalSize: formatTotalSize(user),
formattedMaxTotalSize: formatMaxTotalSize(user),
formattedTotalSizePercent: `${Math.round(totalSizePercent(user) * 100)}%`,
formattedTotalSizePercent: formatTotalSizePercent(user),
totalSizeClass: totalSizeClass(user),
formattedAccountType: accountTypeToString(user.account_type),
formattedCanShareFolder: yesOrNo(getCanShareFolder(user)),

View File

@ -7,8 +7,6 @@ const logger = Logger.create('cron');
export default class CronService extends BaseService {
public async runInBackground() {
await this.models.item().updateTotalSizes();
cron.schedule('0 */6 * * *', async () => {
const startTime = Date.now();
logger.info('Deleting expired tokens...');

View File

@ -1,5 +1,5 @@
import { User } from '../db';
import { getMaxItemSize, getMaxTotalItemSize } from '../models/utils/user';
import { getMaxItemSize, getMaxTotalItemSize, totalSizePercent } from '../models/utils/user';
import { formatBytes } from './bytes';
export function yesOrNo(value: any): string {
@ -20,6 +20,10 @@ export function formatMaxTotalSize(user: User): string {
return size ? formatBytes(size) : '∞';
}
export function formatTotalSizePercent(user: User): string {
return `${Math.round(totalSizePercent(user) * 100)}%`;
}
export function formatTotalSize(user: User): string {
return formatBytes(user.total_item_size);
}

View File

@ -6,10 +6,10 @@
{{#userProps}}
{{#show}}
<tr>
<td>
<td class="{{#classes}}{{.}}{{/classes}}">
<strong>{{label}}</strong>
</td>
<td>
<td class="{{#classes}}{{.}}{{/classes}}">
{{value}}
</td>
</tr>