mirror of
https://github.com/plausible/analytics.git
synced 2024-11-30 00:58:54 +03:00
Browser icon improvements (#4246)
* Use png for Safari icon * Fix spacing for screen sizes * Add browser icon to version drilldown
This commit is contained in:
parent
766807e9fd
commit
486ee68ca8
@ -10,7 +10,7 @@ import ImportedQueryUnsupportedWarning from '../imported-query-unsupported-warni
|
|||||||
// Icons copied from https://github.com/alrra/browser-logos
|
// Icons copied from https://github.com/alrra/browser-logos
|
||||||
const BROWSER_ICONS = {
|
const BROWSER_ICONS = {
|
||||||
'Chrome': 'chrome.svg',
|
'Chrome': 'chrome.svg',
|
||||||
'Safari': 'safari.svg',
|
'Safari': 'safari.png',
|
||||||
'Firefox': 'firefox.svg',
|
'Firefox': 'firefox.svg',
|
||||||
'Microsoft Edge': 'edge.svg',
|
'Microsoft Edge': 'edge.svg',
|
||||||
'Vivaldi': 'vivaldi.svg',
|
'Vivaldi': 'vivaldi.svg',
|
||||||
@ -28,6 +28,17 @@ const BROWSER_ICONS = {
|
|||||||
'vivo Browser': 'vivo.png'
|
'vivo Browser': 'vivo.png'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function browserIconFor(browser) {
|
||||||
|
const filename = BROWSER_ICONS[browser] || 'fallback.svg'
|
||||||
|
|
||||||
|
return (
|
||||||
|
<img
|
||||||
|
src={`/images/icon/browser/${filename}`}
|
||||||
|
className="w-4 h-4 mr-2"
|
||||||
|
/>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
function Browsers({ query, site, afterFetchData }) {
|
function Browsers({ query, site, afterFetchData }) {
|
||||||
function fetchData() {
|
function fetchData() {
|
||||||
return api.get(url.apiPath(site, '/browsers'), query)
|
return api.get(url.apiPath(site, '/browsers'), query)
|
||||||
@ -41,14 +52,7 @@ function Browsers({ query, site, afterFetchData }) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function renderIcon(listItem) {
|
function renderIcon(listItem) {
|
||||||
const filename = BROWSER_ICONS[listItem.name] || 'fallback.svg'
|
return browserIconFor(listItem.name)
|
||||||
|
|
||||||
return (
|
|
||||||
<img
|
|
||||||
src={`/images/icon/browser/${filename}`}
|
|
||||||
className="w-4 h-4 mr-2"
|
|
||||||
/>
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
@ -67,6 +71,15 @@ function Browsers({ query, site, afterFetchData }) {
|
|||||||
function BrowserVersions({ query, site, afterFetchData }) {
|
function BrowserVersions({ query, site, afterFetchData }) {
|
||||||
function fetchData() {
|
function fetchData() {
|
||||||
return api.get(url.apiPath(site, '/browser-versions'), query)
|
return api.get(url.apiPath(site, '/browser-versions'), query)
|
||||||
|
.then(res => {
|
||||||
|
return {...res, results: res.results.map((row => {
|
||||||
|
return {...row, name: `${row.browser} ${row.name}`}
|
||||||
|
}))}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function renderIcon(listItem) {
|
||||||
|
return browserIconFor(listItem.browser)
|
||||||
}
|
}
|
||||||
|
|
||||||
function getFilterFor(listItem) {
|
function getFilterFor(listItem) {
|
||||||
@ -86,6 +99,7 @@ function BrowserVersions({ query, site, afterFetchData }) {
|
|||||||
getFilterFor={getFilterFor}
|
getFilterFor={getFilterFor}
|
||||||
keyLabel="Browser version"
|
keyLabel="Browser version"
|
||||||
metrics={maybeWithCR([VISITORS_METRIC, PERCENTAGE_METRIC], query)}
|
metrics={maybeWithCR([VISITORS_METRIC, PERCENTAGE_METRIC], query)}
|
||||||
|
renderIcon={renderIcon}
|
||||||
query={query}
|
query={query}
|
||||||
/>
|
/>
|
||||||
)
|
)
|
||||||
@ -150,7 +164,9 @@ function ScreenSizes({ query, site, afterFetchData }) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function renderIcon(screenSize) {
|
function renderIcon(screenSize) {
|
||||||
return iconFor(screenSize.name)
|
return (
|
||||||
|
<span className="mr-1.5">{iconFor(screenSize.name)}</span>
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
function getFilterFor(listItem) {
|
function getFilterFor(listItem) {
|
||||||
|
BIN
priv/static/images/icon/browser/safari.png
Normal file
BIN
priv/static/images/icon/browser/safari.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.1 KiB |
File diff suppressed because one or more lines are too long
Before Width: | Height: | Size: 5.1 KiB |
Loading…
Reference in New Issue
Block a user