version 0.2.0

This commit is contained in:
Ray Lothian 2018-04-10 12:20:58 +04:30
parent 6cdf075737
commit 1213fff7b3
11 changed files with 339 additions and 205 deletions

1
data/popup/explore.js Symbolic link
View file

@ -0,0 +1 @@
../../../explore.js

View file

@ -26,7 +26,7 @@ body {
background-color: #fff;
font-family: "Helvetica Neue",Helvetica,sans-serif;
font-size: 13px;
width: 700px;
width: 600px;
}
table {
width: 100%;
@ -35,7 +35,6 @@ table {
fieldset {
border: solid 1px #ccc;
}
select,
input[type=search],
input[type=text] {
width: 100%;
@ -43,15 +42,15 @@ input[type=text] {
text-indent: 5px;
padding-right: 5px;
}
select,
input {
outline: none;
background-color: #fff;
color: #000;
border: solid 1px #ccc;
border: solid 1px #e7e7e7;
box-sizing: border-box;
height: 24px;
border-radius: 0;
font-size: 11px;
}
input[type=button] {
cursor: pointer;
@ -64,29 +63,59 @@ input[type=button]:disabled {
opacity: 0.2;
cursor: default;
}
select {
-webkit-appearance: none;
-moz-appearance: none;
border: none;
user-select: none;
outline: none;
background: rgba(255,255,255,.5) url(list.svg) no-repeat center right 4px;
background-size: 8px;
font-size: 13px;
border-radius: 0;
padding: 2px 16px 2px 4px;
}
#list {
margin: 20px 0;
overflow: auto;
height: 300px;
background-color: rgba(0, 0, 0, 0.05);
margin-bottom: 10px;
background-color: #fdfafa;
background-position: top 120px center;
background-repeat: no-repeat;
}
#list[data-loading=true] {
background: url(loading.gif) top 120px center no-repeat;
background-image: url(loading.gif);
background-size: 64px;
}
#list table {
table-layout: fixed;
}
#list th {
height: 30px;
background-color: #e7e7e7;
}
#list tr {
cursor: pointer;
}
#list tr[data-matched=false] {
opacity: 0.5;
}
#list tbody {
position: relative;
}
#list tbody tr:nth-child(odd) {
background-color: #fff;
}
#list tbody tr:nth-child(even) {
background-color: #f5f5f5;
}
#list[data-loading=false] tbody:empty:before {
content: 'no user-agent string for this query!';
display: block;
position: absolute;
top: 50px;
left: 10px;
}
#list td:nth-child(1) {
text-align: center;
}
@ -117,3 +146,26 @@ input[type=button]:disabled {
#info:empty {
display: none;
}
[data-cmd="apply"] {
color: #fff;
background-color: #3c923c;
border: solid 1px #327932;
margin-right: 2px;
margin-left: 2px;
}
[data-cmd="reset"] {
color: #fff;
background-color: #eea345;
border: solid 1px #ec9730;
}
[data-cmd="refresh"] {
background-color: #f5f5f5;
}
#explore:not([data-loaded="true"]) {
margin-top: -8px;
height: 16px;
}

View file

