This commit is contained in:
AuroraLS3 2024-12-01 09:53:40 +00:00
parent 93e4e6ce36
commit 87f638a2d3
13 changed files with 1378 additions and 1873 deletions

View File

@ -157,7 +157,7 @@ Time:
Unit: DAYS
# Includes players online, tps and performance time series
Remove_time_series_data_after:
Time: 90
Time: 3650
Unit: DAYS
Remove_ping_data_after:
Time: 14

View File

@ -17,11 +17,13 @@
"hong kong": "HKG",
"armenia": "ARM",
"vietnam": "VNM",
"vatican city": "VAT",
"australia": "AUS",
"laos": "LAO",
"aruba": "ABW",
"solomon islands": "SLB",
"turkey": "TUR",
"türkiye": "TUR",
"ukraine": "UKR",
"austria": "AUT",
"united states": "USA",
@ -33,7 +35,8 @@
"greece": "GRC",
"paraguay": "PRY",
"palau": "PLW",
"congo, republic of the": "COG",
"congo republic": "COD",
"dr congo": "COG",
"vanuatu": "VUT",
"cyprus": "CYP",
"colombia": "COL",
@ -93,6 +96,7 @@
"zimbabwe": "ZWE",
"el salvador": "SLV",
"macedonia": "MKD",
"north macedonia": "MKD",
"saint lucia": "LCA",
"bolivia": "BOL",
"china": "CHN",
@ -187,6 +191,7 @@
"tanzania": "TZA",
"grenada": "GRD",
"netherlands": "NLD",
"the netherlands": "NLD",
"sao tome and principe": "STP",
"guam": "GUM",
"eritrea": "ERI",
@ -221,5 +226,30 @@
"saint vincent and the grenadines": "VCT",
"tonga": "TON",
"barbados": "BRB",
"new caledonia": "NCL"
"new caledonia": "NCL",
"réunion": "REU",
"mayotte": "MYT",
"martinique": "MTQ",
"guadeloupe": "GLP",
"french guiana": "GUF",
"eswatini": "SWZ",
"cocos (keeling) islands": "CCK",
"macao": "MAC",
"st kitts and nevis": "KNA",
"saint barthélemy": "BLM",
"st vincent and grenadines": "VCT",
"bahamas": "BHS",
"myanmar": "MMR",
"tokelau": "TKL",
"wallis and futuna": "WLF",
"ivory coast": "CIV",
"côte d'ivoire": "CIV",
"gambia": "GMB",
"nauru": "NRU",
"federated states of micronesia": "FSM",
"curaçao": "CUW",
"são tomé and príncipe": "STP",
"turks and caicos islands": "TCA",
"norfolk island": "NFK",
"pitcairn islands": "PCN"
}

View File

@ -905,7 +905,7 @@ plugin:
loadedServerInfo: "Identifiant de serveur chargé : ${0}"
loadingServerInfo: "Chargement des informations d'identification du serveur"
no: "Non"
today: "Aujourd'hui"
today: "'Aujourd''hui'"
unavailable: "Indisponible"
unknown: "Inconnu"
yes: "Oui"

View File

