Merge branch 'master' into improved_epilogue_menu
BIN
game/gui/button/menubuttons/check.png
Normal file
After Width: | Height: | Size: 3.1 KiB |
BIN
game/gui/button/menubuttons/checkbox.png
Normal file
After Width: | Height: | Size: 3.8 KiB |
BIN
game/gui/button/menubuttons/cross.png
Normal file
After Width: | Height: | Size: 3.4 KiB |
BIN
game/gui/button/menubuttons/down.png
Normal file
After Width: | Height: | Size: 551 B |
BIN
game/gui/button/menubuttons/template_full_idle.png
Normal file
After Width: | Height: | Size: 18 KiB |
BIN
game/gui/button/menubuttons/up.png
Normal file
After Width: | Height: | Size: 541 B |
BIN
game/gui/mod_frame.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
0
game/mods/-DISABLEALLMODS.txt
Normal file
0
game/mods/-NOLOADORDER.txt
Normal file
0
game/mods/-NOMODS.txt
Normal file
|
@ -1,55 +1,120 @@
|
|||
To normal users installing multiple mods: It's recommended to only have one mod folder installed in the mods directory in case two mods have duplicate `green_fang_story` label, otherwise the game will error out if mods conflict each other, this includes not only labels but images & sound too.
|
||||
--- MOD LOADER USAGE ---
|
||||
|
||||
The game loads an alternate storyline.rpy, this allows you to control the flow of the game's storytelling
|
||||
Examples include:
|
||||
- You want to inject more stuff inbetween chapters, maybe you hate time skip writing
|
||||
- You want to have more of an after story kind of ordeal, for example expanding Ending 2
|
||||
- You want to replace the entire story route
|
||||
You can still call the vanilla game's chapters like the intro (call chapter_1) for example but you might want to either copy the vanilla scripts and mix in your edits to have full control
|
||||
If there's problems with installed mods - like if an enabled mod makes the game crash on startup - there's 3 file flags you can apply to work around it, checked only in the root of the mods folder:
|
||||
- Any file starting with "DISABLEALLMODS". This will force disable all currently installed mods, but will still load all their metadata. Removing this flag will return the mod states to how it was previously.
|
||||
- Any file starting with "NOLOADORDER". This will erase the load order/states and always load mods in folder alphabetical order, with mod states depending on the "Enable New Mods" option in the preferences menu.
|
||||
- Any file starting with "NOMODS". This turns off mod loading entirely by making the game not find any metadata files to load.
|
||||
These file flags already exist in the mods folder, but renamed to not trigger in-game. Enable them by renaming the file to take off the first hyphen.
|
||||
|
||||
You will need to learn bit of Ren'Py & bit of actual Python anyways but you don't have to think too hard in learning anything new other than familiarizing with this game's script.rpy's already defined Character objects and images, you can freely ignore most of the UI and so on for the inexperienced but passionate artist and/or writer.
|
||||
When ordering the mods in the mod menu, know that not all mod code will be loaded according to the order. Ren'Py has a feature called 'init' that will run code at certain mod-defined stages (priorities) of the engine starting up, so if one mod's init block is set to run at an earlier priority than another mod's, it doesn't what order it is in the mod loader, it will always load that init first. The only time when the order comes into effect is if 2 mod's init blocks run at the same priority, or aren't running in an init block.
|
||||
|
||||
Textbox limitation: ~300 characters / four lines, the maximum in the vanilla game's script is around roughly ~278 and that only barely overflows to four lines, so <200 characters / three lines of text should be fine.
|
||||
|
||||
--- Ideal file structure of your mod ---
|
||||
--- MOD CREATION PRE-REQUSITES ---
|
||||
|
||||
Before modding, you may want to do either of these things:
|
||||
|
||||
-Download Snoot Game as a renpy project and launch through the SDK so you can have easy access to debugging and other QoL tools, including dev mode. (Download the repo in this link: https://git.cavemanon.xyz/Cavemanon/SnootGame)
|
||||
-Open script.rpy and put 'config.developer = True' somewhere in the 'init python' block to have access to renpy's dev mode.
|
||||
|
||||
Pick the latter option if you're lazy, since you don't seriously need to use the SDK for most things.
|
||||
|
||||
|
||||
--- MOD CRREATION ---
|
||||
|
||||
When creating a mod, make a new folder within the 'mods' directory at the root of the game directory and name it whatever you want. Inside that folder, make a file called 'metadata.json', and follow the JSON file format to implement details about your mod. An example would be:
|
||||
|
||||
```
|
||||
{
|
||||
"ID": "234234u9SDjjasdhl23",
|
||||
"Name": "Test Mod",
|
||||
"Label": "test_mod_label",
|
||||
"Version": "1.0",
|
||||
"Authors": [ "Author1", "Author2", "Author3" ],
|
||||
"Links": "Link1",
|
||||
"Description": "This contains the description of my mod"
|
||||
}
|
||||
```
|
||||
|
||||
Make sure there isn't a comma at the end of the last entry in your JSON.
|
||||
|
||||
Below is all the possible entries you can put in, and explanations for what they do. Note that you don't need to put all of these in your metadata file, and infact the only hard requirement is the "ID" entry.
|
||||
|
||||
"ID" : The ID of your mod. Required to be able to load your mod at all, as it is used by the mod loader for mod orders and enabling/disabling. Make this as unique of a string as you can, like a hash. Smash your keyboard if you must. This is how the game knows to differentiate your mod from others (And can be used by other mods to find if a user has your mod installed, if they so choose).
|
||||
|
||||
"Name" : The name of your mod. If this doesn't exist, the game will assume the name of your mod folder.
|
||||
|
||||
"Label" : The label to jump to start your mod story. If this doesn't exist, the button this mod will appear as will do nothing when clicked. Useful if you're only modifying something relating to the base game.
|
||||
|
||||
"Version" : The version number of your mod.
|
||||
|
||||
"Authors" : The authors of your mod. This can be a list of strings or just a string. If it's just a string, it will display in the mod details pane with only "Author:" instead of "Authors:"
|
||||
|
||||
"Links" : The links to download your mod and/or advertisement. This can be a list of strings or just a string. If it's just a string, it will display in the mod details pane with only "Link:" instead of "Links:". In order for this to be useful, use the 'a' text tag to make these texts hyperlinks.
|
||||
|
||||
"Description" : The description of your mod.
|
||||
|
||||
"Mobile Description" : The description of your mod, but only appearing while playing Snoot on Android. If this doesn't exist, it will assume the contents of the description entry. Otherwise, you can copy your description text here and format it however you think it fits for Android.
|
||||
|
||||
"Display" : How your mod button appears if there's an icon image detected. This can be set to "name" - which only displays the mod name - "icon" - which only displays the icon, taking up the entire button - or "both" - which displays the name and icon together, with the icon miniaturized and to the side of the name. This defaults to "both" if it doesn't exist, and if an icon image is not present, it will fall back to "name" mode.
|
||||
|
||||
"Thumbnail Displayable" : What displayable to use for the thumbnail when the mod has loaded scripts. If this doesn't exist, the game will use the thumbnail image found alongside your metadata file
|
||||
|
||||
"Icon Displayable" : What displayable to use for the icon when the mod has loaded scripts. If this doesn't exist, the game will use the icon image found alongside your metadata file
|
||||
|
||||
"Screenshot Displayables" : What displayables to use for screenshots when the mod has loaded scripts. This should be a list of strings. The game will choose each displayable in the list over images found alongside the metadata file sequentially, so if there's 5 screenshot images and 3 screenshot displayables, the last 2 will still display the screenshot images, and the first 3 will display the screenshot displayables. If there's more displayables than images, then the mod will appear to gain screenshots in the mod details pane when the mod is enabled. If you enter empty strings in the list ( "" ), the game will interpret that as a deliberate skipping over to load screenshot images instead of displayables, so if your list consists of '[ "", "my_displayable" ]' and there's any number of screenshot images found, the first screenshot will still show a screenshot image, and only the next one will show a displayable. If this entry doesn't exist, it will just use the screenshot images found alongside your metadata file.
|
||||
|
||||
In the same directory as your metadata file, there's image files you can put in the to make your mod more appealing. These can be any of Ren'Py's supported image file types, so the file extension here is just for demonstration:
|
||||
|
||||
-'thumbnail.png' will appear as a banner for your mod, at the top of the mod details pane
|
||||
-'icon.png' will show a small image next your mod name or take up the entire button depending on what your "Display" entry is set to.
|
||||
-'screenshot(number).png' will show screenshots at the bottom of the mod details pane. The '(number)' is a placeholder for a number that represents what order your screenshots appear in. For example, you can have 'screenshot1.png', 'screenshot2.png', and 'screenshot3.png' in your mod directory, and they will all appear in the mod details pane in order. These numbers don't need to be strictly sequential, they can be any number as long as they are integers, and the order will be derived from ASCII ordering.
|
||||
|
||||
As the game loads the metadata, it will also collect scripts for loading. When you make your mod scripts, ALL OF THEM NEED TO HAVE .rpym EXTENSIONS. This is important for being able to control mods with the mod loader, otherwise there would be mod conflicts galore. If you use .rpy extensions to make your mod scripts, they will work, but they will not be manageable by the mod loader. This means you should only use them for development, or if you're not using the mod loader anyway - such as adding a translation to the base game.
|
||||
|
||||
Additionally, Ren'Py will not load any files from the mods folder automatically, so any and all audio/image/video files need to be manually defined to be usable.
|
||||
|
||||
--- TRANSLATION ---
|
||||
|
||||
For disambiguation, a "language code" refers to the code Ren'Py uses to refer to languages program-wide, and can be found on the folder names in "game/tl", with "None" being the default language (Representing a fallback language, but usually meaning English. Internally, it's an actual None variable)
|
||||
|
||||
For translating mods, you should use the Ren'Py SDK to automatically generate translations from mod scripts. Make sure to use a language code that Snoot supports when you do so, so you don't accidentally create a new language. Put them into an organized directory in your mod and change them to use .rpym extensions so that translations don't activate unless your mod is as well (This prevents potential conflicts from other mods from interface/string translations).
|
||||
|
||||
For assets, the easiest way is to put them in the "tl" folder and have the same filepath to your mod asset as it is from the "game" folder to your asset, just like how the officially supported translations are. This will make your mod less portable, but at least there's no namespace or file conflicts for translating images. If you're deadset on making your mod portable, you'll have to make conditionals in your mod to swap out images depending on the language, which means other people translating your mod can't just add a file somewhere and be done with it, they will need to edit your mod scripts as well.
|
||||
|
||||
For translating metadata, you can translate the .json file by creating a new .json and naming it "metadata_(language code).json" (Ex: "metadata_es.json" for spanish). Fill out the .json how you would with the normal metadata file, but with your translated strings. The game will automatically pick this up and replace the strings (or add, if there's no 'None' variant of an entry) according to your language. Note that translating the ID or Label will do nothing, so you will always need a metadata.json file with at least an ID entry even if your mod isn't in english.
|
||||
|
||||
For the images found alongisde your metadata, you can do the same thing as your .json to replace them. Simply append your language code to your image filename like "thumbnail_es.png", "icon_es.png", etc.. For screenshots, the number in your filename will determine if any given translated image will replace another image, or add it inbetween images. So if you have "screenshot4.png", and you have "screenshot2_es.png" and "screenshot5_es.png", all screenshots will show up if your language is in spanish. If there's "screenshot4_es.png" in the directory, then it will replace "screenshot4.png". The final screenshot display will always take the english screenshots as a base before replacing the images with whatever translated images that exist.
|
||||
|
||||
|
||||
--- TIPS ---
|
||||
|
||||
The Ren'Py documentation is your friend, but it is also a bitch-ass friend. It will sometimes be notoriously unhelpful, so consult other renpy dudes from the Ren'Py discord, your snoot communities, or youtube. This may also be of interest, as it will link to other documentation as well as many interesting libraries you can use:
|
||||
https://github.com/methanoliver/awesome-renpy
|
||||
|
||||
Link to Ren'Py documentation:
|
||||
https://www.renpy.org/doc/html/
|
||||
|
||||
When making the file structure for your mod, this is the ideal. Keep it nice and organized, preferably keeping the root of your mods folder clear of eveything but metadata related stuff:
|
||||
```
|
||||
In the root of the mods folder:
|
||||
folder_of_your_mod_name
|
||||
- name_of_storyline.rpy
|
||||
- metadata.json
|
||||
- Your various image metadatas
|
||||
-> asset_folder
|
||||
- asset.png
|
||||
-> script_folder
|
||||
- script.rpy
|
||||
|
||||
name_of_storyline.rpy
|
||||
- script.rpym
|
||||
-> etc. folders...
|
||||
- etc. files...
|
||||
```
|
||||
init python:
|
||||
# Modding Support variables
|
||||
# All mod rpy files must have title of their mod (this shows up on a button)
|
||||
# and finally the label that controls the flow of dialogue
|
||||
|
||||
mod_menu_access += [{
|
||||
'Name': "Mod Name",
|
||||
'Label': "mod_storyline"
|
||||
}];
|
||||
|
||||
image template_sample = Image("mods/folder_of_your_mod_name/asset_folder/asset.png")
|
||||
|
||||
label mod_storyline:
|
||||
call chapter_1_new
|
||||
To start your mod, just make it under the label you defined in your metadata file in a mod script. An example in a newly created "mymodscript.rpym":
|
||||
```
|
||||
label my_mod_label:
|
||||
scene my_background
|
||||
show my_sprite
|
||||
"blah blah dialogue"
|
||||
```
|
||||
|
||||
script_folder/script.rpy
|
||||
```
|
||||
label chapter_1_new:
|
||||
show template_sample at scenter
|
||||
"Sample Text"
|
||||
Textbox limitation: ~300 characters / four lines, the maximum in the vanilla game's script is around roughly ~278 and that only barely overflows to four lines, so <200 characters / three lines of text should be fine.
|
||||
|
||||
hide template_sample
|
||||
play music 'audio/OST/Those Other Two Weirdos.ogg'
|
||||
show anon neutral flip at aright with dissolve
|
||||
A "Sample Text"
|
||||
|
||||
return
|
||||
```
|
||||
|
||||
The funny thing is I don't even like 'fanfictions' to begin with but this mod support allows these 'fanfictions', ironic.
|
||||
If a user has many mods installed, it would be annoying to need to keep track of which mods to enable or disable because of code conflicts, so make your variables/functions unique. Since Ren'Py's own scripting doesn't support namespaced stuff, a very simple way is to prefix all your variables/functions with a mod-unique name, similar to your mod ID. An example would be "mymodisfantastic2349234_function_or_variable". Kinda ugly, but manageable with Ctrl-F and string replacement if there's problems. If there must be code conflicts, let the user know in your mod description!
|
|
@ -142,8 +142,13 @@ default persistent.enable_debug_scores = config.developer
|
|||
default persistent.enable_chapter_select = config.developer
|
||||
default persistent.lewd = False
|
||||
default persistent.autoup = False
|
||||
default persistent.show_mod_screenshots = True
|
||||
default persistent.gallery_edgescroll = True
|
||||
|
||||
init -1000 python:
|
||||
if persistent.newmods_default_state == None:
|
||||
persistent.newmods_default_state = True
|
||||
|
||||
init python:
|
||||
# No idea what this does
|
||||
if persistent.scroll == True:
|
||||
|
|
|
@ -916,6 +916,12 @@ screen preferences():
|
|||
textbutton _("Enable Debug Scores") action ToggleVariable("persistent.enable_debug_scores", True, False)
|
||||
textbutton _("Enable Chapter Select") action ToggleVariable("persistent.enable_chapter_select", True, False)
|
||||
|
||||
vbox:
|
||||
style_prefix "check"
|
||||
label _("Mods")
|
||||
textbutton _("Show Mod Screenshots") action [Function(onclick_audio, persistent.show_mod_screenshots), ToggleVariable("persistent.show_mod_screenshots", True, False)]
|
||||
textbutton _("Enable New Mods") action [Function(onclick_audio, persistent.newmods_default_state), ToggleVariable("persistent.newmods_default_state", True, False)]
|
||||
|
||||
if not main_menu:
|
||||
if config.developer and persistent.enable_debug_scores:
|
||||
$ debug_story_variables(False)
|
||||
|
|
|
@ -14,12 +14,6 @@
|
|||
#Why yes all my code was formerly in one massive file called "script" thats 28k lines long, how could you tell?
|
||||
#Licensed under the GNU AGPL v3, for more information check snootgame.xyz or the LICENSE file that should have came with this work.
|
||||
|
||||
init -1 python:
|
||||
# Modding Support variables
|
||||
# All mod rpy files must run a small init python script
|
||||
mod_dir = "mods/"
|
||||
mod_menu_access = []
|
||||
|
||||
init python:
|
||||
import webbrowser # This is for the ch2 "look the link up" choice
|
||||
import random
|
||||
|
@ -54,6 +48,22 @@ init python:
|
|||
if renpy.seen_image("fang tail"):
|
||||
renpy.mark_image_seen("fang_tail_movie")
|
||||
|
||||
# Determine the splash type for the Snoot game logo
|
||||
persistent.splashtype = random.randint(0,2000 - 1)
|
||||
|
||||
|
||||
label before_main_menu:
|
||||
# Force users pre-Patch 11 to use english if they were on 'None'
|
||||
if preferences.language == None:
|
||||
$ preferences.language = 'en'
|
||||
|
||||
# Call initial language setup screen
|
||||
if (persistent.languaged_up is None):
|
||||
$ preferences.set_volume('ui', config.default_sfx_volume)
|
||||
$ persistent.languaged_up = True
|
||||
call screen lang_sel
|
||||
|
||||
return
|
||||
|
||||
label start:
|
||||
|
||||
|
|
|
@ -352,6 +352,18 @@ init 1 python:
|
|||
|
||||
# aight, time for the stuff that isn't gallery required.
|
||||
|
||||
### SPLASHSCREEN
|
||||
|
||||
image caveintrosequence:
|
||||
"caveintro"
|
||||
alpha 0
|
||||
time 0.5
|
||||
linear 3.5 alpha 1
|
||||
time 10
|
||||
linear 1 alpha 0
|
||||
|
||||
|
||||
|
||||
### OTHER
|
||||
|
||||
|
||||
|
|
91
game/src/rounded_corners.rpy
Normal file
|
@ -0,0 +1,91 @@
|
|||
# RoundedCorners() rounds the corners of a displayable you give it
|
||||
|
||||
python early:
|
||||
import collections, pygame_sdl2 as pygame
|
||||
|
||||
def normalize_color(col):
|
||||
a = col[3] / 255.0
|
||||
r = a * col[0] / 255.0
|
||||
g = a * col[1] / 255.0
|
||||
b = a * col[2] / 255.0
|
||||
return (r, g, b, a)
|
||||
|
||||
_rounded_corners_relative = {
|
||||
None: 0.0,
|
||||
"min": 1.0,
|
||||
"max": 2.0,
|
||||
"width": 3.0,
|
||||
"height": 4.0,
|
||||
}
|
||||
|
||||
def RoundedCorners(child, radius, relative=None, outline_width=0.0, outline_color="#fff", **kwargs):
|
||||
if not isinstance(radius, tuple): radius = (radius,) * 4
|
||||
relative = _rounded_corners_relative[relative]
|
||||
outline_color = normalize_color(Color(outline_color))
|
||||
return Transform(child, mesh=True, shader="shader.rounded_corners", u_radius=radius, u_relative=relative, u_outline_color=outline_color, u_outline_width=outline_width, **kwargs)
|
||||
|
||||
CurriedRoundedCorners = renpy.curry(RoundedCorners)
|
||||
|
||||
renpy.register_shader("shader.rounded_corners", variables="""
|
||||
uniform vec4 u_radius;
|
||||
uniform float u_outline_width;
|
||||
uniform vec4 u_outline_color;
|
||||
uniform float u_relative;
|
||||
uniform sampler2D tex0;
|
||||
attribute vec2 a_tex_coord;
|
||||
varying vec2 v_tex_coord;
|
||||
uniform vec2 u_model_size;
|
||||
""", vertex_200="""
|
||||
v_tex_coord = a_tex_coord;
|
||||
""", fragment_functions="""
|
||||
float rounded_rectangle(vec2 p, vec2 b, float r) {
|
||||
return length(max(abs(p) - b + r, 0.0)) - r;
|
||||
}
|
||||
|
||||
float get_radius(vec2 uv_minus_center, vec4 radius) {
|
||||
vec2 xy = (uv_minus_center.x > 0.0) ? radius.xy : radius.zw;
|
||||
float r = (uv_minus_center.y > 0.0) ? xy.x : xy.y;
|
||||
return r;
|
||||
}
|
||||
""", fragment_200="""
|
||||
vec2 center = u_model_size.xy / 2.0;
|
||||
vec2 uv = (v_tex_coord.xy * u_model_size.xy);
|
||||
|
||||
vec2 uv_minus_center = uv - center;
|
||||
float radius = get_radius(uv_minus_center, u_radius);
|
||||
|
||||
vec4 color = texture2D(tex0, v_tex_coord);
|
||||
|
||||
if (u_relative != 0.0) {
|
||||
float side_size;
|
||||
if (u_relative == 1.0) {
|
||||
side_size = u_model_size.x;
|
||||
} else if (u_relative == 2.0) {
|
||||
side_size = u_model_size.y;
|
||||
} else if (u_relative == 3.0) {
|
||||
side_size = min(u_model_size.x, u_model_size.y);
|
||||
} else {
|
||||
side_size = max(u_model_size.x, u_model_size.y);
|
||||
}
|
||||
|
||||
radius *= side_size;
|
||||
}
|
||||
|
||||
if (u_outline_width > 0.0) {
|
||||
vec2 center_outline = center - u_outline_width;
|
||||
|
||||
float crop1 = rounded_rectangle(uv - center, center, radius);
|
||||
float crop2 = rounded_rectangle(uv - center, center_outline, radius - u_outline_width);
|
||||
|
||||
float coeff1 = smoothstep(1.0, -1.0, crop1);
|
||||
float coeff2 = smoothstep(1.0, -1.0, crop2);
|
||||
|
||||
float outline_coeff = (coeff1 - coeff2);
|
||||
|
||||
gl_FragColor = mix(vec4(0.0), mix(color, u_outline_color, outline_coeff), coeff1);
|
||||
}
|
||||
else {
|
||||
float crop = rounded_rectangle(uv_minus_center, center, radius);
|
||||
gl_FragColor = mix(color, vec4(0.0), smoothstep(0.0, 1.0, crop));
|
||||
}
|
||||
""")
|
|
@ -1,25 +1,11 @@
|
|||
|
||||
label splashscreen:
|
||||
$ persistent.splashtype = random.randint(0,2000 - 1)
|
||||
|
||||
image caveintrosequence:
|
||||
"caveintro"
|
||||
alpha 0
|
||||
time 0.5
|
||||
linear 3.5 alpha 1
|
||||
time 10
|
||||
linear 1 alpha 0
|
||||
|
||||
if not renpy.get_autoreload():
|
||||
show caveintrosequence
|
||||
play sound 'audio/OST/startup.ogg'
|
||||
pause 11.2
|
||||
stop sound
|
||||
|
||||
if (persistent.languaged_up is None):
|
||||
$ persistent.languaged_up = True
|
||||
$ preferences.set_volume('ui', config.default_sfx_volume) # hack
|
||||
call screen lang_sel
|
||||
|
||||
|
||||
return
|
||||
|
||||
|
|
|
@ -36,7 +36,7 @@ init python:
|
|||
notice = _("NOTICE: Please keep in mind this is a fan translation, and as such it may not be completely accurate to the original intent of any written lines.")
|
||||
|
||||
languages = [
|
||||
{'image': 'gui/flag/USofA.png', 'name': 'English', 'value': None },
|
||||
{'image': 'gui/flag/USofA.png', 'name': 'English', 'value': 'en' },
|
||||
{'image': 'gui/flag/Mexico.png', 'name': 'Español', 'value': 'es'},
|
||||
{'image': 'gui/flag/Rus.png', 'name': 'Русский', 'value': 'ru'},
|
||||
{'image': 'gui/flag/Poland.png', 'name': 'Polski', 'value': 'pl'},
|
||||
|
@ -106,7 +106,7 @@ screen lang_sel():
|
|||
imagebutton:
|
||||
idle darkie(languages[i]["image"])
|
||||
hover glowie(languages[i]["image"])
|
||||
action If(languages[i]["value"] in persistent.seenWarning or languages[i]["value"] == None,
|
||||
action If(languages[i]["value"] in persistent.seenWarning or languages[i]["value"] == 'en',
|
||||
true = [Language(languages[i]["value"]), MainMenu(False,False)],
|
||||
# Important to change the language before calling notice. Otherwise it will be in english.
|
||||
false = [Language(languages[i]["value"]), AddToSet(set=persistent.seenWarning, value=languages[i]["value"]), Show(screen="OkPrompt", message=notice, go_menu=True)]
|
||||
|
@ -122,7 +122,7 @@ screen lang_button(lang):
|
|||
spacing 15
|
||||
textbutton lang["name"]:
|
||||
activate_sound "audio/ui/uiRollover.wav"
|
||||
action If(lang["value"] in persistent.seenWarning or lang["value"] == None,
|
||||
action If(lang["value"] in persistent.seenWarning or lang["value"] == 'en',
|
||||
true = [Language(lang["value"])],
|
||||
false = [Language(lang["value"]), AddToSet(set=persistent.seenWarning, value=lang["value"]), Show(screen="OkPrompt", message=notice, go_menu=False)]
|
||||
)
|
||||
|
|