mirror of
https://github.com/upscayl/upscayl.git
synced 2025-01-19 09:27:27 +01:00
Merge remote-tracking branch 'origin/main' into suvojit/add-upscayl-cloud-modal
This commit is contained in:
commit
0f0de851cb
2
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
2
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
@ -15,7 +15,7 @@ body:
|
|||||||
- type: textarea
|
- type: textarea
|
||||||
attributes:
|
attributes:
|
||||||
label: Paste the logs
|
label: Paste the logs
|
||||||
description: 💥 Paste the logs below - Read [Wiki](https://github.com/upscayl/upscayl/wiki) if you don't know how to
|
description: 💥 Paste the logs below ([Guide](https://github.com/upscayl/upscayl/wiki/Guide#logs))
|
||||||
value: |
|
value: |
|
||||||
<details><summary>Logs</summary><pre>
|
<details><summary>Logs</summary><pre>
|
||||||
<!-- 📃 PASTE THE LOG BELOW THIS LINE! -->
|
<!-- 📃 PASTE THE LOG BELOW THIS LINE! -->
|
||||||
|
2
.github/ISSUE_TEMPLATE/doc_issue.yml
vendored
2
.github/ISSUE_TEMPLATE/doc_issue.yml
vendored
@ -1,5 +1,5 @@
|
|||||||
name: Documentation Issue
|
name: Documentation Issue
|
||||||
description: Something wrong with the docs, release, etc
|
description: "Any issue that's not with the software itself: docs, release notes, etc"
|
||||||
labels: documentation
|
labels: documentation
|
||||||
body:
|
body:
|
||||||
- type: checkboxes
|
- type: checkboxes
|
||||||
|
@ -6,7 +6,10 @@
|
|||||||
|
|
||||||
# v2.5 is out!
|
# v2.5 is out!
|
||||||
|
|
||||||
|
<a href="https://upscayl.org/#download">
|
||||||
<img src="https://img.shields.io/github/downloads/upscayl/upscayl/total.svg?style=for-the-badge&logo=&labelColor=ede9fe&color=8e6bf6" width="200px" style="border-radius:50%"/>
|
<img src="https://img.shields.io/github/downloads/upscayl/upscayl/total.svg?style=for-the-badge&logo=&labelColor=ede9fe&color=8e6bf6" width="200px" style="border-radius:50%"/>
|
||||||
|
</a>
|
||||||
|
|
||||||
</br>
|
</br>
|
||||||
</br>
|
</br>
|
||||||
|
|
||||||
|
@ -78,6 +78,7 @@ app.on("ready", async () => {
|
|||||||
webSecurity: false,
|
webSecurity: false,
|
||||||
preload: join(__dirname, "preload.js"),
|
preload: join(__dirname, "preload.js"),
|
||||||
},
|
},
|
||||||
|
titleBarStyle: getPlatform() === "mac" ? "hiddenInset" : "default",
|
||||||
});
|
});
|
||||||
const url = isDev
|
const url = isDev
|
||||||
? "http://localhost:8000"
|
? "http://localhost:8000"
|
||||||
@ -159,20 +160,11 @@ app.on("ready", async () => {
|
|||||||
// GET IMAGE QUALITY (NUMBER) TO LOCAL STORAGE
|
// GET IMAGE QUALITY (NUMBER) TO LOCAL STORAGE
|
||||||
mainWindow.webContents
|
mainWindow.webContents
|
||||||
.executeJavaScript('localStorage.getItem("quality");', true)
|
.executeJavaScript('localStorage.getItem("quality");', true)
|
||||||
.then((overwriteToggle: string | null) => {
|
.then((lastSavedQuality: string | null) => {
|
||||||
if (overwriteToggle !== null) {
|
if (lastSavedQuality !== null) {
|
||||||
quality = parseInt(overwriteToggle);
|
quality = parseInt(lastSavedQuality);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// GET OVERWRITE SETTINGS FROM LOCAL STORAGE
|
|
||||||
mainWindow.webContents
|
|
||||||
.executeJavaScript('localStorage.getItem("overwrite");', true)
|
|
||||||
.then((lastSavedOverwrite: boolean | null) => {
|
|
||||||
if (lastSavedOverwrite !== null) {
|
|
||||||
overwrite = lastSavedOverwrite;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
mainWindow.webContents.send(commands.OS, getPlatform());
|
mainWindow.webContents.send(commands.OS, getPlatform());
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -379,6 +371,7 @@ ipcMain.handle(commands.SELECT_CUSTOM_MODEL_FOLDER, async (event, message) => {
|
|||||||
//------------------------Image Upscayl-----------------------------//
|
//------------------------Image Upscayl-----------------------------//
|
||||||
ipcMain.on(commands.UPSCAYL, async (event, payload) => {
|
ipcMain.on(commands.UPSCAYL, async (event, payload) => {
|
||||||
if (!mainWindow) return;
|
if (!mainWindow) return;
|
||||||
|
overwrite = payload.overwrite;
|
||||||
const model = payload.model as string;
|
const model = payload.model as string;
|
||||||
const gpuId = payload.gpuId as string;
|
const gpuId = payload.gpuId as string;
|
||||||
const saveImageAs = payload.saveImageAs as string;
|
const saveImageAs = payload.saveImageAs as string;
|
||||||
@ -416,8 +409,18 @@ ipcMain.on(commands.UPSCAYL, async (event, payload) => {
|
|||||||
"." +
|
"." +
|
||||||
saveImageAs;
|
saveImageAs;
|
||||||
|
|
||||||
|
// GET OVERWRITE SETTINGS FROM LOCAL STORAGE
|
||||||
|
mainWindow.webContents
|
||||||
|
.executeJavaScript('localStorage.getItem("overwrite");', true)
|
||||||
|
.then((lastSavedOverwrite: boolean | null) => {
|
||||||
|
if (lastSavedOverwrite !== null) {
|
||||||
|
console.log("Overwrite: ", lastSavedOverwrite);
|
||||||
|
overwrite = lastSavedOverwrite;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
// UPSCALE
|
// UPSCALE
|
||||||
if (fs.existsSync(outFile) && !overwrite) {
|
if (fs.existsSync(outFile) && overwrite === false) {
|
||||||
// If already upscayled, just output that file
|
// If already upscayled, just output that file
|
||||||
logit("✅ Already upscayled at: ", outFile);
|
logit("✅ Already upscayled at: ", outFile);
|
||||||
mainWindow.webContents.send(commands.UPSCAYL_DONE, outFile);
|
mainWindow.webContents.send(commands.UPSCAYL_DONE, outFile);
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import { ipcRenderer, contextBridge } from "electron";
|
import { ipcRenderer, contextBridge } from "electron";
|
||||||
|
import getPlatform from "./getPlatform";
|
||||||
|
|
||||||
// 'ipcRenderer' will be available in index.js with the method 'window.electron'
|
// 'ipcRenderer' will be available in index.js with the method 'window.electron'
|
||||||
contextBridge.exposeInMainWorld("electron", {
|
contextBridge.exposeInMainWorld("electron", {
|
||||||
@ -9,4 +10,5 @@ contextBridge.exposeInMainWorld("electron", {
|
|||||||
}),
|
}),
|
||||||
invoke: (command: string, payload: any) =>
|
invoke: (command: string, payload: any) =>
|
||||||
ipcRenderer.invoke(command, payload),
|
ipcRenderer.invoke(command, payload),
|
||||||
|
platform: getPlatform(),
|
||||||
});
|
});
|
||||||
|
@ -5,7 +5,7 @@ export default function Header({ version }: { version: string }) {
|
|||||||
<a
|
<a
|
||||||
href="https://github.com/upscayl/upscayl"
|
href="https://github.com/upscayl/upscayl"
|
||||||
target="_blank"
|
target="_blank"
|
||||||
className="outline-none focus-visible:ring-2"
|
className={`outline-none focus-visible:ring-2`}
|
||||||
data-tip="Star us on GitHub 😁">
|
data-tip="Star us on GitHub 😁">
|
||||||
<div className="flex items-center gap-3 px-5 py-5">
|
<div className="flex items-center gap-3 px-5 py-5">
|
||||||
<img src="icon.png" className="inline-block w-14" alt="Upscayl Logo" />
|
<img src="icon.png" className="inline-block w-14" alt="Upscayl Logo" />
|
||||||
|
@ -42,14 +42,14 @@ export function ImageFormatSelect({
|
|||||||
onClick={() => setExportType("jpg")}>
|
onClick={() => setExportType("jpg")}>
|
||||||
JPG
|
JPG
|
||||||
</button>
|
</button>
|
||||||
{/* WEBP */}
|
{/* WEBP
|
||||||
<button
|
<button
|
||||||
className={`btn-primary btn ${
|
className={`btn-primary btn ${
|
||||||
saveImageAs === "webp" && "btn-accent"
|
saveImageAs === "webp" && "btn-accent"
|
||||||
}`}
|
}`}
|
||||||
onClick={() => setExportType("webp")}>
|
onClick={() => setExportType("webp")}>
|
||||||
WEBP
|
WEBP
|
||||||
</button>
|
</button> */}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -11,9 +11,12 @@ export function QualityInput({
|
|||||||
}: QualityInputProps) {
|
}: QualityInputProps) {
|
||||||
return (
|
return (
|
||||||
<div className="flex flex-col gap-2">
|
<div className="flex flex-col gap-2">
|
||||||
<p className="text-sm font-medium uppercase">
|
<div className="flex gap-1 text-sm font-medium uppercase">
|
||||||
Image Compression ({quality}%)
|
<p className="shrink-0">Image Compression ({quality}%)</p>
|
||||||
</p>
|
<p className="badge-primary badge text-[10px] font-medium">
|
||||||
|
EXPERIMENTAL
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
<input
|
<input
|
||||||
type="range"
|
type="range"
|
||||||
placeholder="Type here"
|
placeholder="Type here"
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import React from "react";
|
import React from "react";
|
||||||
export function ThemeSelect() {
|
export function ThemeSelect() {
|
||||||
const availableThemes = [
|
const availableThemes = [
|
||||||
|
{ label: "upscayl", value: "upscayl" },
|
||||||
{ label: "light", value: "light" },
|
{ label: "light", value: "light" },
|
||||||
{ label: "dark", value: "dark" },
|
{ label: "dark", value: "dark" },
|
||||||
{ label: "cupcake", value: "cupcake" },
|
{ label: "cupcake", value: "cupcake" },
|
||||||
|
@ -10,22 +10,28 @@ const ToggleOverwrite = ({ overwrite, setOverwrite }: ToggleOverwriteProps) => {
|
|||||||
if (!localStorage.getItem("overwrite")) {
|
if (!localStorage.getItem("overwrite")) {
|
||||||
localStorage.setItem("overwrite", JSON.stringify(overwrite));
|
localStorage.setItem("overwrite", JSON.stringify(overwrite));
|
||||||
} else {
|
} else {
|
||||||
setOverwrite(localStorage.getItem("overwrite"));
|
const currentlySavedOverwrite = localStorage.getItem("overwrite");
|
||||||
|
if (currentlySavedOverwrite) {
|
||||||
|
setOverwrite(JSON.parse(currentlySavedOverwrite));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="flex flex-col gap-2">
|
<div className="flex flex-col gap-2">
|
||||||
<p className="text-sm font-medium">OVERWRITE PREVIOUS UPSCALE</p>
|
<p className="text-sm font-medium">OVERWRITE PREVIOUS UPSCALE</p>
|
||||||
<input
|
<input
|
||||||
type="checkbox"
|
type="checkbox"
|
||||||
className="toggle-primary toggle"
|
className="toggle"
|
||||||
checked={overwrite}
|
checked={overwrite}
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
setOverwrite((oldValue) => {
|
setOverwrite((oldValue: boolean) => {
|
||||||
if (oldValue === true) {
|
if (oldValue) {
|
||||||
localStorage.removeItem("overwrite");
|
localStorage.removeItem("overwrite");
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
return !oldValue;
|
|
||||||
});
|
});
|
||||||
localStorage.setItem("overwrite", JSON.stringify(!overwrite));
|
localStorage.setItem("overwrite", JSON.stringify(!overwrite));
|
||||||
}}
|
}}
|
||||||
|
@ -130,7 +130,8 @@ function LeftPaneImageSteps({
|
|||||||
};
|
};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="animate-step-in animate flex h-screen flex-col gap-7 overflow-y-auto p-5 overflow-x-hidden">
|
<div
|
||||||
|
className={`animate-step-in animate flex h-screen flex-col gap-7 overflow-y-auto p-5 overflow-x-hidden`}>
|
||||||
{/* BATCH OPTION */}
|
{/* BATCH OPTION */}
|
||||||
<div className="flex flex-row items-center gap-2">
|
<div className="flex flex-row items-center gap-2">
|
||||||
<input
|
<input
|
||||||
@ -139,7 +140,7 @@ function LeftPaneImageSteps({
|
|||||||
defaultChecked={batchMode}
|
defaultChecked={batchMode}
|
||||||
onClick={() => setBatchMode((oldValue) => !oldValue)}></input>
|
onClick={() => setBatchMode((oldValue) => !oldValue)}></input>
|
||||||
<p
|
<p
|
||||||
className="mr-1 inline-block cursor-help text-sm"
|
className="mr-1 inline-block cursor-help text-sm"
|
||||||
data-tooltip-id="tooltip"
|
data-tooltip-id="tooltip"
|
||||||
data-tooltip-content="This will let you Upscayl all files in a folder at once">
|
data-tooltip-content="This will let you Upscayl all files in a folder at once">
|
||||||
Batch Upscayl
|
Batch Upscayl
|
||||||
|
@ -2,18 +2,22 @@ import React from "react";
|
|||||||
|
|
||||||
function RightPaneInfo({ version, batchMode }) {
|
function RightPaneInfo({ version, batchMode }) {
|
||||||
return (
|
return (
|
||||||
<>
|
<div className="flex flex-col items-center bg-base-200 p-4 rounded-btn">
|
||||||
<p className="p-5 pb-1 text-lg font-semibold">
|
<p className="pb-1 text-lg font-semibold">
|
||||||
Select {batchMode ? "a Folder" : "an Image"} to Upscayl
|
Select {batchMode ? "a Folder" : "an Image"} to Upscayl
|
||||||
</p>
|
</p>
|
||||||
{batchMode && (
|
{batchMode ? (
|
||||||
<p className="w-full pb-5 text-center md:w-96">
|
<p className="w-full pb-5 text-center md:w-96 text-primary-content/80">
|
||||||
Make sure that the folder doesn't contain anything except PNG, JPG,
|
Make sure that the folder doesn't contain anything except PNG, JPG,
|
||||||
JPEG & WEBP images.
|
JPEG & WEBP images.
|
||||||
</p>
|
</p>
|
||||||
|
) : (
|
||||||
|
<p className="w-full pb-5 text-center md:w-96 text-primary-content/80">
|
||||||
|
Select or drag and drop a PNG, JPG, JPEG or WEBP image.
|
||||||
|
</p>
|
||||||
)}
|
)}
|
||||||
<p className="text-sm">Upscayl v{version}</p>
|
<p className="text-sm badge badge-primary">Upscayl v{version}</p>
|
||||||
</>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -410,6 +410,7 @@ const Home = () => {
|
|||||||
gpuId: gpuId.length === 0 ? null : gpuId,
|
gpuId: gpuId.length === 0 ? null : gpuId,
|
||||||
saveImageAs,
|
saveImageAs,
|
||||||
scale,
|
scale,
|
||||||
|
overwrite,
|
||||||
});
|
});
|
||||||
logit("🏁 UPSCAYL");
|
logit("🏁 UPSCAYL");
|
||||||
}
|
}
|
||||||
@ -438,10 +439,27 @@ const Home = () => {
|
|||||||
|
|
||||||
const allowedFileTypes = ["png", "jpg", "jpeg", "webp"];
|
const allowedFileTypes = ["png", "jpg", "jpeg", "webp"];
|
||||||
|
|
||||||
|
if (typeof window === "undefined") {
|
||||||
|
return (
|
||||||
|
<img
|
||||||
|
src="/icon.png"
|
||||||
|
alt="Upscayl icon"
|
||||||
|
className="absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2 w-36 animate-pulse"
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="flex h-screen w-screen flex-row overflow-hidden bg-base-300">
|
<div className="flex h-screen w-screen flex-row overflow-hidden bg-base-300">
|
||||||
|
<<<<<<< HEAD
|
||||||
<div className="flex h-screen w-128 flex-col rounded-r-3xl bg-base-100">
|
<div className="flex h-screen w-128 flex-col rounded-r-3xl bg-base-100">
|
||||||
<UpscaylCloudModal show={showCloudModal} setShow={setShowCloudModal} />
|
<UpscaylCloudModal show={showCloudModal} setShow={setShowCloudModal} />
|
||||||
|
=======
|
||||||
|
<div className={`flex h-screen w-128 flex-col bg-base-100`}>
|
||||||
|
{window.electron.platform === "mac" && (
|
||||||
|
<div className="pt-8 mac-titlebar"></div>
|
||||||
|
)}
|
||||||
|
>>>>>>> origin/main
|
||||||
{/* HEADER */}
|
{/* HEADER */}
|
||||||
<div className="flex flex-row items-center">
|
<div className="flex flex-row items-center">
|
||||||
<Header version={version} />
|
<Header version={version} />
|
||||||
@ -498,6 +516,10 @@ const Home = () => {
|
|||||||
onDragEnter={(e) => handleDragEnter(e)}
|
onDragEnter={(e) => handleDragEnter(e)}
|
||||||
onDragLeave={(e) => handleDragLeave(e)}
|
onDragLeave={(e) => handleDragLeave(e)}
|
||||||
onPaste={(e) => handlePaste(e)}>
|
onPaste={(e) => handlePaste(e)}>
|
||||||
|
{window.electron.platform === "mac" && (
|
||||||
|
<div className="absolute top-0 w-full h-8 mac-titlebar"></div>
|
||||||
|
)}
|
||||||
|
|
||||||
{progress.length > 0 &&
|
{progress.length > 0 &&
|
||||||
upscaledImagePath.length === 0 &&
|
upscaledImagePath.length === 0 &&
|
||||||
upscaledBatchFolderPath.length === 0 ? (
|
upscaledBatchFolderPath.length === 0 ? (
|
||||||
@ -576,7 +598,7 @@ const Home = () => {
|
|||||||
All done!
|
All done!
|
||||||
</p>
|
</p>
|
||||||
<button
|
<button
|
||||||
className="btn btn-primary bg-gradient-blue rounded-lg p-3 font-medium text-white/90 transition-colors"
|
className="btn btn-primary bg-gradient-blue rounded-btn p-3 font-medium text-white/90 transition-colors"
|
||||||
onClick={openFolderHandler}>
|
onClick={openFolderHandler}>
|
||||||
Open Upscayled Folder
|
Open Upscayled Folder
|
||||||
</button>
|
</button>
|
||||||
|
1
renderer/renderer.d.ts
vendored
1
renderer/renderer.d.ts
vendored
@ -4,6 +4,7 @@ export interface IElectronAPI {
|
|||||||
on: (command, func?) => IpcRenderer;
|
on: (command, func?) => IpcRenderer;
|
||||||
send: (command, func?) => IpcRenderer;
|
send: (command, func?) => IpcRenderer;
|
||||||
invoke: (command, func?) => any;
|
invoke: (command, func?) => any;
|
||||||
|
platform: "mac" | "win" | "linux";
|
||||||
}
|
}
|
||||||
|
|
||||||
declare global {
|
declare global {
|
||||||
|
@ -149,6 +149,22 @@
|
|||||||
animation: animate-step-in 0.6s cubic-bezier(0.07, 0.43, 0.02, 1);
|
animation: animate-step-in 0.6s cubic-bezier(0.07, 0.43, 0.02, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[data-theme="upscayl"] .btn {
|
||||||
|
@apply ring-1 ring-slate-500 font-medium normal-case !min-h-min h-10 py-2 px-3;
|
||||||
|
}
|
||||||
|
|
||||||
|
[data-theme="upscayl"] input[type="range"] {
|
||||||
|
@apply rounded-full;
|
||||||
|
}
|
||||||
|
|
||||||
|
[data-theme="upscayl"] .react-select-container .react-select__control {
|
||||||
|
@apply rounded-btn h-10 ring-1 ring-slate-500 cursor-pointer !border-0 !border-none !border-transparent bg-primary shadow-none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mac-titlebar {
|
||||||
|
-webkit-app-region: drag;
|
||||||
|
}
|
||||||
|
|
||||||
@keyframes animate-step-in {
|
@keyframes animate-step-in {
|
||||||
0% {
|
0% {
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
|
@ -20,6 +20,26 @@ module.exports = {
|
|||||||
plugins: [require("daisyui"), require("tailwind-scrollbar")],
|
plugins: [require("daisyui"), require("tailwind-scrollbar")],
|
||||||
daisyui: {
|
daisyui: {
|
||||||
themes: [
|
themes: [
|
||||||
|
{
|
||||||
|
upscayl: {
|
||||||
|
primary: "#334155",
|
||||||
|
secondary: "#4f46e5",
|
||||||
|
accent: "#6d28d9",
|
||||||
|
neutral: "#475569",
|
||||||
|
"base-100": "#1e293b",
|
||||||
|
"base-200": "#0f172a",
|
||||||
|
"base-300": "#020617",
|
||||||
|
"--rounded-btn": "2rem", // border radius rounded-btn utility class, used in buttons and similar element
|
||||||
|
"--rounded-badge": "2rem", // border radius rounded-badge utility class, used in badges and similar
|
||||||
|
"--animation-btn": "0.5s", // duration of animation when you click on button
|
||||||
|
"--animation-input": "0.5s", // duration of animation for inputs like checkbox, toggle, radio, etc
|
||||||
|
"--btn-text-case": "uppercase", // set default text transform for buttons
|
||||||
|
"--btn-focus-scale": "0.95", // scale transform of button when you focus on it
|
||||||
|
"--border-btn": "1px", // border width of buttons
|
||||||
|
"--tab-border": "1px", // border width of tabs
|
||||||
|
"--tab-radius": "0.5rem", // border radius of tabs
|
||||||
|
},
|
||||||
|
},
|
||||||
"light",
|
"light",
|
||||||
"dark",
|
"dark",
|
||||||
"cupcake",
|
"cupcake",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user