@ -118,7 +118,7 @@ command:
network: "> §2ネットワークページ"
players: "> §2プレイヤー"
search: "> §2${0} §f${1}§2 の検索結果:"
serverList: "Minecraft id::名前::uuid::version"
serverList: "Minecraft id::名前::uuid::バージョン"
servers: "> §2サーバー"
webUserList: "ユーザー名::別プレイヤーとのリンク::権限レベル"
webUsers: "> §2${0} Webユーザー"
@ -257,7 +257,7 @@ html:
noServers: "データーベース内に登録されたサーバーが見つかりません"
noServersLong: 'プランがどのゲーム サーバーにもインストールされていないか、同じデータベースに接続されていないようです。ネットワーク チュートリアルについては、<a href="https://github.com/plan-player-analytics/Plan/wiki">Wiki</a>を参考にしてください'
noSpongeChunks: "Spongeではチャンクを利用できません"
noUptimeCalculation: "Server is offline, or has never restarted with Plan installed."
noUptimeCalculation: "サーバーがオフラインであるか、Plan がインストールされた状態で再起動されたことがありません。"
performanceNoGameServers: "TPS、エンティティ、またはチャンクデータは、ゲーム ティックループがないため、プロキシサーバーから収集されません"
predictedNewPlayerRetention: "これは以前のプレーヤーから基づいた予測値です"
error:
@ -290,19 +290,19 @@ html:
active: "よくログインしている"
activePlaytime: "アクティブなプレイ時間"
activityIndex: "活動指数"
addJoinAddressGroup: "Add address group"
addressGroup: "Address group {{n}}"
addJoinAddressGroup: "アドレスグループの追加"
addressGroup: "{{n}} アドレスグループ"
afk: "離席"
afkTime: "離席時間"
all: "全て"
allTime: "全体"
allowed: "Allowed"
allowlist: "Allowlist"
allowed: "許可された"
allowlist: "許可リスト"
allowlistBounces: "Allowlist Bounces"
alphabetical: "アルファベット順"
apply: "適用"
asNumbers: "の情報"
attempts: "Attempts"
attempts: "試行回数"
average: "平均の初回セッション時間"
averageActivePlaytime: "平均アクティブプレイ時間"
averageAfkTime: "平均AFK時間"
@ -333,7 +333,7 @@ html:
cpuUsage: "CPU使用率"
currentPlayerbase: "ログインプレイヤー"
currentUptime: "現状のアップタイム"
currentlyInstalledPlugins: "Currently Installed Plugins"
currentlyInstalledPlugins: "現在インストールされているプラグイン"
dayByDay: "詳細情報"
dayOfweek: "曜日"
deadliestWeapon: "最もPvPで使用されている武器"
@ -345,7 +345,7 @@ html:
duringLowTps: "TPSの低下までの時間:"
entities: "エンティティ数"
errors: "Planエラーログ"
export: "Export"
export: "出力"
exported: "データエクスポート時間"
favoriteServer: "お気に入りのサーバー"
firstSession: "初参加"
@ -437,10 +437,10 @@ html:
last24hours: "24時間"
last30days: "1ヶ月"
last7days: "1週間"
lastAllowed: "Last Allowed"
lastBlocked: "Last Blocked"
lastAllowed: "直近の許可"
lastBlocked: "直近の拒否"
lastConnected: "直近の接続"
lastKnownAttempt: "Last Known Attempt"
lastKnownAttempt: "直近の試行"
lastPeak: "直近のピークタイム"
lastSeen: "直近のオンライン"
latestJoinAddresses: "最後に参加したサーバーのアドレス"
@ -489,7 +489,7 @@ html:
name: "名前"
network: "ネットワーク"
networkAsNumbers: "ネットワーク数"
networkCalendar: "Network Calendar"
networkCalendar: "ネットワークカレンダー"
networkOnlineActivity: "ネットワーク内の接続状況"
networkOverview: "ネットワーク概要"
networkPage: "ネットワークページ"
@ -527,8 +527,8 @@ html:
playersOnlineNow: "オンラインのプレイヤー(今)"
playersOnlineOverview: "接続状況の概要"
playtime: "プレイ時間"
pluginHistory: "Plugin History"
pluginVersionHistory: "Plugin Version History"
pluginHistory: "プラグイン履歴"
pluginVersionHistory: "プラグインバージョン履歴"
plugins: "プラグイン"
pluginsOverview: "プラグイン一覧"
punchcard: "パンチカード"
@ -679,7 +679,7 @@ html:
page_network_playerbase_graphs: "プレイヤー層のグラフを表示"
page_network_playerbase_overview: "プレイヤー層の概要番号を表示"
page_network_players: "プレイヤーリストタブを表示"
page_network_plugin_history: "See Plugin History across the network"
page_network_plugin_history: "ネットワーク全体のプラグイン履歴を見る"
page_network_plugins: "プロキシーのプラグインタブを表示"
page_network_retention: "プレイヤー維持のタブを表示"
page_network_server_list: "サーバーリストを表示"
@ -722,7 +722,7 @@ html:
page_server_playerbase_graphs: "プレイヤー層概要グラフを表示"
page_server_playerbase_overview: "プレイヤー層概要番号を表示"
page_server_players: "プレイヤーリストタブを表示"
page_server_plugin_history: "See Plugin History"
page_server_plugin_history: "プラグイン履歴を見る"
page_server_plugins: "サーバーのプラグインタブを表示"
page_server_retention: "プレイヤーの維持タブを表示"
page_server_sessions: "セッションタブを表示"
@ -835,7 +835,7 @@ html:
success: "新規ユーザー登録が完了しました!ログインできるようになりました。"
usernameTip: "ユーザー名は50文字以内で指定します"
text:
click: "Click for more"
click: "ここをクリック"
clickAndDrag: "Click and Drag for more"
clickToExpand: "クリックして展開"
comparing15days: "直近15日との比較"
@ -888,8 +888,8 @@ plugin:
emptyIP: "server.propertiesの設定で、IPの項目が設定されておらずAlternative IPが使用されていません。そのため誤ったリンクが表示されます!"
geoDisabled: "位置情報サービスが有効ではありません。 (Data.Geolocations: false)"
geoInternetRequired: "「Plan」は初回起動時、「GeoLite2」の位置情報データベースをダウンロードするためインターネットアクセスが必要です"
proxyAddress: "Proxy server detected in the database - Proxy Webserver address is '${0}'."
proxyDisabledWebserver: "Disabling Webserver on this server - You can override this behavior by setting '${0}' to false."
proxyAddress: "データベースでプロキシサーバーが検出されました - プロキシウェブサーバーのアドレスは '${0}' です。"
proxyDisabledWebserver: "ウェブサーバーを無効にする - '${0}' を false に設定することで、この動作をオーバーライドできます。"
settingChange: "Note: Set '${0}' to ${1}"
storeSessions: "前回のシャットダウン時に、保存されていたセッションを保存します"
webserverDisabled: "Webサーバーの初期化に失敗しました (WebServer.DisableWebServer: true)"
@ -910,7 +910,7 @@ plugin:
unknown: "不明"
yes: "はい"
yesterday: "'昨日'"
localeReloaded: "Custom locale.yml was modified so it was reloaded and is now in use."
localeReloaded: "カスタムlocale.ymlが修正されたため、再読込されました。"
version:
checkFail: "新しいバージョンのチェックに失敗しました"
checkFailGithub: "Github/versions.txtに存在するバージョン情報のロードに失敗しました"

View File

@ -7,42 +7,42 @@
"proxy": "http://localhost:8800",
"dependencies": {
"@babel/plugin-proposal-private-property-in-object": "^7.21.11",
"@fortawesome/fontawesome-free": "^6.5.2",
"@fortawesome/fontawesome-svg-core": "^6.5.2",
"@fortawesome/free-brands-svg-icons": "^6.5.2",
"@fortawesome/free-regular-svg-icons": "^6.5.2",
"@fortawesome/free-solid-svg-icons": "^6.5.2",
"@fortawesome/fontawesome-free": "^6.7.1",
"@fortawesome/fontawesome-svg-core": "^6.7.1",
"@fortawesome/free-brands-svg-icons": "^6.7.1",
"@fortawesome/free-regular-svg-icons": "^6.7.1",
"@fortawesome/free-solid-svg-icons": "^6.7.1",
"@fortawesome/react-fontawesome": "^0.2.2",
"@fullcalendar/bootstrap": "^6.1.11",
"@fullcalendar/core": "^6.1.13",
"@fullcalendar/daygrid": "^6.1.11",
"@fullcalendar/interaction": "^6.1.11",
"@fullcalendar/react": "^6.1.11",
"@highcharts/map-collection": "^2.1.0",
"@testing-library/jest-dom": "^6.4.5",
"@testing-library/react": "^15.0.7",
"@fullcalendar/bootstrap": "^6.1.15",
"@fullcalendar/core": "^6.1.15",
"@fullcalendar/daygrid": "^6.1.15",
"@fullcalendar/interaction": "^6.1.15",
"@fullcalendar/react": "^6.1.15",
"@highcharts/map-collection": "^2.3.0",
"@testing-library/jest-dom": "^6.6.3",
"@testing-library/react": "^16.0.1",
"@testing-library/user-event": "^14.5.2",
"axios": "^1.7.2",
"axios": "^1.7.8",
"bootstrap": "^5.3.3",
"export-to-csv": "^1.3.0",
"highcharts": "^11.4.3",
"i18next": "^23.11.5",
"highcharts": "^11.4.8",
"i18next": "^24.0.2",
"i18next-chained-backend": "^4.6.2",
"i18next-http-backend": "^2.5.2",
"i18next-http-backend": "^3.0.1",
"i18next-localstorage-backend": "^4.2.0",
"masonry-layout": "^4.2.2",
"moment": "^2.30.1",
"react": "^18.3.1",
"react-bootstrap": "^2.10.2",
"react-bootstrap": "^2.10.6",
"react-bootstrap-range-slider": "^3.0.8",
"react-dom": "^18.3.1",
"react-i18next": "^14.1.2",
"react-i18next": "^15.1.3",
"react-mcjsonchat": "^1.0.0",
"react-router-dom": "^6.23.1",
"sass": "^1.77.2",
"react-router-dom": "^6.26.0",
"sass": "^1.81.0",
"source-map-explorer": "^2.5.2",
"swagger-ui": "^5.17.12",
"web-vitals": "^3.0.2"
"swagger-ui": "^5.18.2",
"web-vitals": "^4.2.4"
},
"scripts": {
"start": "vite",
@ -68,7 +68,7 @@
]
},
"devDependencies": {
"@vitejs/plugin-react": "^4.3.0",
"vite": "^5.2.11"
"@vitejs/plugin-react": "^4.3.4",
"vite": "^6.0.1"
}
}

