Porovnat revize
Žádné společné commity. „main“ a „3.0“ mají zcela odlišnou historii.
3
.drone.status
Normální soubor
3
.drone.status
Normální soubor
@ -0,0 +1,3 @@
|
||||
{
|
||||
"url": "https://drone.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo/"
|
||||
}
|
58
.drone.yml
Normální soubor
58
.drone.yml
Normální soubor
@ -0,0 +1,58 @@
|
||||
---
|
||||
kind: pipeline
|
||||
name: default
|
||||
|
||||
clone:
|
||||
disable: true
|
||||
|
||||
steps:
|
||||
- name: clone
|
||||
image: alpine/git
|
||||
commands:
|
||||
- git clone https://git.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo.git sources
|
||||
- cd sources && git checkout $DRONE_COMMIT
|
||||
|
||||
- name: lint
|
||||
image: alpine
|
||||
commands:
|
||||
- apk update
|
||||
- apk add --no-cache build-base curl unzip
|
||||
- apk add --no-cache lua5.1 lua5.1-dev luarocks5.1
|
||||
- luarocks-5.1 install luacheck
|
||||
- cd sources
|
||||
- luacheck ./*.lua
|
||||
|
||||
- name: build
|
||||
image: alpine
|
||||
commands:
|
||||
- apk update && apk add --no-cache zip
|
||||
# Delete unneeded files/dirs
|
||||
- rm -rf sources/.git
|
||||
- rm -f sources/.drone.status
|
||||
- rm -f sources/.drone.yml
|
||||
- rm -f sources/.luacheckrc
|
||||
# Set Version and AddonVersion
|
||||
- export VERSION=$DRONE_TAG
|
||||
- export ADDON_VERSION=$(echo $DRONE_TAG | sed -E 's/(0|)\.//g')
|
||||
- sed -i "s/0.123456789/$VERSION/g" sources/AchievementInfoCommon.lua
|
||||
- sed -i "s/0.123456789/$VERSION/g" sources/AchievementInfo.txt
|
||||
- sed -i "s/0.123456789/$ADDON_VERSION/g" sources/AchievementInfo.txt
|
||||
# Rename and zip
|
||||
- mv sources AchievementInfo
|
||||
- zip -r "AchievementInfo-$DRONE_TAG.zip" ./AchievementInfo
|
||||
when:
|
||||
event:
|
||||
- tag
|
||||
|
||||
- name: release
|
||||
image: plugins/gitea-release
|
||||
settings:
|
||||
base_url: https://git.f-brinker.de
|
||||
api_key:
|
||||
from_secret: gitea_token
|
||||
files: ./*.zip
|
||||
title: AchievementInfo ${DRONE_TAG}
|
||||
note: AchievementInfo/CHANGELOG.md
|
||||
when:
|
||||
event:
|
||||
- tag
|
@ -1,55 +0,0 @@
|
||||
name: Workflow
|
||||
run-name: ${{ gitea.actor }} is linting and creating a new release on tag pushes 🚀
|
||||
on: [push]
|
||||
|
||||
jobs:
|
||||
|
||||
Linting:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Check out repository code
|
||||
uses: actions/checkout@v4
|
||||
- name: Run Luacheck linter
|
||||
uses: lunarmodules/luacheck@v1
|
||||
|
||||
Release:
|
||||
needs: [Linting]
|
||||
if: ${{ startsWith(github.ref, 'refs/tags/') }} # only for tags
|
||||
runs-on: ubuntu-latest
|
||||
env:
|
||||
Version: ${{ gitea.ref_name }}
|
||||
steps:
|
||||
- name: Check out repository code
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
path: sources
|
||||
- name: Delete unneeded files/dirs
|
||||
run: |
|
||||
rm -rf sources/.git
|
||||
rm -rf sources/.gitea
|
||||
rm -rf sources/screenshots
|
||||
rm -f sources/.luacheckrc
|
||||
- name: Set Version and AddonVersion
|
||||
run: |
|
||||
echo "Version: ${{ env.Version }}"
|
||||
export ADDON_VERSION=$(echo ${{ env.Version }} | sed -E 's/(0|)\.//g')
|
||||
sed -i "s/0.123456789/${{ env.Version }}/g" sources/AchievementInfoCommon.lua
|
||||
sed -i "s/0.123456789/${{ env.Version }}/g" sources/AchievementInfo.txt
|
||||
sed -i "s/0.123456789/$ADDON_VERSION/g" sources/AchievementInfo.txt
|
||||
- name: Rename and zip
|
||||
run: |
|
||||
mv sources AchievementInfo
|
||||
zip -r "AchievementInfo-${{ env.Version }}.zip" ./AchievementInfo
|
||||
- name: Create release
|
||||
id: create_release
|
||||
uses: akkuman/gitea-release-action@v1
|
||||
with:
|
||||
token: ${{ secrets.token }}
|
||||
name: "AchievementInfo ${{ env.Version }}"
|
||||
tag_name: "${{ env.Version }}"
|
||||
body_path: AchievementInfo/CHANGELOG.md
|
||||
draft: false
|
||||
prerelease: false
|
||||
sha256sum: true
|
||||
files: |-
|
||||
*.zip
|
@ -17,8 +17,7 @@ read_globals = {
|
||||
"EVENT_ACHIEVEMENT_UPDATED",
|
||||
"EVENT_ADD_ON_LOADED",
|
||||
"EVENT_MANAGER",
|
||||
"LINK_STYLE_BRACKETS",
|
||||
"LINK_STYLE_BRACKET",
|
||||
"zo_callLater",
|
||||
"zo_strformat",
|
||||
"ZO_SavedVars",
|
||||
}
|
@ -15,7 +15,6 @@ function AchievementInfo.initialize(_, addOnName)
|
||||
AchievementInfo.hijackedFirstLoad = true
|
||||
|
||||
-- Load Saved Variables
|
||||
AchievementInfo.useAccountWideSettings = AchievementInfo.loadUseAccountWideSettings()
|
||||
AchievementInfo.savedVars = AchievementInfo.loadSavedVars()
|
||||
|
||||
-- Load Language Data
|
||||
|
@ -5,8 +5,8 @@
|
||||
## Author: |c87B7CCAsto|r, @Astarax
|
||||
## Contact: mail@coded-with-heart.com
|
||||
|
||||
## APIVersion: 101044
|
||||
## SavedVariables: ACHIEVEMENT_INFO_DB ACHIEVEMENT_INFO_DB_USE_AW
|
||||
## APIVersion: 100031
|
||||
## SavedVariables: ACHIEVEMENT_INFO_DB
|
||||
|
||||
## DependsOn: LibAddonMenu-2.0
|
||||
|
||||
|
@ -49,7 +49,7 @@ function AchievementInfo.onAchievementUpdated(_, achId)
|
||||
local percentageStep = false
|
||||
local percentageStepSize = AchievementInfo.settingGet("genShowUpdateSteps")
|
||||
|
||||
local link = GetAchievementLink(achId, LINK_STYLE_BRACKETS)
|
||||
local link = GetAchievementLink(achId, LINK_STYLE_BRACKET)
|
||||
local catName = "/"
|
||||
|
||||
if categoryId ~= false then
|
||||
@ -67,18 +67,13 @@ function AchievementInfo.onAchievementUpdated(_, achId)
|
||||
tmpOutput = tmpOutput .. ", "
|
||||
end
|
||||
|
||||
tmpOutput = tmpOutput .. zo_strformat("<<1>>", description) .. " "
|
||||
tmpOutput = tmpOutput .. description .. " "
|
||||
tmpOutput = tmpOutput .. AchievementInfo.calcCriteriaColor(numCompleted, numRequired) .. numCompleted .. "|r"
|
||||
tmpOutput = tmpOutput .. AchievementInfo.clrDefault .. "/" .. "|r"
|
||||
tmpOutput = tmpOutput .. AchievementInfo.clrCriteriaComplete .. numRequired .. "|r"
|
||||
tmpOutput = tmpOutput .. AchievementInfo.clrDefault
|
||||
|
||||
if AchievementInfo.settingGet("genShowOpenDetailsOnly") == true then
|
||||
if numCompleted ~= numRequired then
|
||||
detailOutput[detailOutputCount] = tmpOutput
|
||||
detailOutputCount = detailOutputCount + 1
|
||||
end
|
||||
else
|
||||
if AchievementInfo.settingGet("genShowOpenDetailsOnly") == true and numCompleted ~= numRequired then
|
||||
detailOutput[detailOutputCount] = tmpOutput
|
||||
detailOutputCount = detailOutputCount + 1
|
||||
end
|
||||
|
@ -35,9 +35,6 @@ LANG_STORE.EN.SettingsOption.AddOnEnabled = "AddOn enabled"
|
||||
LANG_STORE.EN.SettingsOption.AddOnEnabledTooltip = "Enable or disable this AddOn"
|
||||
LANG_STORE.EN.SettingsOption.AddOnEnabledWarning = "Only the output messages can be disabled here"
|
||||
|
||||
LANG_STORE.EN.SettingsOption.AccountWideEnabled = "Use account-wide Settings"
|
||||
LANG_STORE.EN.SettingsOption.AccountWideEnabledTooltip = "Use and edit the same settings for all characters"
|
||||
|
||||
LANG_STORE.EN.SettingsOption.ShowEveryUpdate = "Show every update"
|
||||
LANG_STORE.EN.SettingsOption.ShowEveryUpdateTooltip = "Shows a message on every status update of an achievement. Otherwise the messages appear only in steps of x%"
|
||||
|
||||
@ -89,9 +86,6 @@ LANG_STORE.DE.SettingsOption.AddOnEnabled = "AddOn aktiviert"
|
||||
LANG_STORE.DE.SettingsOption.AddOnEnabledTooltip = "Aktiviere oder deaktiviere dieses AddOn"
|
||||
LANG_STORE.DE.SettingsOption.AddOnEnabledWarning = "An dieser Stelle können nur die Ausgaben deaktiviert werden."
|
||||
|
||||
LANG_STORE.DE.SettingsOption.AccountWideEnabled = "Accountübergreifende Einstellungen"
|
||||
LANG_STORE.DE.SettingsOption.AccountWideEnabledTooltip = "Benutze und speichere die Einstellungen für alle Charaktere"
|
||||
|
||||
LANG_STORE.DE.SettingsOption.ShowEveryUpdate = "Zeige alle Fortschritte"
|
||||
LANG_STORE.DE.SettingsOption.ShowEveryUpdateTooltip = "Zeigt bei jeder Aktualisierung eines Erfolgs einen Hinweis. Alternativ wird nur in x% Schritten ein Status ausgegeben"
|
||||
|
||||
@ -144,9 +138,6 @@ LANG_STORE.FR.SettingsOption.AddOnEnabled = "Extension activée"
|
||||
LANG_STORE.FR.SettingsOption.AddOnEnabledTooltip = "Active ou désactive cette extension"
|
||||
LANG_STORE.FR.SettingsOption.AddOnEnabledWarning = "Seul les messages sortants peuvent être désactivés"
|
||||
|
||||
LANG_STORE.FR.SettingsOption.AccountWideEnabled = LANG_STORE.EN.SettingsOption.AccountWideEnabled
|
||||
LANG_STORE.FR.SettingsOption.AccountWideEnabledTooltip = LANG_STORE.EN.SettingsOption.AccountWideEnabledTooltip
|
||||
|
||||
LANG_STORE.FR.SettingsOption.ShowEveryUpdate = "Affichage de chaque mise à jour"
|
||||
LANG_STORE.FR.SettingsOption.ShowEveryUpdateTooltip = "Affiche un message pour chaque mise à jour d'un succès. Le reste du temps les messages n'apparaissent que sous forme de plage de x%"
|
||||
|
||||
|
@ -5,15 +5,6 @@
|
||||
|
||||
|
||||
|
||||
-- Function to determine if Account Wide Settings should be used
|
||||
function AchievementInfo.loadUseAccountWideSettings()
|
||||
return ZO_SavedVars:New("ACHIEVEMENT_INFO_DB_USE_AW", 1, nil, {
|
||||
enabled = false
|
||||
})
|
||||
end
|
||||
|
||||
|
||||
|
||||
-- Function to set and load the Saved Variables
|
||||
function AchievementInfo.loadSavedVars()
|
||||
local defaults = {
|
||||
@ -45,14 +36,9 @@ function AchievementInfo.loadSavedVars()
|
||||
cat20 = true,
|
||||
cat21 = true,
|
||||
cat22 = true,
|
||||
-- ... new one default to true
|
||||
devDebug = false
|
||||
}
|
||||
|
||||
if AchievementInfo.useAccountWideSettings["enabled"] == true then
|
||||
return ZO_SavedVars:NewAccountWide("ACHIEVEMENT_INFO_DB", 1, nil, defaults)
|
||||
end
|
||||
|
||||
return ZO_SavedVars:New("ACHIEVEMENT_INFO_DB", 1, nil, defaults)
|
||||
end
|
||||
|
||||
@ -63,16 +49,16 @@ function AchievementInfo.createSettingsPanel()
|
||||
local panelData = {
|
||||
type = "panel",
|
||||
name = AchievementInfo.name,
|
||||
displayName = AchievementInfo.clrDefault .. AchievementInfo.name,
|
||||
displayName = AchievementInfo.clrDefault..AchievementInfo.name,
|
||||
author = AchievementInfo.author,
|
||||
version = string.format("%.2f", AchievementInfo.version),
|
||||
version = string.format("%.1f", AchievementInfo.version),
|
||||
slashCommand = "/achievementInfo"
|
||||
}
|
||||
|
||||
local optionsTable = {
|
||||
[1] = {
|
||||
type = "header",
|
||||
name = AchievementInfo.clrSettingsHeader .. LANG.SettingsHeader.General
|
||||
name = AchievementInfo.clrSettingsHeader..LANG.SettingsHeader.General
|
||||
},
|
||||
[2] = {
|
||||
type = "checkbox",
|
||||
@ -83,21 +69,13 @@ function AchievementInfo.createSettingsPanel()
|
||||
warning = LANG.SettingsOption.AddOnEnabledWarning
|
||||
},
|
||||
[3] = {
|
||||
type = "checkbox",
|
||||
name = LANG.SettingsOption.AccountWideEnabled,
|
||||
tooltip = LANG.SettingsOption.AccountWideEnabledTooltip,
|
||||
getFunc = function() return AchievementInfo.useAccountWideSettings["enabled"] end,
|
||||
setFunc = function() AchievementInfo.toggleAccountWideSettings() end,
|
||||
requiresReload = true
|
||||
},
|
||||
[4] = {
|
||||
type = "checkbox",
|
||||
name = LANG.SettingsOption.ShowEveryUpdate,
|
||||
tooltip = LANG.SettingsOption.ShowEveryUpdateTooltip,
|
||||
getFunc = function() return AchievementInfo.settingGet("genShowEveryUpdate") end,
|
||||
setFunc = function() AchievementInfo.settingToogle("genShowEveryUpdate") end
|
||||
},
|
||||
[5] = {
|
||||
[4] = {
|
||||
type = "slider",
|
||||
name = LANG.SettingsOption.ShowUpdateSteps,
|
||||
tooltip = LANG.SettingsOption.ShowUpdateStepsTooltip,
|
||||
@ -108,21 +86,21 @@ function AchievementInfo.createSettingsPanel()
|
||||
setFunc = function(value) AchievementInfo.settingSet("genShowUpdateSteps", value) end,
|
||||
default = 25
|
||||
},
|
||||
[6] = {
|
||||
[5] = {
|
||||
type = "checkbox",
|
||||
name = LANG.SettingsOption.ShowDetails,
|
||||
tooltip = LANG.SettingsOption.ShowDetailsTooltip,
|
||||
getFunc = function() return AchievementInfo.settingGet("genShowDetails") end,
|
||||
setFunc = function() AchievementInfo.settingToogle("genShowDetails") end
|
||||
},
|
||||
[7] = {
|
||||
[6] = {
|
||||
type = "checkbox",
|
||||
name = LANG.SettingsOption.ShowOpenDetailsOnly,
|
||||
tooltip = LANG.SettingsOption.ShowOpenDetailsOnlyTooltip,
|
||||
getFunc = function() return AchievementInfo.settingGet("genShowOpenDetailsOnly") end,
|
||||
setFunc = function() AchievementInfo.settingToogle("genShowOpenDetailsOnly") end
|
||||
},
|
||||
[8] = {
|
||||
[7] = {
|
||||
type = "checkbox",
|
||||
name = LANG.SettingsOption.OneElementPerLine,
|
||||
tooltip = LANG.SettingsOption.OneElementPerLineTooltip,
|
||||
@ -130,11 +108,11 @@ function AchievementInfo.createSettingsPanel()
|
||||
setFunc = function() AchievementInfo.settingToogle("genOnePerLine") end,
|
||||
warning = LANG.SettingsOption.OneElementPerLineWarning
|
||||
},
|
||||
[9] = {
|
||||
[8] = {
|
||||
type = "header",
|
||||
name = AchievementInfo.clrSettingsHeader .. LANG.SettingsHeader.Categories
|
||||
},
|
||||
[10] = {
|
||||
[9] = {
|
||||
type = "description",
|
||||
text = LANG.SettingsHeader.CategoriesDescription .. ":"
|
||||
}
|
||||
@ -150,8 +128,8 @@ function AchievementInfo.createSettingsPanel()
|
||||
type = "checkbox",
|
||||
name = catName,
|
||||
tooltip = LANG.SettingsOption.CategoryTooltip .. " '" .. catName .. "'",
|
||||
getFunc = function() return AchievementInfo.settingGetForCategory("cat" .. i) end,
|
||||
setFunc = function() AchievementInfo.settingToogle("cat" .. i) end
|
||||
getFunc = function() return AchievementInfo.settingGet("cat"..i) end,
|
||||
setFunc = function() AchievementInfo.settingToogle("cat"..i) end
|
||||
})
|
||||
end
|
||||
|
||||
@ -171,8 +149,8 @@ function AchievementInfo.createSettingsPanel()
|
||||
})
|
||||
|
||||
-- Register
|
||||
LibAddonMenu2:RegisterAddonPanel(AchievementInfo.name .. "SettingsPanel", panelData)
|
||||
LibAddonMenu2:RegisterOptionControls(AchievementInfo.name .. "SettingsPanel", optionsTable)
|
||||
LibAddonMenu2:RegisterAddonPanel(AchievementInfo.name.."SettingsPanel", panelData)
|
||||
LibAddonMenu2:RegisterOptionControls(AchievementInfo.name.."SettingsPanel", optionsTable)
|
||||
end
|
||||
|
||||
|
||||
@ -189,18 +167,6 @@ end
|
||||
|
||||
|
||||
|
||||
-- Function to retrieve settings for categories (default true)
|
||||
function AchievementInfo.settingGetForCategory(id)
|
||||
if AchievementInfo.savedVars[id] == nil then
|
||||
AchievementInfo.savedVars[id] = true
|
||||
return true
|
||||
else
|
||||
return AchievementInfo.savedVars[id]
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
-- Function to toggle Checkbox values
|
||||
function AchievementInfo.settingToogle(id)
|
||||
if AchievementInfo.savedVars[id] == false then
|
||||
@ -212,17 +178,6 @@ end
|
||||
|
||||
|
||||
|
||||
-- Function to toggle Checkbox value for accountWideSettings
|
||||
function AchievementInfo.toggleAccountWideSettings()
|
||||
if AchievementInfo.useAccountWideSettings["enabled"] == false then
|
||||
AchievementInfo.useAccountWideSettings["enabled"] = true
|
||||
else
|
||||
AchievementInfo.useAccountWideSettings["enabled"] = false
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
-- Function to set settings
|
||||
function AchievementInfo.settingSet(id, value)
|
||||
AchievementInfo.savedVars[id] = value
|
||||
|
13
CHANGELOG.md
13
CHANGELOG.md
@ -1,18 +1,5 @@
|
||||
#### Notable Changes
|
||||
|
||||
##### Release 4.15
|
||||
* Fixed "bracket style" of the achievement links, thanks to DakJaniels
|
||||
|
||||
##### Release 4.5
|
||||
* Fixed "ShowDetails" option working only in combination with "ShowOpenDetailsOnly"
|
||||
|
||||
##### Release 4.3
|
||||
* Fixed an error with gendered achievement descriptions
|
||||
|
||||
##### Release 4.0
|
||||
* Added accountwide settings
|
||||
* Added an "use accountwide settings" option to the settings of each character
|
||||
|
||||
##### Release 3.0
|
||||
* Removed the bundled Dependency LibAddonMenu-2.0: You have to download it on your own now
|
||||
|
||||
|
29
README.md
29
README.md
@ -1,33 +1,12 @@
|
||||
# AchievementInfo
|
||||
|
||||
[![Version Status](https://monitoring.f-brinker.de/api/badge/18/status?style=plastic&upLabel=Up%20to%20date&downLabel=Outdated)](https://monitoring.f-brinker.de/status/eso)
|
||||
[![Build Status](https://git.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo/actions/workflows/build.yaml/badge.svg)](https://git.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo/actions)
|
||||
|
||||
[![Build Status](https://drone.f-brinker.de/api/badges/fbrinker/elderscrolls-addon-achievementInfo/status.svg)](https://drone.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo)
|
||||
[![Latest Releases](https://badgen.net/badge/releases/latest)](https://git.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo/releases)
|
||||
[![Downloads](https://badgen.net/https/scripts.f-brinker.de/esoui-stats/badge-total.php?cache=1800)](https://www.esoui.com/downloads/info350-AchievementInfo.html)
|
||||
[![Favorites](https://badgen.net/https/scripts.f-brinker.de/esoui-stats/badge-fav.php?cache=1800)](https://www.esoui.com/downloads/info350-AchievementInfo.html)
|
||||
|
||||
This is a **The Elderscrolls Online** addon. [See all details and the download @ESOUI](http://www.esoui.com/downloads/info350-AchievementInfo.html#info).
|
||||
This is an **The Elderscrolls Online** addon. [See all details and the download @ESOUI](http://www.esoui.com/downloads/info350-AchievementInfo.html#info).
|
||||
|
||||
[Issue-Tracker](https://git.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo/issues)
|
||||
|
||||
## Description
|
||||
|
||||
### What is this AddOn about?
|
||||
|
||||
I like achievements, and I like to know what to do to complete them and what type of achievements exist without browsing through the entire achievement catalog: This AddOn displays lightweight chat notifications if you make progress in an achievement (please see the screenshots).
|
||||
|
||||
### Features
|
||||
|
||||
* Shows chat notifications if you do something that is needed for an achievement
|
||||
* Triggers on each action or just in x% steps of the achievement's requirements (configurable)
|
||||
* Can show some details in the chat notification like (kill 250/1000 Humanoids)
|
||||
* You can toggle the notifications for each category
|
||||
* Lightweight: It is not always present and shows up only when necessary
|
||||
* You can enable account-wide settings
|
||||
|
||||
![preview screenshot](screenshots/chat-1.jpg)
|
||||
|
||||
## Why is this a public project?
|
||||
|
||||
In case I quit or pause playing TESO and cannot maintain this addon, feel free to contribute to keep this up to date and running.
|
||||
@ -35,9 +14,9 @@ I'll still be available here and be able to update the ESOUI page.
|
||||
|
||||
## How to contribute?
|
||||
|
||||
**IMPORTANT: Github is a mirror.** Please contribute at [git.f-brinker.de/elderscrolls-addon-achievementInfo](https://git.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo) - You can log in with your Github or Gitlab account (OAuth2).
|
||||
**IMPORTANT: Github is a mirror.** Please contribute at [git.f-brinker.de/elderscrolls-addon-achievementInfo](https://git.f-brinker.de/fbrinker/elderscrolls-addon-achievementInfo) - You can login with your Github or Gitlab account (OAuth2).
|
||||
|
||||
Then, create a fork of the repository, do what you have to do, and create a pull-request afterward. Feel free to contact me any time.
|
||||
Then, create a fork of the repository, do what you have to do and create a pull-request afterwards. Feel free to contact me any time.
|
||||
|
||||
#### Linting
|
||||
Luacheck is used to check the LUA code. [Documentation](https://luacheck.readthedocs.io/en/stable/index.html)
|
||||
|
binární
screenshots/chat-1.jpg
binární
screenshots/chat-1.jpg
Binární soubor nebyl zobrazen.
Před Šířka: | Výška: | Velikost: 60 KiB |
binární
screenshots/chat-2.jpg
binární
screenshots/chat-2.jpg
Binární soubor nebyl zobrazen.
Před Šířka: | Výška: | Velikost: 21 KiB |
binární
screenshots/settings.jpg
binární
screenshots/settings.jpg
Binární soubor nebyl zobrazen.
Před Šířka: | Výška: | Velikost: 91 KiB |
Načítá se…
Odkázat v novém úkolu
Zablokovat Uživatele