@ -5,132 +5,132 @@
<link rel="stylesheet" href="index.css">
</head>
<body>
<div hbox id="filter">
<select id="os">
<option value="skipped">All (OS)</option>
<optgroup label="Populars">
<option value="windows">Windows</option>
<option value="mac os">Mac OS</option>
<option value="linux">Linux</option>
<option value="chromium os">Chromium OS</option>
<option value="ubuntu">Ubuntu</option>
<option value="debian">Debian</option>
<option value="android">Android</option>
<option value="ios">iOS</option>
</optgroup>
<optgroup label="Others">
<option value="amigaos">AmigaOS</option>
<option value="openbsd">OpenBSD</option>
<option value="beos">BeOS</option>
<option value="haiku">Haiku</option>
<option value="solaris">Solaris</option>
<option value="netbsd">NetBSD</option>
<option value="freebsd">FreeBSD</option>
<option value="slackware">Slackware</option>
<option value="suse">SUSE</option>
<option value="gentoo">gentoo</option>
<option value="fedora">Fedora</option>
<option value="gentoo">Gentoo</option>
<option value="mageia">Mageia</option>
<option value="centos">CentOS</option>
<option value="mint">Mint</option>
<option value="dragonfly">DragonFly</option>
<option value="kubuntu">Kubuntu</option>
<option value="mandriva">Mandriva</option>
<option value="zenwalk">Zenwalk</option>
<option value="unix">Unix</option>
<option value="gnu">GNU</option>
<option value="os/2">OS/2</option>
<option value="aix">AIX</option>
<option value="qnx">QNX</option>
<option value="beos">BEOS</option>
<option value="risc os">RISC OS</option>
<option value="symbian">Symbian</option>
<option value="nintendo">Nintendo</option>
<option value="opensolaris">OpenSolaris</option>
<option value="kubuntu">kubuntu</option>
</optgroup>
</select>
<select id="browser">
<option value="skipped">All (Browser)</option>
<optgroup label="Populars">
<option value="ie">Internet Explorer</option>
<option value="safari">Safari</option>
<option value="chrome">Chrome</option>
<option value="firefox">Firefox</option>
<option value="opera">Opera</option>
<option value="edge">Edge</option>
</optgroup>
<optgroup label="Others">
<option value="webkit">WebKit</option>
<option value="avant">Avant</option>
<option value="maxthon">Maxthon</option>
<option value="arora">Arora</option>
<option value="mozilla">Mozilla</option>
<option value="epiphany">Epiphany</option>
<option value="camino">Camino</option>
<option value="chimera">Chimera</option>
<option value="chromium">Chromium</option>
<option value="comodo dragon">Dragon</option>
<option value="conkeror">conkeror</option>
<option value="conkeror">Conkeror</option>
<option value="dillo">Dillo</option>
<option value="links">Links</option>
<option value="firebird">Firebird</option>
<option value="swiftfox">Swiftfox</option>
<option value="netscape">Netscape</option>
<option value="flock">Flock</option>
<option value="icab">iCab</option>
<option value="iceape">Iceape</option>
<option value="icecat">icecat</option>
<option value="icecat">IceCat</option>
<option value="iceweasel">IceWeasel</option>
<option value="iron">Iron</option>
<option value="k-meleon">Meleon</option>
<option value="konqueror">Konqueror</option>
<option value="lunascape">Lunascape</option>
<option value="lynx">Lynx</option>
<option value="maxthon">MAXTHON</option>
<option value="midori">midori</option>
<option value="midori">Midori</option>
<option value="khtml">KHTML</option>
<option value="mosaic">Mosaic</option>
<option value="netsurf">NetSurf</option>
<option value="omniweb">OmniWeb</option>
<option value="opera tablet">Tablet</option>
<option value="opera mini">Mini</option>
<option value="phoenix">Phoenix</option>
<option value="rockmelt">RockMelt</option>
<option value="mobile safari">Safari</option>
<option value="android browser">Browser</option>
<option value="seamonkey">SeaMonkey</option>
<option value="slim">Slim</option>
<option value="webkit">Webkit</option>
<option value="w3m">w3m</option>
</optgroup>
</select>
<select id="sort">
<option value="true">Browser version (descending)</option>
<option value="false">Browser version (ascending)</option>
</select>
</div>
<div id="list" data-loading=true>
<table>
<colgroup>
<col width="40">
<col width="100">
<col width="150">
<col width="100">
<col>
</colgroup>
<thead>
<thead id="filter">
<tr>
<th></th>
<th>Browser</th>
<th>OS</th>
<th>String</th>
<th>
<select id="browser">
<option value="skipped">All (Browser)</option>
<optgroup label="Populars">
<option value="ie">Internet Explorer</option>
<option value="safari">Safari</option>
<option value="chrome">Chrome</option>
<option value="firefox">Firefox</option>
<option value="opera">Opera</option>
<option value="edge">Edge</option>
</optgroup>
<optgroup label="Others">
<option value="webkit">WebKit</option>
<option value="avant">Avant</option>
<option value="maxthon">Maxthon</option>
<option value="arora">Arora</option>
<option value="mozilla">Mozilla</option>
<option value="epiphany">Epiphany</option>
<option value="camino">Camino</option>
<option value="chimera">Chimera</option>
<option value="chromium">Chromium</option>
<option value="comodo dragon">Dragon</option>
<option value="conkeror">conkeror</option>
<option value="conkeror">Conkeror</option>
<option value="dillo">Dillo</option>
<option value="links">Links</option>
<option value="firebird">Firebird</option>
<option value="swiftfox">Swiftfox</option>
<option value="netscape">Netscape</option>
<option value="flock">Flock</option>
<option value="icab">iCab</option>
<option value="iceape">Iceape</option>
<option value="icecat">icecat</option>
<option value="icecat">IceCat</option>
<option value="iceweasel">IceWeasel</option>
<option value="iron">Iron</option>
<option value="k-meleon">Meleon</option>
<option value="konqueror">Konqueror</option>
<option value="lunascape">Lunascape</option>
<option value="lynx">Lynx</option>
<option value="maxthon">MAXTHON</option>
<option value="midori">midori</option>
<option value="midori">Midori</option>
<option value="khtml">KHTML</option>
<option value="mosaic">Mosaic</option>
<option value="netsurf">NetSurf</option>
<option value="omniweb">OmniWeb</option>
<option value="opera tablet">Tablet</option>
<option value="opera mini">Mini</option>
<option value="phoenix">Phoenix</option>
<option value="rockmelt">RockMelt</option>
<option value="mobile safari">Safari</option>
<option value="android browser">Browser</option>
<option value="seamonkey">SeaMonkey</option>
<option value="slim">Slim</option>
<option value="webkit">Webkit</option>
<option value="w3m">w3m</option>
</optgroup>
</select>
</th>
<th>
<select id="os">
<option value="skipped">All (OS)</option>
<optgroup label="Populars">
<option value="windows">Windows</option>
<option value="mac os">Mac OS</option>
<option value="linux">Linux</option>
<option value="chromium os">Chromium OS</option>
<option value="ubuntu">Ubuntu</option>
<option value="debian">Debian</option>
<option value="android">Android</option>
<option value="ios">iOS</option>
</optgroup>
<optgroup label="Others">
<option value="amigaos">AmigaOS</option>
<option value="openbsd">OpenBSD</option>
<option value="beos">BeOS</option>
<option value="haiku">Haiku</option>
<option value="solaris">Solaris</option>
<option value="netbsd">NetBSD</option>
<option value="freebsd">FreeBSD</option>
<option value="slackware">Slackware</option>
<option value="suse">SUSE</option>
<option value="gentoo">gentoo</option>
<option value="fedora">Fedora</option>
<option value="gentoo">Gentoo</option>
<option value="mageia">Mageia</option>
<option value="centos">CentOS</option>
<option value="mint">Mint</option>
<option value="dragonfly">DragonFly</option>
<option value="kubuntu">Kubuntu</option>
<option value="mandriva">Mandriva</option>
<option value="zenwalk">Zenwalk</option>
<option value="unix">Unix</option>
<option value="gnu">GNU</option>
<option value="os/2">OS/2</option>
<option value="aix">AIX</option>
<option value="qnx">QNX</option>
<option value="beos">BEOS</option>
<option value="risc os">RISC OS</option>
<option value="symbian">Symbian</option>
<option value="nintendo">Nintendo</option>
<option value="opensolaris">OpenSolaris</option>
<option value="kubuntu">kubuntu</option>
</optgroup>
</select>
</th>
<th>
User-Agent
<select id="sort">
<option value="true">descending</option>
<option value="false">ascending</option>
</select>
</th>
</tr>
</thead>
<template>
@ -146,17 +146,18 @@
</div>
<div hbox>
<input type="search" id="custom" placeholder="Filter items">
<input type="button" value="Update" disabled="true">
<input type="button" value="Refresh" title="Refresh the current page" style="margin-left: 2px;" data-cmd="refresh">
<input type="button" value="Refresh Tab" title="Refresh the current page" style="margin-left: 2px;" data-cmd="refresh">
</div>
<div hbox id="agent" pack="center" align="center">
User-Agent String:&nbsp;
<input id="ua" type="text" name="">
<input id="ua" type="text" placeholder="Your preferred user-agent string">
<span id="info"></span>
<input type="button" value="Apply" title="Set this string as the browser's User-Agent string" data-cmd="apply">
<input type="button" value="Reset" title="Reset User-Agent string to the default one" style="margin-left: 2px;" data-cmd="reset">
</div>
<div id="explore"></div>
<script src="ua-parser.min.js"></script>
<script src="index.js"></script>
<script async src="explore.js"></script>
</body>
</html>

View file

@ -94,7 +94,7 @@ document.addEventListener('change', ({target}) => {
localStorage.setItem(target.id, target.value);
update();
}
if (target.closest('#list')) {
if (target.type === 'radio') {
document.getElementById('ua').value = target.closest('tr').querySelector('td:nth-child(4)').textContent;
}
});

File diff suppressed because one or more lines are too long

1
data/popup/list.svg Normal file
View file

@ -0,0 +1 @@
<?xml version="1.0" ?><!DOCTYPE svg PUBLIC '-//W3C//DTD SVG 1.1//EN' 'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'><svg enable-background="new 0 0 48 48" height="48px" id="Layer_3" version="1.1" viewBox="0 0 48 48" width="48px" xml:space="preserve" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><polygon fill="#241F20" points="0,12.438 48,12.438 24,35.562 "/></svg>

After

Width:  |  Height:  |  Size: 404 B