View File

@ -67,7 +67,7 @@ const PingGraphTab = ({identifier}) => {
const PerformanceGraphsCard = () => {
const {t} = useTranslation();
const {authRequired, hasPermission} = useAuth();
const {authRequired, hasPermission, hasChildPermission} = useAuth();
const {identifier} = useParams();
const {data, loadingError} = useDataRequest(fetchOptimizedPerformance, [identifier]);
@ -115,33 +115,40 @@ const PerformanceGraphsCard = () => {
}
}, [pluginHistory, setPluginHistorySeries, t]);
const tabs = [
{
name: t('html.label.all'), icon: faGears, color: 'blue-grey', href: 'all',
element: <AllGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>,
permission: 'page.server.performance.graphs'
}, {
name: t('html.label.tps'), icon: faTachometerAlt, color: 'red', href: 'tps',
element: <TpsGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>,
permission: 'page.server.performance.graphs.tps'
}, {
name: t('html.label.cpuRam'), icon: faMicrochip, color: 'light-green', href: 'cpu-ram',
element: <CpuRamGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>,
permission: ['page.server.performance.graphs.cpu', 'page.server.performance.graphs.ram']
}, {
name: t('html.label.world'), icon: faMap, color: 'purple', href: 'world-load',
element: <WorldGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>,
permission: ['page.server.performance.graphs.entities', 'page.server.performance.graphs.chunks']
}, {
name: t('html.label.ping'), icon: faSignal, color: 'amber', href: 'ping',
element: <PingGraphTab identifier={identifier}/>,
permission: 'page.server.performance.graphs.ping'
}, {
name: t('html.label.diskSpace'), icon: faHdd, color: 'green', href: 'disk',
element: <DiskGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>,
permission: 'page.server.performance.graphs.disk'
},
].filter(tab => hasChildPermission(tab.permission));
return <Card id={"performance-graphs"}>
<CardTabs tabs={[
{
name: t('html.label.all'), icon: faGears, color: 'blue-grey', href: 'all',
element: <AllGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>
}, {
name: t('html.label.tps'), icon: faTachometerAlt, color: 'red', href: 'tps',
element: <TpsGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>
}, {
name: t('html.label.cpuRam'), icon: faMicrochip, color: 'light-green', href: 'cpu-ram',
element: <CpuRamGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>
}, {
name: t('html.label.world'), icon: faMap, color: 'purple', href: 'world-load',
element: <WorldGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>
}, {
name: t('html.label.ping'), icon: faSignal, color: 'amber', href: 'ping',
element: <PingGraphTab identifier={identifier}/>
}, {
name: t('html.label.diskSpace'), icon: faHdd, color: 'green', href: 'disk',
element: <DiskGraphTab data={data} dataSeries={parsedData} pluginHistorySeries={pluginHistorySeries}
loadingError={loadingError || pluginHistoryLoadingError}/>
},
]}/>
<CardTabs tabs={tabs}/>
</Card>
}

