Update, and force DBS.js decoder encoding to prevent breakage on Windows

This commit is contained in:
DUOLabs333
2023-07-18 07:15:40 -04:00
parent 06869e03dd
commit ae008cfbc2
8 changed files with 19677 additions and 19217 deletions

View File

@@ -71,7 +71,7 @@ def dl_file(path):
for url in urls:
dl_file(url)
db_data = open(root + "code/dbs/DBS.js").read()
db_data = open(root + "code/dbs/DBS.js",encoding="utf-8").read()
db_vars = re.findall(r"var (\w+)\s*=\s*(\{[\w\W]+?\n\s*\})\s*(?=;|/\*|var)", db_data)
db = {}
@@ -119,7 +119,8 @@ def decompress_font_list(flist):
yield Font(ff, fsf, psn, int(flg), int(cat), url)
prev_ff, prev_fsf, prev_flg, prev_cat = ff, fsf, flg, cat
for font in decompress_font_list(db["FNTS"]["list"]):
print(font.url)
if '--fonts' in sys.argv:
for font in decompress_font_list(db["FNTS"]["list"]):
path = "rsrc/fonts/" + font.url

View File

@@ -44,6 +44,9 @@ var PIMG = {
"tools/pen" : "",
"tools/fpen" : "",
"tools/cpen" : "",
"tools/aapoint" : "",
"tools/dapoint" : "",
"tools/capoint" : "",
"tools/gradient" : "",
"tools/hand" : "",
"tools/rview" : "",
@@ -77,6 +80,7 @@ var PIMG = {
"tools/slice" : "",
"tools/sselect" : "",
"tools/artb" : "",
"tools/mremove" : "",
"adj/brit" : "",
"adj/levl" : "",
"adj/curv" : "",
@@ -7973,7 +7977,7 @@ var LNG = {
},
{
"name": "繁体中文",
"code": "zh-HK",
"code": "zh-CHT",
"table": 23
},
{

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@@ -1,328 +1,328 @@
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/dropbox@10.9.0/dist/Dropbox-sdk.min.js"></script>
</head>
<body onload="go()">
<script type="text/javascript" >
var sentFalse = false;
var authDone = false;
var lastMsg, authUrl;
var DROPBOX_APP_KEY = "ylv5pcromn2df1o"; //'7rlydkifdtp5gnb';
var redirectUri = "https://www.photopea.com/code/storages/dropboxStorage.html";
var dbx = new Dropbox.Dropbox({ clientId: DROPBOX_APP_KEY });
function go() {
if (window.name == "authwin")
{
authDone = false;
window.setTimeout(function()
{
var searchParams = new URLSearchParams(window.location.search.substr(1));
var dropboxCode = searchParams.get('code');
window.opener.saveCode(dropboxCode);
send("ready",true);
window.setTimeout(function()
{
window.close();
}, 400);
}, 100);
}
else
{
dbx.auth.accessToken = localStorage.getItem('dropboxAccessToken');
window.addEventListener("message", onMessage,false);
doAction(checkUser);
}
}
function handleError(e)
{
console.log(e);
if(e.error && e.error == "multiple_colons") { send(1,"Rename path contains more than one colon."); }
else
{
send("ready",false);
sentFalse = true;
}
}
function saveCode(code)
{
dbx.auth.getAccessTokenFromCode(redirectUri, code)
.then(function({ result })
{
dbx.auth.accessToken = result.access_token;
localStorage.setItem('dropboxAccessToken', result.access_token);
authDone = true;
if(retryAction) { doAction(retryAction.action, retryAction.prms, 1); retryAction = null; }
else send("ready",true);
})
.catch(function(error) { handleError(error); });
}
function signOut()
{
var w = window.open("https://www.dropbox.com/logout", 'logoutwin', 'width=700,height=800');
if(!w) { handleError("Popup window blocked.") }
else
{
dbx.authTokenRevoke()
.then(function({ result })
{
send(0,"");
})
.catch(function(error) { handleError(error); });
window.setTimeout(function()
{
w.close();
}, 5000);
}
}
//check valid accessToken and proceed, or try to reauthenticate
function doAction(action, prms)
{
if(action == signOut) { signOut(); }
else if(sentFalse) { authenticate(action,prms); }
else if(dbx.auth.accessToken)
{
dbx.checkUser({"query": ""})
.then(function(e) {
action(prms);
})
.catch(function(e)
{
handleError(e);
});
}
else { handleError("No Access Token present."); }
}
function handleListResult(response, prms, out)
{
var entries = response.result.entries;
if (!out) { out = []; };
for (var i = 0; i<entries.length; ++i)
{
if (entries[i][".tag"] == "file")
{
out.push([entries[i].name,entries[i].size, Date.parse(entries[i].server_modified)/1000]);
}
else out.push([entries[i].name,-1, 0]);
}
if(response.result.has_more)
{
prms.cursor = response.result.cursor;
listDir(prms, out);
}
else
{
getThumbnailPage(prms, 0, out);
}
}
function listDir(prms, out)
//recursively listdir until no more .has_more, passing out array with every call
{
if(prms.path == "/") { prms.path = ""; }
if(prms.cursor)
{
dbx.filesListFolderContinue({cursor: prms.cursor})
.then(function(response) { handleListResult(response,prms,out); })
.catch(function(error) { handleError(error); });
}
else
{
dbx.filesListFolder({path: prms.path})
.then(function(response) { handleListResult(response,prms,out); })
.catch(function(error) { handleError(error); });
}
}
function getThumbnailPage(prms, i, out)
{
var ii = i;
var thumbnailExtenstions = ["jpg", "jpeg", "png", "tiff", "tif", "gif", "webp", "ppm", "bmp",
"JPG", "JPEG", "PNG", "TIFF", "TIF", "GIF", "WEBP", "PPM", "BMP"];
var query = [];
while(query.length < 25 && ii < out.length)
{
if(thumbnailExtenstions.includes(out[ii][0].split('.').pop()))
{
query.push({"path" : prms.path + "/" + out[ii][0], "format" : "png"});
}
++ii;
}
dbx.filesGetThumbnailBatch({entries:query})
.then(function(response) {
ii = i;
var j = 0;
while(j < 25 && ii < out.length)
{
//could just check names from metadata, probably faster than .includes
if(thumbnailExtenstions.includes(out[ii][0].split('.').pop()))
{
out[ii].push(response.result.entries[j].thumbnail)
++j
}
++ii;
}
if(ii < out.length) { getThumbnailPage(prms, ii, out); }
else { convertThumbnail(prms, 0, out) }
})
.catch(function(e) { console.log(e); })
}
function convertThumbnail(prms, i, out)
{
if(i == out.length) { send(0,out); }
else if(out[i].length == 4)
{
fetch("data:image/png;base64,"+out[i][3])
.then(function(result) {
result.blob()
.then(function(blob) {
out[i][3] = URL.createObjectURL(blob);
convertThumbnail(prms, i+1, out);
})
.catch(function(e) { handleError(e); });
})
.catch(function(e) { handleError(e); });
}
else { convertThumbnail(prms, i+1, out); }
}
function downloadFile(prms)
{
dbx.filesDownload({"path" : prms.path})
.then(function(response) {
response.result.fileBlob.arrayBuffer()
.then(function(buffer) { window.parent.postMessage(buffer,"*"); })
.catch(function(e) { handleError(e); });
})
.catch(function(response) {
handleError(response);
});
}
function downloadThumbnail(prms)
{
dbx.filesGetThumbnail({"path" : prms.path, "format" : "png"})
.then(function(response) {
var blobURL = URL.createObjectURL(response.result.fileBlob);
console.log(blobURL);
var xhr = new XMLHttpRequest();
xhr.open('GET', blobURL, true);
xhr.responseType = "arraybuffer";
xhr.onload = function(e) {window.parent.postMessage(e.target.response,"*"); };
xhr.onerror = function(e) { console.error(e); };
xhr.send();
})
.catch(function(response) {
handleError(response);
});
}
function uploadFile(prms)
{
var file = new Blob([prms.buffer]);
dbx.filesUpload({"path": prms.path, "contents": file, "mode" : "overwrite"})
.then(function(response) { send(0,""); })
.catch(function(error) { send(1,error); });
}
function deleteFile(prms)
{
dbx.filesDelete({ "path" : prms.path })
.then(function(response) { send(0,""); })
.catch(function(error) { send(1,error); });
}
function makeFolder(prms)
{
dbx.filesCreateFolderV2({ "path" : prms.path.slice(0, -1) })
.then(function(response) { send(0,""); })
.catch(function(error) { send(1,error); });
}
function renameFile(prms)
{
dbx.filesMoveV2({ "from_path": prms.from_path, "to_path": prms.to_path })
.then(function(response) {send(0,""); })
.catch(function(error) { send(1,error); });
}
function authenticate(action, prms)
{
sentFalse = false;
if(action) { retryAction = { "action": action, "prms": prms }; }
dbx.auth.getAuthenticationUrl(
redirectUri,
'',
'code',
'',
[
'account_info.read',
'files.content.write',
'files.content.read',
],
'user',
true,)
.then(function(url)
{
var w = window.open(url, 'authwin', 'width=700,height=800');
if(!w) { handleError("Popup window blocked.") }
else
{
var popupTick = setInterval(function()
{
if (w.closed)
{
clearInterval(popupTick);
if (!authDone) { handleError("Authorization failed (window closed without authorization completing.") }
}
}, 500);
}
});
}
function checkUser(prms)
{
send("ready",true);
}
function onMessage(e) {
if((typeof e.data) == "string") {
var msg = JSON.parse(e.data);
console.log(msg);
if(msg.code=="show") { doAction(listDir, { "path" : msg.prm }); }
else if(msg.code=="load") { doAction(downloadFile, { "path" : msg.prm }); }
//else if(msg.code=="load") { doAction(downloadThumbnail, { "path" : msg.prm }); }
else if(msg.code=="delete") { doAction(deleteFile, { "path" : msg.prm }); }
else if(msg.code=="save" && msg.prm.endsWith("/")) { doAction(makeFolder, { "path" : msg.prm }); }
else if(msg.code=="forget") { doAction(signOut); }
else if(msg.code=="rename")
{
var prmSplit = msg.prm.split(":");
if (prmSplit.length > 2) { handleError({"error" : "multiple_colons"}); return; }
else { doAction(renameFile, { "from_path" : prmSplit[0], "to_path" : prmSplit[0].substring(0,prmSplit[0].lastIndexOf("/")+1)+prmSplit[1] }); }
}
lastMsg=msg;
}
else {
if(lastMsg.code=="save") doAction(uploadFile, { "path": lastMsg.prm, "buffer" : e.data });
}
}
function send(code,prm) {
window.parent.postMessage(JSON.stringify({"code":code, "prm":prm}),"*");
}
</script>
</body>
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/dropbox@10.9.0/dist/Dropbox-sdk.min.js"></script>
</head>
<body onload="go()">
<script type="text/javascript" >
var sentFalse = false;
var authDone = false;
var lastMsg, authUrl;
var DROPBOX_APP_KEY = "ylv5pcromn2df1o"; //'7rlydkifdtp5gnb';
var redirectUri = window.location.href;
var dbx = new Dropbox.Dropbox({ clientId: DROPBOX_APP_KEY });
function go() {
if (window.name == "authwin")
{
authDone = false;
window.setTimeout(function()
{
var searchParams = new URLSearchParams(window.location.search.substr(1));
var dropboxCode = searchParams.get('code');
window.opener.saveCode(dropboxCode);
send("ready",true);
window.setTimeout(function()
{
window.close();
}, 400);
}, 100);
}
else
{
dbx.auth.accessToken = localStorage.getItem('dropboxAccessToken');
window.addEventListener("message", onMessage,false);
doAction(checkUser);
}
}
function handleError(e)
{
console.log(e);
if(e.error && e.error == "multiple_colons") { send(1,"Rename path contains more than one colon."); }
else
{
send("ready",false);
sentFalse = true;
}
}
function saveCode(code)
{
dbx.auth.getAccessTokenFromCode(redirectUri, code)
.then(function({ result })
{
dbx.auth.accessToken = result.access_token;
localStorage.setItem('dropboxAccessToken', result.access_token);
authDone = true;
if(retryAction) { doAction(retryAction.action, retryAction.prms, 1); retryAction = null; }
else send("ready",true);
})
.catch(function(error) { handleError(error); });
}
function signOut()
{
var w = window.open("https://www.dropbox.com/logout", 'logoutwin', 'width=700,height=800');
if(!w) { handleError("Popup window blocked.") }
else
{
dbx.authTokenRevoke()
.then(function({ result })
{
send(0,"");
})
.catch(function(error) { handleError(error); });
window.setTimeout(function()
{
w.close();
}, 5000);
}
}
//check valid accessToken and proceed, or try to reauthenticate
function doAction(action, prms)
{
if(action == signOut) { signOut(); }
else if(sentFalse) { authenticate(action,prms); }
else if(dbx.auth.accessToken)
{
dbx.checkUser({"query": ""})
.then(function(e) {
action(prms);
})
.catch(function(e)
{
handleError(e);
});
}
else { handleError("No Access Token present."); }
}
function handleListResult(response, prms, out)
{
var entries = response.result.entries;
if (!out) { out = []; };
for (var i = 0; i<entries.length; ++i)
{
if (entries[i][".tag"] == "file")
{
out.push([entries[i].name,entries[i].size, Date.parse(entries[i].server_modified)/1000]);
}
else out.push([entries[i].name,-1, 0]);
}
if(response.result.has_more)
{
prms.cursor = response.result.cursor;
listDir(prms, out);
}
else
{
getThumbnailPage(prms, 0, out);
}
}
function listDir(prms, out)
//recursively listdir until no more .has_more, passing out array with every call
{
if(prms.path == "/") { prms.path = ""; }
if(prms.cursor)
{
dbx.filesListFolderContinue({cursor: prms.cursor})
.then(function(response) { handleListResult(response,prms,out); })
.catch(function(error) { handleError(error); });
}
else
{
dbx.filesListFolder({path: prms.path})
.then(function(response) { handleListResult(response,prms,out); })
.catch(function(error) { handleError(error); });
}
}
function getThumbnailPage(prms, i, out)
{
var ii = i;
var thumbnailExtenstions = ["jpg", "jpeg", "png", "tiff", "tif", "gif", "webp", "ppm", "bmp",
"JPG", "JPEG", "PNG", "TIFF", "TIF", "GIF", "WEBP", "PPM", "BMP"];
var query = [];
while(query.length < 25 && ii < out.length)
{
if(thumbnailExtenstions.includes(out[ii][0].split('.').pop()))
{
query.push({"path" : prms.path + "/" + out[ii][0], "format" : "png"});
}
++ii;
}
dbx.filesGetThumbnailBatch({entries:query})
.then(function(response) {
ii = i;
var j = 0;
while(j < 25 && ii < out.length)
{
//could just check names from metadata, probably faster than .includes
if(thumbnailExtenstions.includes(out[ii][0].split('.').pop()))
{
out[ii].push(response.result.entries[j].thumbnail)
++j
}
++ii;
}
if(ii < out.length) { getThumbnailPage(prms, ii, out); }
else { convertThumbnail(prms, 0, out) }
})
.catch(function(e) { console.log(e); })
}
function convertThumbnail(prms, i, out)
{
if(i == out.length) { send(0,out); }
else if(out[i].length == 4)
{
fetch("data:image/png;base64,"+out[i][3])
.then(function(result) {
result.blob()
.then(function(blob) {
out[i][3] = URL.createObjectURL(blob);
convertThumbnail(prms, i+1, out);
})
.catch(function(e) { handleError(e); });
})
.catch(function(e) { handleError(e); });
}
else { convertThumbnail(prms, i+1, out); }
}
function downloadFile(prms)
{
dbx.filesDownload({"path" : prms.path})
.then(function(response) {
response.result.fileBlob.arrayBuffer()
.then(function(buffer) { window.parent.postMessage(buffer,"*"); })
.catch(function(e) { handleError(e); });
})
.catch(function(response) {
handleError(response);
});
}
function downloadThumbnail(prms)
{
dbx.filesGetThumbnail({"path" : prms.path, "format" : "png"})
.then(function(response) {
var blobURL = URL.createObjectURL(response.result.fileBlob);
console.log(blobURL);
var xhr = new XMLHttpRequest();
xhr.open('GET', blobURL, true);
xhr.responseType = "arraybuffer";
xhr.onload = function(e) {window.parent.postMessage(e.target.response,"*"); };
xhr.onerror = function(e) { console.error(e); };
xhr.send();
})
.catch(function(response) {
handleError(response);
});
}
function uploadFile(prms)
{
var file = new Blob([prms.buffer]);
dbx.filesUpload({"path": prms.path, "contents": file, "mode" : "overwrite"})
.then(function(response) { send(0,""); })
.catch(function(error) { send(1,error); });
}
function deleteFile(prms)
{
dbx.filesDelete({ "path" : prms.path })
.then(function(response) { send(0,""); })
.catch(function(error) { send(1,error); });
}
function makeFolder(prms)
{
dbx.filesCreateFolderV2({ "path" : prms.path.slice(0, -1) })
.then(function(response) { send(0,""); })
.catch(function(error) { send(1,error); });
}
function renameFile(prms)
{
dbx.filesMoveV2({ "from_path": prms.from_path, "to_path": prms.to_path })
.then(function(response) {send(0,""); })
.catch(function(error) { send(1,error); });
}
function authenticate(action, prms)
{
sentFalse = false;
if(action) { retryAction = { "action": action, "prms": prms }; }
dbx.auth.getAuthenticationUrl(
redirectUri,
'',
'code',
'',
[
'account_info.read',
'files.content.write',
'files.content.read',
],
'user',
true,)
.then(function(url)
{
var w = window.open(url, 'authwin', 'width=700,height=800');
if(!w) { handleError("Popup window blocked.") }
else
{
var popupTick = setInterval(function()
{
if (w.closed)
{
clearInterval(popupTick);
if (!authDone) { handleError("Authorization failed (window closed without authorization completing.") }
}
}, 500);
}
});
}
function checkUser(prms)
{
send("ready",true);
}
function onMessage(e) {
if((typeof e.data) == "string") {
var msg = JSON.parse(e.data);
console.log(msg);
if(msg.code=="show") { doAction(listDir, { "path" : msg.prm }); }
else if(msg.code=="load") { doAction(downloadFile, { "path" : msg.prm }); }
//else if(msg.code=="load") { doAction(downloadThumbnail, { "path" : msg.prm }); }
else if(msg.code=="delete") { doAction(deleteFile, { "path" : msg.prm }); }
else if(msg.code=="save" && msg.prm.endsWith("/")) { doAction(makeFolder, { "path" : msg.prm }); }
else if(msg.code=="forget") { doAction(signOut); }
else if(msg.code=="rename")
{
var prmSplit = msg.prm.split(":");
if (prmSplit.length > 2) { handleError({"error" : "multiple_colons"}); return; }
else { doAction(renameFile, { "from_path" : prmSplit[0], "to_path" : prmSplit[0].substring(0,prmSplit[0].lastIndexOf("/")+1)+prmSplit[1] }); }
}
lastMsg=msg;
}
else {
if(lastMsg.code=="save") doAction(uploadFile, { "path": lastMsg.prm, "buffer" : e.data });
}
}
function send(code,prm) {
window.parent.postMessage(JSON.stringify({"code":code, "prm":prm}),"*");
}
</script>
</body>
</html>

View File

@@ -1,80 +1,80 @@

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0" />
<meta name="thumbnail" content="https://www.photopea.com/promo/screens/scr5.png" />
<meta name="theme-color" content="#474747">
<title>Photopea | Online Photo Editor</title>
<link rel="apple-touch-icon" href="promo/icon512.png">
<link rel="icon" sizes="512x512" href="promo/icon512.png">
<link rel="image_src" type="image/png" href="promo/icon512.png" />
<link rel="manifest" href="manifest.json">
<link rel="chrome-webstore-item" href="//chrome.google.com/webstore/detail/fmophgdjdipcbfjiopifpngdjmemonko">
<meta name="description" content="Photopea Online Photo Editor lets you edit photos, apply effects, filters, add text, crop or resize pictures. Do Online Photo Editing in your browser for free!" />
<link rel="stylesheet" href="style/all.css" />
<style>
#cap {
font-size: 1.3em;
padding:2% 2% 1em 2%; background-color: #0f171d; /*background-image: linear-gradient(rgb(20, 20, 22), rgb(40,40,45));*/
color:#e6e6e6; text-align:center;
/*position:absolute; z-index:10; margin:1em; border-radius: 1em;*/
}
#cap a { color:inherit; font-weight:bold; }
#cap p { margin-bottom:1.5em; line-height:1.5em; }
h1 { font-size: 2.3em; margin:0.5em 0; letter-spacing: 0em; line-height:1.2em; }
strong { display:inline-block; font-size: 1.1em; background:rgba(0,0,0,0.1); padding:0.1em 0.5em;
margin: 0.2em 0.5em 0.2em 0; border-radius:0.3em; font-weight:normal; line-height:1.7}
</style>
<script>
function showCap() {_showCap(true);} function hideCap() {_showCap(false);}
function _showCap(vis){
document.getElementById("cap").setAttribute("style", vis?"":"display:none;");
localStorage.setItem("capShown", ""+vis);
}
</script>
</head>
<body class="theme0">
<!---->
<div id="cap">
<span style="position:absolute;right:0;top:0;font-size:7em;margin:0 0.2em;cursor:pointer;" onclick="hideCap()"></span>
<img style="width:8em; height:8em; margin-top:1em;" src="promo/icon512.png" alt="Photopea logo" />
<h1>Photopea: advanced photo editor</h1>
<p style="font-size:1.3em">Free online photo editor supporting <b>PSD</b>, <b>XCF</b>, <b>Sketch</b>, <b>XD</b> and <b>CDR</b> formats.
(<b>Adobe Photoshop</b>, <b>GIMP</b>, <b>Sketch App</b>, <b>Adobe XD</b> and <b>CorelDRAW</b>).</p>
<p>Create a new image or open existing files from your computer. Save your work as PSD
(File - Save as PSD) or as JPG / PNG / SVG (File - Export). Suggest new features at our
<a href="//github.com/photopea/photopea/issues" target="_blank">GitHub</a> or <a href="//www.facebook.com/photopea/" target="_blank">Facebook</a>.
Our goal is to create <a href="https://blog.photopea.com/introduction.html" target="_blank">the most advanced and affordable photo editor</a>.</p>
<span><!--<a href="mailto:support@photopea.com">-->support@photopea.com<!--</a>-->
| Reddit: <a target="_blank" href="//www.reddit.com/r/photopea/">/r/Photopea</a>
| <a target="_blank" href="/privacy.html">Privacy Policy</a></span>
</div>
<!---->
<script>if(localStorage.getItem("capShown")=="false" || window.self != window.top) hideCap();</script>
<script src="code/ext/ext.js"></script>
<script src="code/dbs/DBS.js"></script>
<script src="code/pp/pp.js"></script>
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https:#/gtag/js?id=G-49YR1RB5KP"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag("js", new Date()); gtag('config', 'G-49YR1RB5KP'); //gtag("config", "UA-4249565-37");
</script>
</body>
</html>

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, minimum-scale=1.0, maximum-scale=1.0, initial-scale=1.0" />
<meta name="thumbnail" content="https://www.photopea.com/promo/screens/scr5.png" />
<meta name="theme-color" content="#474747">
<title>Photopea | Online Photo Editor</title>
<link rel="apple-touch-icon" href="promo/icon512.png">
<link rel="icon" sizes="512x512" href="promo/icon512.png">
<link rel="image_src" type="image/png" href="promo/icon512.png" />
<link rel="manifest" href="manifest.json">
<link rel="chrome-webstore-item" href="//chrome.google.com/webstore/detail/fmophgdjdipcbfjiopifpngdjmemonko">
<meta name="description" content="Photopea Online Photo Editor lets you edit photos, apply effects, filters, add text, crop or resize pictures. Do Online Photo Editing in your browser for free!" />
<link rel="stylesheet" href="style/all.css" />
<style>
#cap {
font-size: 1.3em;
padding:2% 2% 1em 2%; background-color: #0f171d; /*background-image: linear-gradient(rgb(20, 20, 22), rgb(40,40,45));*/
color:#e6e6e6; text-align:center;
/*position:absolute; z-index:10; margin:1em; border-radius: 1em;*/
}
#cap a { color:inherit; font-weight:bold; }
#cap p { margin-bottom:1.5em; line-height:1.5em; }
h1 { font-size: 2.3em; margin:0.5em 0; letter-spacing: 0em; line-height:1.2em; }
strong { display:inline-block; font-size: 1.1em; background:rgba(0,0,0,0.1); padding:0.1em 0.5em;
margin: 0.2em 0.5em 0.2em 0; border-radius:0.3em; font-weight:normal; line-height:1.7}
</style>
<script>
function showCap() {_showCap(true);} function hideCap() {_showCap(false);}
function _showCap(vis){
document.getElementById("cap").setAttribute("style", vis?"":"display:none;");
localStorage.setItem("capShown", ""+vis);
}
</script>
</head>
<body class="theme0">
<!---->
<div id="cap">
<span style="position:absolute;right:0;top:0;font-size:7em;margin:0 0.2em;cursor:pointer;" onclick="hideCap()"></span>
<img style="width:8em; height:8em; margin-top:1em;" src="promo/icon512.png" alt="Photopea logo" />
<h1>Photopea: advanced photo editor</h1>
<p style="font-size:1.3em">Free online photo editor supporting <b>PSD</b>, <b>XCF</b>, <b>Sketch</b>, <b>XD</b> and <b>CDR</b> formats.
(<b>Adobe Photoshop</b>, <b>GIMP</b>, <b>Sketch App</b>, <b>Adobe XD</b> and <b>CorelDRAW</b>).</p>
<p>Create a new image or open existing files from your computer. Save your work as PSD
(File - Save as PSD) or as JPG / PNG / SVG (File - Export). Suggest new features at our
<a href="//github.com/photopea/photopea/issues" target="_blank">GitHub</a> or <a href="//www.facebook.com/photopea/" target="_blank">Facebook</a>.
Our goal is to create <a href="https://blog.photopea.com/introduction.html" target="_blank">the most advanced and affordable photo editor</a>.</p>
<span><!--<a href="mailto:support@photopea.com">-->support@photopea.com<!--</a>-->
| Reddit: <a target="_blank" href="//www.reddit.com/r/photopea/">/r/Photopea</a>
| <a target="_blank" href="/privacy.html">Privacy Policy</a></span>
</div>
<!---->
<script>if(localStorage.getItem("capShown")=="false" || window.self != window.top) hideCap();</script>
<script src="code/ext/ext.js"></script>
<script src="code/dbs/DBS.js"></script>
<script src="code/pp/pp.js"></script>
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-49YR1RB5KP"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag("js", new Date()); gtag('config', 'G-49YR1RB5KP'); //gtag("config", "UA-4249565-37");
</script>
</body>
</html>

File diff suppressed because one or more lines are too long

View File

@@ -1165,6 +1165,16 @@ input[type="checkbox"]:checked + label:before { content: "\2713"; }
display:inline-block;
min-width:4em;
}
.label6 .flabel
{
display:inline-block;
min-width:6em;
}
.label8 .flabel
{
display:inline-block;
min-width:8em;
}
.label12 .flabel
{
display:inline-block;