From 1cb4d2171203e7b70c45c70607f687134b4b0195 Mon Sep 17 00:00:00 2001 From: Adam Oresten Date: Tue, 22 Jun 2021 21:15:44 +0100 Subject: [PATCH] Updated to 0.8.7 --- .github/workflows/main.yml | 80 ++--- .gitignore | 1 + module.json | 76 ++--- scripts/main.js | 649 +++++++++++++++++++------------------ 4 files changed, 404 insertions(+), 402 deletions(-) create mode 100644 .gitignore diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 3b1c917..964170c 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -1,40 +1,40 @@ -name: Release Creation - -on: - release: - types: [published] - -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - # Substitute the Manifest and Download URLs in the module.json - - name: Substitute Manifest and Download Links For Versioned Ones - id: sub_manifest_link_version - uses: microsoft/variable-substitution@v1 - with: - files: 'module.json' - env: - version: ${{github.event.release.tag_name}} - url: https://github.com/${{github.repository}} - manifest: https://github.com/${{github.repository}}/releases/latest/download/module.json - download: https://github.com/${{github.repository}}/releases/download/${{github.event.release.tag_name}}/module.zip - - # Create a zip file with all files required by the module to add to the release - - run: zip -r ./module.zip module.json LICENSE styles/ scripts/ templates/ languages/ - - # Create a release for this specific version - - name: Update Release with Files - id: create_version_release - uses: ncipollo/release-action@v1 - with: - allowUpdates: true # Set this to false if you want to prevent updating existing releases - name: ${{ github.event.release.name }} - draft: false - prerelease: false - token: ${{ secrets.GITHUB_TOKEN }} - artifacts: './module.json, ./module.zip' - tag: ${{ github.event.release.tag_name }} - body: ${{ github.event.release.body }} +name: Release Creation + +on: + release: + types: [published] + +jobs: + build: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + + # Substitute the Manifest and Download URLs in the module.json + - name: Substitute Manifest and Download Links For Versioned Ones + id: sub_manifest_link_version + uses: microsoft/variable-substitution@v1 + with: + files: 'module.json' + env: + version: ${{github.event.release.tag_name}} + url: https://github.com/${{github.repository}} + manifest: https://github.com/${{github.repository}}/releases/latest/download/module.json + download: https://github.com/${{github.repository}}/releases/download/${{github.event.release.tag_name}}/module.zip + + # Create a zip file with all files required by the module to add to the release + - run: zip -r ./module.zip module.json LICENSE styles/ scripts/ templates/ languages/ + + # Create a release for this specific version + - name: Update Release with Files + id: create_version_release + uses: ncipollo/release-action@v1 + with: + allowUpdates: true # Set this to false if you want to prevent updating existing releases + name: ${{ github.event.release.name }} + draft: false + prerelease: false + token: ${{ secrets.GITHUB_TOKEN }} + artifacts: './module.json, ./module.zip' + tag: ${{ github.event.release.tag_name }} + body: ${{ github.event.release.body }} diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..bc8a670 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +.idea/* \ No newline at end of file diff --git a/module.json b/module.json index c3de60d..7d85c2a 100644 --- a/module.json +++ b/module.json @@ -1,38 +1,38 @@ -{ - "name": "potato-or-not", - "title": "Potato Or Not", - "description": "Is your computer a potoato or not? If so, this mod will prompt you that you might want to turn down your graphics.", - "version": "0.4.3", - "author": "Wasp (Wasp#2005)", - "esmodules": [ - "main.js" - ], - "languages": [ - { - "lang": "en", - "name": "English", - "path": "lang/en.json" - }, - { - "lang": "fr-FR", - "name": "Français (France)", - "path": "lang/fr-FR.json" - }, - { - "lang": "pt-BR", - "name": "Português (Brasil)", - "path": "lang/pt-BR.json" - }, - { - "lang": "es", - "name": "Español", - "path": "lang/es.json" - } - ], - "minimumCoreVersion": "0.7.7", - "compatibleCoreVersion": "0.7.9", - "url": "https://github.com/Haxxer/FoundryVTT-PotatoOrNot", - "manifest": "https://github.com/Haxxer/FoundryVTT-PotatoOrNot/releases/latest/download/module.json", - "download": "https://github.com/Haxxer/FoundryVTT-PotatoOrNot/releases/latest/download/module.zip" -} - +{ + "name": "potato-or-not", + "title": "Potato Or Not", + "description": "Is your computer a potato or not? If so, this mod will prompt you that you might want to turn down your graphics.", + "version": "0.4.4", + "author": "Wasp (Wasp#2005)", + "esmodules": [ + "scripts/main.js" + ], + "languages": [ + { + "lang": "en", + "name": "English", + "path": "languages/en.json" + }, + { + "lang": "fr-FR", + "name": "Français (France)", + "path": "languages/fr-FR.json" + }, + { + "lang": "pt-BR", + "name": "Português (Brasil)", + "path": "languages/pt-BR.json" + }, + { + "lang": "es", + "name": "Español", + "path": "languages/es.json" + } + ], + "minimumCoreVersion": "0.7.7", + "compatibleCoreVersion": "0.8.6", + "url": "https://github.com/Haxxer/FoundryVTT-PotatoOrNot", + "manifest": "https://github.com/Haxxer/FoundryVTT-PotatoOrNot/releases/latest/download/module.json", + "download": "https://github.com/Haxxer/FoundryVTT-PotatoOrNot/releases/latest/download/module.zip" +} + diff --git a/scripts/main.js b/scripts/main.js index 9daafef..571d371 100644 --- a/scripts/main.js +++ b/scripts/main.js @@ -1,325 +1,326 @@ -Hooks.on("ready", () => { - - window.PotatoOrNot = new PotatoOrNotHandler(); - - console.log("Potato Or Not | Ready") - - Hooks.call("PotatoOrNotReady"); - - window.PotatoOrNot.postSetup(); - -}); - -class PotatoOrNotHandler{ - - constructor(){ - - game.settings.register("potato-or-not", "promptUsers", { - name: "Prompt All New Users", - hint: "This will make it so that the prompt will be shown to all new users.", - scope: "world", - config: true, - default: true, - type: Boolean - }); - - game.settings.register("potato-or-not", "hasBeenPrompted", { - scope: "client", - config: false, - default: false, - type: Boolean - }); - - game.settings.register("potato-or-not", "potatoLevel", { - scope: "client", - config: false, - default: 1, - type: Number - }); - - game.settings.register("potato-or-not", "numberOfSettings", { - scope: "client", - config: false, - default: 5, - type: Number - }); - - game.settings.registerMenu("potato-or-not", "potato-or-not", { - name: "Set Up Potato Settings", - label: "Show Dialog", - icon: "fas fa-carrot", - type: PotatoOrNotApplication, - restricted: false - }); - - game.settings.register("potato-or-not", "settings", { - name: "Show Dialog", - scope: "client", - default: {}, - type: Object, - config: false - }); - - this._settings = [ - { - "core": { - "maxFPS": 20, - "softShadows": false, - "mipmap": false, - "visionAnimation": false, - "lightAnimation": false, - }, - }, - { - "core": { - "maxFPS": 30, - "softShadows": true, - "mipmap": false, - "visionAnimation": true, - "lightAnimation": true, - } - }, - { - "core": { - "maxFPS": 60, - "softShadows": true, - "mipmap": true, - "visionAnimation": true, - "lightAnimation": true, - } - } - ]; - - this._quality = game.settings.get("potato-or-not", "potatoLevel"); - - } - - get current_settings(){ - return this.settings[this.quality]; - } - - set settings(settings){ - throw "You cannot set settings directly, please use PotatoOrNot.addSetting and PotatoOrNot.removeSetting"; - } - - get settings(){ - return this._settings; - } - - _validate_quality_level(quality_level){ - if(this.settings[quality_level] === undefined) throw "quality_level must be 0, 1, or 2 - low, medium, and high settings"; - } - - _validate_module(quality_level, module){ - this._validate_quality_level(quality_level); - if(this.settings[quality_level][module] === undefined) throw `Module setting "${module}" not found in quality level of "${quality_level}"`; - } - - _validate_setting(quality_level, module, setting){ - this._validate_module(quality_level, module); - if(this.settings[quality_level][module][setting] === undefined) throw `Setting "${setting}" in module "${module}" not found`; - } - - get numberOfSettings(){ - let numberOfSettings = []; - for(let i = 0; i < this.settings.length; i++){ - numberOfSettings[i] = 0; - for(let settings of Object.values(this.settings[i])){ - numberOfSettings[i] += Object.keys(settings).length; - } - } - return numberOfSettings; - } - - postSetup(){ - let numberOfSettings = this.numberOfSettings[this.quality]; - - if(!game.settings.get('potato-or-not', 'hasBeenPrompted') && game.settings.get('potato-or-not', 'promptUsers')){ - this.showDialog(); - }else if(numberOfSettings != game.settings.get("potato-or-not", "numberOfSettings")){ - game.settings.set("potato-or-not", "numberOfSettings", numberOfSettings); - this.updateSettings(); - } - } - - updateSettings(){ - - let modules = Object.keys(this.current_settings); - - for(let module of modules){ - for(let [setting, value] of Object.entries(this.current_settings[module])){ - try{ - game.settings.set(module, setting, value); - console.log(`Potato Or Not | Set ${module}.${setting} to ${value}`); - }catch(err){ - console.error(`Potato Or Not | Could not set ${module}.${setting} to ${value}`); - } - } - } - - window.location.reload(); - - } - - /** - * Locally prompts the settings dialog - * - * @return {FormApplication} The potato FormApplication - */ - showDialog(){ - return new PotatoOrNotApplication().render(true); - } - - get quality(){ - return this._quality; - } - - /** - * Sets the graphic quality of the client - * @param {number} quality_level The quality level which to apply - * - * @return {bool} If the quality level was applied succeeded - */ - set quality(level){ - if(typeof level !== 'number') throw "quality must be of type number"; - if(!(level >= 0 && level <= 2)) throw "quality must be 0, 1, or 2"; - - this._quality = level; - game.settings.set("potato-or-not", "potatoLevel", level); - - this.updateSettings(); - } - - /** - * Gets the value of a setting of a module at a quality level - * @param {number} quality_level The quality level which to get the setting from - * @param {string} module The module the setting belongs to - * @param {string} setting The setting to get the value from - * - * @return {any} The value of the setting - */ - getSetting(quality_level=1, module="", setting="", value=""){ - - this._validate_setting(quality_level, module, setting); - - return this.settings[quality_level][module][setting]; - - } - - /** - * Adds a setting to be applied on a quality level - * @param {number} quality_level The quality level which to apply the setting to - * @param {string} module The module the setting belongs to - * @param {string} setting The setting to modify - * @param {any} value The value to set - * @param {bool} force Whether to force-apply the setting right away should the client have the same quality level - * - * @return {bool} If setting was applied succeeded - */ - addSetting(quality_level=1, module="", setting="", value="", force=false){ - - this._validate_quality_level(quality_level); - - if(this.settings[quality_level][module] === undefined){ - this.settings[quality_level][module] = {}; - } - - this.settings[quality_level][module][setting] = value; - - if(force && this.quality == quality_level){ - try{ - game.settings.set(module, setting, value); - return true; - }catch(err){ - console.error(`Potato Or Not | Could not set ${module}.${setting} to ${value} - please see log below`); - throw err; - } - } - - return true; - - } - - /** - * Removes a setting from a quality level - * @param {number} quality_level The quality level which to apply the setting to - * @param {string} module The module the setting belongs to - * @param {string} setting The setting to modify - * - * @return {bool} If setting was removed successfully - */ - removeSetting(quality_level=1, module="", setting=""){ - - this._validate_setting(quality_level, module, setting); - - try{ - delete this.settings[quality_level][module][setting]; - }catch(err){ - console.error(`Potato Or Not | Could not remove ${module}.${setting} - please see log below`); - throw err; - } - - return true; - - } - -} - -class PotatoOrNotApplication extends FormApplication { - - constructor(dialogData={}, options={}) { - super(dialogData, options); - game.settings.sheet.close(); - this.potato_quality = PotatoOrNot.quality; - } - - /* -------------------------------------------- */ - - /** @override */ - static get defaultOptions() { - return mergeObject(super.defaultOptions, { - title: "Potato Or Not", - template: `modules/potato-or-not/templates/potato-template.html`, - classes: ["dialog"], - width: 900, - height: 425, - }); - } - - /* -------------------------------------------- */ - - /** @override */ - getData() { - let data = super.getData(); - data.potato_quality = this.potato_quality; - return data; - } - - /* -------------------------------------------- */ - - /** @override */ - activateListeners(html) { - super.activateListeners(html); - let btn = html.find(".potato-level-container"); - btn.click(this._selectedPotatoLevel.bind(this)); - } - - /* -------------------------------------------- */ - - _selectedPotatoLevel(event) { - event.preventDefault(); - const btn = $(event.currentTarget); - const level = btn.attr("level")|0; - this.potato_quality = level; - btn.attr('active', true); - this._element.find(".potato-level-container").not(btn).removeAttr("active"); - } - - /* -------------------------------------------- */ - - async _updateObject(event, formData) { - PotatoOrNot.quality = this.potato_quality; - game.settings.set("potato-or-not", "hasBeenPrompted", true); - } - +Hooks.on("ready", () => { + + window.PotatoOrNot = new PotatoOrNotHandler(); + + console.log("Potato Or Not | Ready") + + Hooks.call("PotatoOrNotReady"); + + window.PotatoOrNot.postSetup(); + +}); + +class PotatoOrNotHandler{ + + constructor(){ + + game.settings.register("potato-or-not", "promptUsers", { + name: "Prompt All New Users", + hint: "This will make it so that the prompt will be shown to all new users.", + scope: "world", + config: true, + default: true, + type: Boolean + }); + + game.settings.register("potato-or-not", "hasBeenPrompted", { + scope: "client", + config: false, + default: false, + type: Boolean + }); + + game.settings.register("potato-or-not", "potatoLevel", { + scope: "client", + config: false, + default: 1, + type: Number + }); + + game.settings.register("potato-or-not", "numberOfSettings", { + scope: "client", + config: false, + default: 5, + type: Number + }); + + game.settings.registerMenu("potato-or-not", "potato-or-not", { + name: "Set Up Potato Settings", + label: "Show Dialog", + icon: "fas fa-carrot", + type: PotatoOrNotApplication, + restricted: false + }); + + game.settings.register("potato-or-not", "settings", { + name: "Show Dialog", + scope: "client", + default: {}, + type: Object, + config: false + }); + + this._settings = [ + { + "core": { + "maxFPS": 20, + "softShadows": false, + "mipmap": false, + "visionAnimation": false, + "lightAnimation": false, + }, + }, + { + "core": { + "maxFPS": 30, + "softShadows": true, + "mipmap": false, + "visionAnimation": true, + "lightAnimation": true, + } + }, + { + "core": { + "maxFPS": 60, + "softShadows": true, + "mipmap": true, + "visionAnimation": true, + "lightAnimation": true, + } + } + ]; + + this._quality = game.settings.get("potato-or-not", "potatoLevel"); + + } + + get current_settings(){ + return this.settings[this.quality]; + } + + set settings(settings){ + throw "You cannot set settings directly, please use PotatoOrNot.addSetting and PotatoOrNot.removeSetting"; + } + + get settings(){ + return this._settings; + } + + _validate_quality_level(quality_level){ + if(this.settings[quality_level] === undefined) throw "quality_level must be 0, 1, or 2 - low, medium, and high settings"; + } + + _validate_module(quality_level, module){ + this._validate_quality_level(quality_level); + if(this.settings[quality_level][module] === undefined) throw `Module setting "${module}" not found in quality level of "${quality_level}"`; + } + + _validate_setting(quality_level, module, setting){ + this._validate_module(quality_level, module); + if(this.settings[quality_level][module][setting] === undefined) throw `Setting "${setting}" in module "${module}" not found`; + } + + get numberOfSettings(){ + let numberOfSettings = []; + for(let i = 0; i < this.settings.length; i++){ + numberOfSettings[i] = 0; + for(let settings of Object.values(this.settings[i])){ + numberOfSettings[i] += Object.keys(settings).length; + } + } + return numberOfSettings; + } + + postSetup(){ + let numberOfSettings = this.numberOfSettings[this.quality]; + + if(!game.settings.get('potato-or-not', 'hasBeenPrompted') && game.settings.get('potato-or-not', 'promptUsers')){ + this.showDialog(); + }else if(numberOfSettings !== game.settings.get("potato-or-not", "numberOfSettings")){ + game.settings.set("potato-or-not", "numberOfSettings", numberOfSettings); + this.updateSettings(); + } + } + + updateSettings(){ + + let modules = Object.keys(this.current_settings); + + for(let module of modules){ + for(let [setting, value] of Object.entries(this.current_settings[module])){ + try{ + game.settings.set(module, setting, value); + console.log(`Potato Or Not | Set ${module}.${setting} to ${value}`); + }catch(err){ + console.error(`Potato Or Not | Could not set ${module}.${setting} to ${value}`); + } + } + } + + window.location.reload(); + + } + + /** + * Locally prompts the settings dialog + * + * @return {FormApplication} The potato FormApplication + */ + showDialog(){ + return new PotatoOrNotApplication().render(true); + } + + get quality(){ + return this._quality; + } + + /** + * Sets the graphic quality of the client + * @param {number} quality_level The quality level which to apply + * + * @return {boolean} If the quality level was applied succeeded + */ + set quality(quality_level){ + + if(typeof quality_level !== 'number') throw "quality must be of type number"; + if(!(quality_level >= 0 && quality_level <= 2)) throw "quality must be 0, 1, or 2"; + + this._quality = quality_level; + game.settings.set("potato-or-not", "potatoLevel", quality_level); + + this.updateSettings(); + } + + /** + * Gets the value of a setting of a module at a quality level + * @param {number} quality_level The quality level which to get the setting from + * @param {string} module The module the setting belongs to + * @param {string} setting The setting to get the value from + * + * @return {any} The value of the setting + */ + getSetting(quality_level = 1, module = "", setting = ""){ + + this._validate_setting(quality_level, module, setting); + + return this.settings[quality_level][module][setting]; + + } + + /** + * Adds a setting to be applied on a quality level + * @param {number} quality_level The quality level which to apply the setting to + * @param {string} module The module the setting belongs to + * @param {string} setting The setting to modify + * @param {any} value The value to set + * @param {boolean} force Whether to force-apply the setting right away should the client have the same quality level + * + * @return {boolean} If setting was applied succeeded + */ + addSetting(quality_level = 1, module = "", setting = "", value = "", force = false){ + + this._validate_quality_level(quality_level); + + if(this.settings[quality_level][module] === undefined){ + this.settings[quality_level][module] = {}; + } + + this.settings[quality_level][module][setting] = value; + + if(force && this.quality === quality_level){ + try{ + game.settings.set(module, setting, value); + return true; + }catch(err){ + console.error(`Potato Or Not | Could not set ${module}.${setting} to ${value} - please see log below`); + throw err; + } + } + + return true; + + } + + /** + * Removes a setting from a quality level + * @param {number} quality_level The quality level which to apply the setting to + * @param {string} module The module the setting belongs to + * @param {string} setting The setting to modify + * + * @return {boolean} If setting was removed successfully + */ + removeSetting(quality_level = 1, module = "", setting = ""){ + + this._validate_setting(quality_level, module, setting); + + try{ + delete this.settings[quality_level][module][setting]; + }catch(err){ + console.error(`Potato Or Not | Could not remove ${module}.${setting} - please see log below`); + throw err; + } + + return true; + + } + +} + +class PotatoOrNotApplication extends FormApplication { + + constructor(dialogData = {}, options = {}) { + super(dialogData, options); + game.settings.sheet.close(); + this.potato_quality = PotatoOrNot.quality; + } + + /* -------------------------------------------- */ + + /** @override */ + static get defaultOptions() { + return mergeObject(super.defaultOptions, { + title: "Potato Or Not", + template: `modules/potato-or-not/templates/potato-template.html`, + classes: ["dialog"], + width: 900, + height: 425, + }); + } + + /* -------------------------------------------- */ + + /** @override */ + getData() { + let data = super.getData(); + data.potato_quality = this.potato_quality; + return data; + } + + /* -------------------------------------------- */ + + /** @override */ + activateListeners(html) { + super.activateListeners(html); + let btn = html.find(".potato-level-container"); + btn.click(this._selectedPotatoLevel.bind(this)); + } + + /* -------------------------------------------- */ + + _selectedPotatoLevel(event) { + event.preventDefault(); + const btn = $(event.currentTarget); + const level = btn.attr("level")|0; + this.potato_quality = level; + btn.attr('active', true); + this._element.find(".potato-level-container").not(btn).removeAttr("active"); + } + + /* -------------------------------------------- */ + + async _updateObject(event, formData) { + PotatoOrNot.quality = this.potato_quality; + game.settings.set("potato-or-not", "hasBeenPrompted", true); + } + } \ No newline at end of file