View File

@ -8,6 +8,7 @@ import {useTheme} from "../../../hooks/themeHook";
import {withReducedSaturation} from "../../../util/colors";
import Accessibility from "highcharts/modules/accessibility";
import {useMetadata} from "../../../hooks/metadataHook";
import {useAuth} from "../../../hooks/authenticationHook.jsx";
const yAxis = [
{
@ -66,6 +67,7 @@ const AllPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
const {t} = useTranslation();
const {graphTheming, nightModeEnabled} = useTheme();
const {timeZoneOffsetMinutes} = useMetadata();
const {hasPermission} = useAuth();
const onResize = useCallback(() => {
let chartElement = document.getElementById(id);
@ -74,14 +76,14 @@ const AllPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
if (chart?.yAxis?.length) {
const newWidth = window.innerWidth
chart.yAxis[0].update({labels: {enabled: newWidth >= 900}});
chart.yAxis[1].update({labels: {enabled: newWidth >= 900}});
chart.yAxis[2].update({labels: {enabled: newWidth >= 1000}});
chart.yAxis[3].update({labels: {enabled: newWidth >= 1000}});
chart.yAxis[4].update({labels: {enabled: newWidth >= 1400}});
chart.yAxis[5].update({labels: {enabled: newWidth >= 1400}});
chart.yAxis[0].update({labels: {enabled: newWidth >= 900 && hasPermission('page.server.performance.graphs.players.online')}});
chart.yAxis[1].update({labels: {enabled: newWidth >= 900 && hasPermission('page.server.performance.graphs.tps')}});
chart.yAxis[2].update({labels: {enabled: newWidth >= 1000 && hasPermission('page.server.performance.graphs.cpu')}});
chart.yAxis[3].update({labels: {enabled: newWidth >= 1000 && hasPermission('page.server.performance.graphs.ram')}});
chart.yAxis[4].update({labels: {enabled: newWidth >= 1400 && hasPermission('page.server.performance.graphs.entities')}});
chart.yAxis[5].update({labels: {enabled: newWidth >= 1400 && hasPermission('page.server.performance.graphs.chunks')}});
}
}, [id])
}, [id, hasPermission])
useEffect(() => {
window.addEventListener("resize", onResize);
@ -107,14 +109,15 @@ const AllPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
const spline = 'spline'
const series = {
playersOnline: {
playersOnline: hasPermission('page.server.performance.graphs.players.online') ? {
name: t('html.label.playersOnline'),
type: 'areaspline',
tooltip: tooltip.zeroDecimals,
data: dataSeries.playersOnline,
color: data.colors.playersOnline,
yAxis: 0
}, tps: {
} : {},
tps: hasPermission('page.server.performance.graphs.tps') ? {
name: t('html.label.tps'),
type: spline,
color: nightModeEnabled ? withReducedSaturation(data.colors.high) : data.colors.high,
@ -122,35 +125,39 @@ const AllPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
tooltip: tooltip.twoDecimals,
data: dataSeries.tps,
yAxis: 1
}, cpu: {
} : {},
cpu: hasPermission('page.server.performance.graphs.cpu') ? {
name: t('html.label.cpu'),
type: spline,
tooltip: tooltip.twoDecimals,
data: dataSeries.cpu,
color: nightModeEnabled ? withReducedSaturation(data.colors.cpu) : data.colors.cpu,
yAxis: 2
}, ram: {
} : {},
ram: hasPermission('page.server.performance.graphs.ram') ? {
name: t('html.label.ram'),
type: spline,
tooltip: tooltip.zeroDecimals,
data: dataSeries.ram,
color: nightModeEnabled ? withReducedSaturation(data.colors.ram) : data.colors.ram,
yAxis: 3
}, entities: {
} : {},
entities: hasPermission('page.server.performance.graphs.entities') ? {
name: t('html.label.loadedEntities'),
type: spline,
tooltip: tooltip.zeroDecimals,
data: dataSeries.entities,
color: nightModeEnabled ? withReducedSaturation(data.colors.entities) : data.colors.entities,
yAxis: 4
}, chunks: {
} : {},
chunks: hasPermission('page.server.performance.graphs.chunks') ? {
name: t('html.label.loadedChunks'),
type: spline,
tooltip: tooltip.zeroDecimals,
data: dataSeries.chunks,
color: nightModeEnabled ? withReducedSaturation(data.colors.chunks) : data.colors.chunks,
yAxis: 5
}
} : {}
};
NoDataDisplay(Highcharts);

View File

@ -8,38 +8,42 @@ import {useTheme} from "../../../hooks/themeHook";
import {withReducedSaturation} from "../../../util/colors";
import Accessibility from "highcharts/modules/accessibility";
import {useMetadata} from "../../../hooks/metadataHook";
import {useAuth} from "../../../hooks/authenticationHook.jsx";
const CpuRamPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
const {t} = useTranslation();
const {graphTheming, nightModeEnabled} = useTheme();
const {timeZoneOffsetMinutes} = useMetadata();
const {hasPermission} = useAuth();
useEffect(() => {
const spline = 'spline'
const series = {
playersOnline: {
playersOnline: hasPermission('page.server.performance.graphs.players.online') ? {
name: t('html.label.playersOnline'),
type: 'areaspline',
tooltip: tooltip.zeroDecimals,
data: dataSeries.playersOnline,
color: data.colors.playersOnline,
yAxis: 0
}, cpu: {
} : {},
cpu: hasPermission('page.server.performance.graphs.cpu') ? {
name: t('html.label.cpu'),
type: spline,
tooltip: tooltip.twoDecimals,
data: dataSeries.cpu,
color: nightModeEnabled ? withReducedSaturation(data.colors.cpu) : data.colors.cpu,
yAxis: 1
}, ram: {
} : {},
ram: hasPermission('page.server.performance.graphs.ram') ? {
name: t('html.label.ram'),
type: spline,
tooltip: tooltip.zeroDecimals,
data: dataSeries.ram,
color: nightModeEnabled ? withReducedSaturation(data.colors.ram) : data.colors.ram,
yAxis: 2
}
} : {}
};
NoDataDisplay(Highcharts);

View File

@ -8,11 +8,13 @@ import {useTheme} from "../../../hooks/themeHook";
import {withReducedSaturation} from "../../../util/colors";
import Accessibility from "highcharts/modules/accessibility";
import {useMetadata} from "../../../hooks/metadataHook";
import {useAuth} from "../../../hooks/authenticationHook.jsx";
const TpsPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
const {t} = useTranslation();
const {graphTheming, nightModeEnabled} = useTheme();
const {timeZoneOffsetMinutes} = useMetadata();
const {hasPermission} = useAuth();
useEffect(() => {
const zones = {
@ -30,14 +32,15 @@ const TpsPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
const spline = 'spline'
const series = {
playersOnline: {
playersOnline: hasPermission('page.server.performance.graphs.players.online') ? {
name: t('html.label.playersOnline'),
type: 'areaspline',
tooltip: tooltip.zeroDecimals,
data: dataSeries.playersOnline,
color: data.colors.playersOnline,
yAxis: 0
}, tps: {
} : {},
tps: hasPermission('page.server.performance.graphs.tps') ? {
name: t('html.label.tps'),
type: spline,
color: nightModeEnabled ? withReducedSaturation(data.colors.high) : data.colors.high,
@ -45,7 +48,7 @@ const TpsPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
tooltip: tooltip.twoDecimals,
data: dataSeries.tps,
yAxis: 1
}
} : {}
};
NoDataDisplay(Highcharts);

View File

@ -8,38 +8,42 @@ import {useTheme} from "../../../hooks/themeHook";
import {withReducedSaturation} from "../../../util/colors";
import Accessibility from "highcharts/modules/accessibility";
import {useMetadata} from "../../../hooks/metadataHook";
import {useAuth} from "../../../hooks/authenticationHook.jsx";
const WorldPerformanceGraph = ({id, data, dataSeries, pluginHistorySeries}) => {
const {t} = useTranslation();
const {graphTheming, nightModeEnabled} = useTheme();
const {timeZoneOffsetMinutes} = useMetadata();
const {hasPermission} = useAuth();
useEffect(() => {
const spline = 'spline'
const series = {
playersOnline: {
playersOnline: hasPermission('page.server.performance.graphs.players.online') ? {
name: t('html.label.playersOnline'),
type: 'areaspline',
tooltip: tooltip.zeroDecimals,
data: dataSeries.playersOnline,
color: data.colors.playersOnline,
yAxis: 0
}, entities: {
} : {},
entities: hasPermission('page.server.performance.graphs.entities') ? {
name: t('html.label.loadedEntities'),
type: spline,
tooltip: tooltip.zeroDecimals,
data: dataSeries.entities,
color: nightModeEnabled ? withReducedSaturation(data.colors.entities) : data.colors.entities,
yAxis: 1
}, chunks: {
} : {},
chunks: hasPermission('page.server.performance.graphs.chunks') ? {
name: t('html.label.loadedChunks'),
type: spline,
tooltip: tooltip.zeroDecimals,
data: dataSeries.chunks,
color: nightModeEnabled ? withReducedSaturation(data.colors.chunks) : data.colors.chunks,
yAxis: 2
}
} : {}
};
NoDataDisplay(Highcharts);

View File

@ -1,6 +1,6 @@
@import "../../node_modules/bootstrap/scss/bootstrap"
@import "src/components/calendar/calendar-fixes"
@import "../components/calendar/calendar-fixes"
p, span, td, .h3, a, button
.svg-inline--fa, .fa, .far, .fas, .fab

View File

@ -12,10 +12,10 @@ import ExtendableRow from "../../components/layout/extension/ExtendableRow";
import {useAuth} from "../../hooks/authenticationHook";
const ServerPerformance = () => {
const {hasPermission} = useAuth();
const {hasPermission, hasChildPermission} = useAuth();
const {identifier} = useParams();
const seeGraphs = hasPermission('page.server.performance.graphs');
const seeGraphs = hasChildPermission('page.server.performance.graphs');
const seeOverview = hasPermission('page.server.performance.overview');
const {data, loadingError} = useDataRequest(fetchPerformanceOverview, [identifier], seeOverview);

File diff suppressed because it is too large Load Diff