Compare commits
6 commits
8a36617298
...
bb858ef261
| Author | SHA1 | Date | |
|---|---|---|---|
| bb858ef261 | |||
| da8749e1a7 | |||
| bfefcd757e | |||
| 56165d0cef | |||
| bd6068d263 | |||
| f07bd10306 |
5 changed files with 63 additions and 11 deletions
|
|
@ -3,7 +3,7 @@
|
|||
|
||||
inputs.nixpkgs.url = "nixpkgs/nixos-unstable";
|
||||
|
||||
outputs = { nixpkgs, ... }:
|
||||
outputs = { nixpkgs, self, ... }:
|
||||
let
|
||||
pkgs = nixpkgs.legacyPackages.x86_64-linux;
|
||||
lib = nixpkgs.lib;
|
||||
|
|
@ -27,7 +27,9 @@
|
|||
};
|
||||
packages.x86_64-linux = rec {
|
||||
default = leek;
|
||||
leek = pkgs.callPackage ./package.nix { };
|
||||
leek = pkgs.callPackage ./package.nix {
|
||||
gitRev = self.sourceInfo.shortRev or self.sourceInfo.dirtyShortRev;
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
|
|
|
|||
14
package.nix
14
package.nix
|
|
@ -1,10 +1,10 @@
|
|||
{
|
||||
kdePackages,
|
||||
python3Packages,
|
||||
qt6
|
||||
{ kdePackages
|
||||
, python3Packages
|
||||
, qt6
|
||||
, gitRev ? "dirty"
|
||||
}: python3Packages.buildPythonApplication rec {
|
||||
pname = "leek";
|
||||
version = "0.0.1";
|
||||
version = gitRev;
|
||||
pyproject = true;
|
||||
|
||||
src = ./.;
|
||||
|
|
@ -13,7 +13,7 @@
|
|||
python3Packages.setuptools
|
||||
];
|
||||
|
||||
|
||||
|
||||
dependencies = with python3Packages; [
|
||||
pyside6
|
||||
tomlkit
|
||||
|
|
@ -25,7 +25,7 @@
|
|||
|
||||
propagatedBuildInputs = [
|
||||
kdePackages.kirigami
|
||||
];
|
||||
];
|
||||
|
||||
makeWrapperArgs = [
|
||||
"\${qtWrapperArgs[@]}"
|
||||
|
|
|
|||
|
|
@ -1,10 +1,16 @@
|
|||
import tomlkit
|
||||
import json
|
||||
from pathlib import Path
|
||||
from tomlkit import TOMLDocument
|
||||
from typing import Any
|
||||
|
||||
|
||||
class Mod:
|
||||
__config: TOMLDocument
|
||||
|
||||
__has_meta_json: bool
|
||||
__meta: dict[str, Any]
|
||||
|
||||
__path: Path
|
||||
__name: str
|
||||
__description: str
|
||||
|
|
@ -18,19 +24,36 @@ class Mod:
|
|||
# Mod metadata
|
||||
@property
|
||||
def name(self) -> str | None:
|
||||
if self.__has_meta_json:
|
||||
if "name" in self.__meta:
|
||||
return self.__meta.get("name", str)
|
||||
if "name" not in self.__config:
|
||||
return None
|
||||
return self.__config.get("name", str)
|
||||
|
||||
@property
|
||||
def description(self) -> str | None:
|
||||
if self.__has_meta_json:
|
||||
if "description" in self.__meta:
|
||||
return self.__meta.get("description", str)
|
||||
if "description" not in self.__config.keys():
|
||||
return None
|
||||
else:
|
||||
return self.__config.get("description", str)
|
||||
|
||||
@property
|
||||
def long_description(self) -> str | None:
|
||||
if "descriptionLong" in self.__meta:
|
||||
return self.__meta.get("descriptionLong", str)
|
||||
return None
|
||||
|
||||
@property
|
||||
def author(self) -> str | None:
|
||||
# TODO: return list with authors
|
||||
if self.__has_meta_json:
|
||||
if "authors" in self.__meta:
|
||||
authors: list[str] = self.__meta.get("authors", list[str])
|
||||
return ", ".join(authors)
|
||||
if "author" not in self.__config:
|
||||
return None
|
||||
return self.__config.get("author", str)
|
||||
|
|
@ -53,6 +76,7 @@ class Mod:
|
|||
|
||||
def __init__(self, path: Path) -> None:
|
||||
self.__path = path
|
||||
self.__meta = {}
|
||||
|
||||
try:
|
||||
config_toml = Path(self.__path, "config.toml")
|
||||
|
|
@ -61,11 +85,21 @@ class Mod:
|
|||
|
||||
if "enabled" not in self.__config:
|
||||
raise InvalidModError("config.toml does not contain the enabled key")
|
||||
else:
|
||||
self.__enabled = self.__config.get("enabled", bool)
|
||||
self.__enabled = self.__config.get("enabled", bool)
|
||||
except FileNotFoundError:
|
||||
raise InvalidModError("config.toml does not exist")
|
||||
|
||||
meta_json: Path = Path(self.__path, "meta.json")
|
||||
if meta_json.exists():
|
||||
self.__has_meta_json = True
|
||||
try:
|
||||
with meta_json.open() as file:
|
||||
self.__meta = json.load(file)
|
||||
except json.JSONDecodeError as e:
|
||||
print("Failed to parse meta.json!: ", e.msg)
|
||||
else:
|
||||
self.__has_meta_json = False
|
||||
|
||||
def __str__(self) -> str:
|
||||
return f"Mod({self.__path})"
|
||||
|
||||
|
|
|
|||
|
|
@ -83,6 +83,16 @@ Kirigami.ApplicationWindow {
|
|||
}
|
||||
Controls.Button {
|
||||
text: "Delete"
|
||||
onClicked: notImplementedDialog.open()
|
||||
Kirigami.Dialog {
|
||||
id: notImplementedDialog
|
||||
title: "Not implemented!"
|
||||
standardButtons: Kirigami.Dialog.Ok
|
||||
padding: Kirigami.Units.largeSpacing
|
||||
Controls.Label {
|
||||
text: "Deleting is not implemented yet"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -9,6 +9,8 @@ QML_IMPORT_NAME = "Leek"
|
|||
QML_IMPORT_MAJOR_VERSION = 1
|
||||
|
||||
|
||||
# Qt follows C++ naming conventions
|
||||
# ruff: noqa: N802
|
||||
@QmlElement
|
||||
@QmlUncreatable("QMod is intended to be returned by a QModListModel")
|
||||
class QMod(QObject):
|
||||
|
|
@ -34,6 +36,10 @@ class QMod(QObject):
|
|||
def description(self) -> str | None:
|
||||
return self.__mod.description
|
||||
|
||||
@Property(str, constant=True)
|
||||
def longDescription(self) -> str | None:
|
||||
return self.__mod.long_description
|
||||
|
||||
mod_enabled = Signal(name="enabled")
|
||||
|
||||
@Property(bool, notify=mod_enabled)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue