Skip to content

Commit

Permalink
Merge branch 'release/0.7.3' into main
Browse files Browse the repository at this point in the history
  • Loading branch information
caewok committed Jan 3, 2024
2 parents 4a2b4c6 + a21c289 commit 01bd846
Show file tree
Hide file tree
Showing 21 changed files with 1,226 additions and 554 deletions.
176 changes: 137 additions & 39 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
@@ -1,47 +1,145 @@
name: Release Creation
# GitHub Actions workflow for creating a new FoundryVTT module release.
#
# Useful References:
# - https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions
# - https://docs.github.com/en/actions/learn-github-actions/contexts
# - https://docs.github.com/en/actions/learn-github-actions/environment-variables
#
# Troubleshooting Checklist:
# - Is the module's manifest file valid JSON?
# You can test your manifest file using https://jsonlint.com/.
#
# - Does the module's manifest have all the required keys?
# See https://foundryvtt.com/article/module-development/#manifest for more
# information.
#
# - Are all the proper files and directories being included in the release's
# module archive ("module.zip")?
# Check that the correct files are being passed to the `zip` command run
# in the "Create Module Archive" step below.
#
# - Is the release tag the proper format?
# See the comments for the "Extract Version From Tag" step below.
#
# - Is a GitHub release being published?
# This workflow will only run when a release is published, not when a
# release is updated. Furthermore, note that while a GitHub release will
# (by default) create a repository tag, a repository tag will not create
# or publish a GitHub release.
#
# - Has the module's entry on FoundryVTT's module administration site
# (https://foundryvtt.com/admin) been updated?
#
name: Create Module Files For GitHub Release

on:

env:
# The URL used for the module's "Project URL" link on FoundryVTT's website.
project_url: "https://github.com/${{github.repository}}"

# A URL that will always point to the latest manifest.
# FoundryVTT uses this URL to check whether the current module version that
# is installed is the latest version. This URL should NOT change,
# otherwise FoundryVTT won't be able to perform this check.
latest_manifest_url: "https://github.com/${{github.repository}}/releases/latest/download/module.json"

# The URL to the module archive associated with the module release being
# processed by this workflow.
release_module_url: "https://github.com/${{github.repository}}/releases/download/${{github.event.release.tag_name}}/module.zip"


on:
# Only run this workflow when a release is published.
# To modify this workflow when other events occur, see:
# - https://docs.github.com/en/actions/using-workflows/triggering-a-workflow
# - https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows
# - https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#on
#
# Note that some steps may depend on context variables that are only
# available for release events, so if you add other events, you may need to
# alter other parts of this workflow.
release:
types: [published]


jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: write

steps:
- uses: actions/checkout@v2
with:
submodules: 'true'

# get part of the tag after the `v`
- name: Extract tag version number
id: get_version
uses: battila7/get-version-action@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: ${{steps.get_version.outputs.version-without-v}}
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: ${{ github.event.release.unpublished }}
prerelease: ${{ github.event.release.prerelease }}
token: ${{ secrets.GITHUB_TOKEN }}
artifacts: './module.json, ./module.zip'
tag: ${{ github.event.release.tag_name }}
body: ${{ github.event.release.body }}
- name: Checkout Repository
uses: actions/checkout@v3
with:
submodules: 'true'

# Extract version embedded in the tag.
# This step expects the tag to be one of the following formats:
# - "v<major>.<minor>.<patch>" (e.g., "v1.2.3")
# - "<major>.<minor>.<patch>" (e.g., "1.2.3")
#
# The version will be used by later steps to fill in the value for the
# "version" key required for a valid module manifest.
- name: Extract Version From Tag
id: get_version
uses: battila7/get-version-action@v2


# Modify "module.json" with values specific to the release.
# Since the values for the "version" and "url" keys aren't known ahead of
# time, the manifest file in the repository is updated with these values.
#
# While this does modify the manifest file in-place, the changes are not
# commited to the repository, and only exist in the action's filesystem.
- name: Modify Module Manifest With Release-Specific Values
id: sub_manifest_link_version
uses: cschleiden/replace-tokens@v1
with:
files: 'module.json'
env:
VERSION: ${{steps.get_version.outputs.version-without-v}}
URL: ${{ env.project_url }}
MANIFEST: ${{ env.latest_manifest_url }}
DOWNLOAD: ${{ env.release_module_url }}


# Create a "module.zip" archive containing all the module's required files.
# If you have other directories or files that will need to be added to
# your packaged module, add them here.
- name: Create Module Archive
run: |
# Note that `zip` will only emit warnings when a file or directory
# doesn't exist, it will not fail.
zip \
`# Options` \
--recurse-paths \
`# The name of the output file` \
./module.zip \
`# The files that will be included.` \
module.json \
README.md \
LICENSE \
templates/ \
scripts/ \
styles/ \
packs/ \
languages/ \
assets/
# Don't forget to add a backslash at the end of the line for any
# additional files or directories!
# Update the GitHub release with the manifest and module archive files.
- name: Update Release With Files
id: create_version_release
uses: ncipollo/release-action@v1
with:
allowUpdates: true
name: ${{ github.event.release.name }}
draft: ${{ github.event.release.unpublished }}
prerelease: ${{ github.event.release.prerelease }}
token: ${{ secrets.GITHUB_TOKEN }}
artifacts: './module.json, ./module.zip'
tag: ${{ github.event.release.tag_name }}
body: ${{ github.event.release.body }}
5 changes: 5 additions & 0 deletions Changelog.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
## 0.7.3
Force source update so that changes reflect in the placeable without moving the mouse. Force radius update when creating the preview. Closes issue #15.
Refactor to use Patcher class.
Update geometry lib to v0.2.12.

## 0.7.2
Update geometry lib to v0.2.2.

Expand Down
13 changes: 6 additions & 7 deletions module.json
Original file line number Diff line number Diff line change
@@ -1,21 +1,20 @@
{
"name": "lightmask",
"minimumCoreVersion": "11",
"id": "lightmask",
"title": "Light/Sound Mask",
"description": "Mask Foundry VTT lights and sounds",
"version": "This is auto replaced",
"version": "#{VERSION}#",
"library": false,
"manifestPlusVersion": "1.0.0",
"compatibility": {
"minimum": "11.299",
"verified": "11.304"
"verified": "11.315"
},
"authors": [
{
"name": "caewok",
"url": "https://github.com/caewok",
"discord": "caewok#9192"
"discord": "caewok"
}
],
"relationships": {
Expand All @@ -39,9 +38,9 @@
"description": "Mask Foundry VTT lights and sounds"
}
],
"url": "This is auto replaced",
"manifest": "This is auto replaced",
"download": "This is auto replaced",
"url": "#{URL}#",
"manifest": "#{MANIFEST}#",
"download": "#{DOWNLOAD}#",
"license": "LICENSE",
"readme": "README.md"
}
42 changes: 42 additions & 0 deletions scripts/AmbientLight.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
/* globals
flattenObject
*/
/* eslint no-unused-vars: ["error", { "argsIgnorePattern": "^_" }] */
"use strict";

import { MODULE_ID, FLAGS } from "./const.js";
import { preCreateAmbientSourceHook, preUpdateAmbientSourceHook } from "./preUpdate.js";

// Patches for the AmbientSoundConfig class
export const PATCHES = {};
PATCHES.BASIC = {};

/**
* Hook updateAmbientLight to set render flag based on change to the config.
* @param {Document} document The existing Document which was updated
* @param {object} change Differential data that was used to update the document
* @param {DocumentModificationContext} options Additional options which modified the update request
* @param {string} userId The ID of the User who triggered the update workflow
*/
export function updateAmbientLight(doc, data, _options, _userId) {
const changeFlags = [
`flags.${MODULE_ID}.${FLAGS.SHAPE}`,
`flags.${MODULE_ID}.${FLAGS.SIDES}`,
`flags.${MODULE_ID}.${FLAGS.POINTS}`,
`flags.${MODULE_ID}.${FLAGS.RELATIVE}`,
`flags.${MODULE_ID}.${FLAGS.CUSTOM_WALLS.IDS}`,
`flags.${MODULE_ID}.${FLAGS.CUSTOM_WALLS.EDGES}`,
`flags.${MODULE_ID}.${FLAGS.ELLIPSE.MINOR}`
];

const changed = new Set(Object.keys(flattenObject(data)));
if ( changeFlags.some(k => changed.has(k)) ) doc.object.renderFlags.set({
refresh: true
});
}

PATCHES.BASIC.HOOKS = {
updateAmbientLight,
preCreateAmbientLight: preCreateAmbientSourceHook,
preUpdateAmbientLight: preUpdateAmbientSourceHook
};
24 changes: 24 additions & 0 deletions scripts/AmbientLightConfig.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
/* globals
*/
/* eslint no-unused-vars: ["error", { "argsIgnorePattern": "^_" }] */
"use strict";

import { injectConfiguration, activateListeners } from "./render.js";

// Patches for the AmbientSoundConfig class
export const PATCHES = {};
PATCHES.BASIC = {};

// ----- NOTE: Hooks ----- //

/**
* @param {Application} application The Application instance being rendered
* @param {jQuery} html The inner HTML of the document that will be displayed and may be modified
* @param {object} data The object of data used when rendering the application
*/
function renderAmbientLightConfig(app, html, data) {
injectConfiguration(app, html, data, "LIGHT"); // Async
activateListeners(app, html);
}

PATCHES.BASIC.HOOKS = { renderAmbientLightConfig };
43 changes: 43 additions & 0 deletions scripts/AmbientSound.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
/* globals
flattenObject
*/
/* eslint no-unused-vars: ["error", { "argsIgnorePattern": "^_" }] */
"use strict";

import { MODULE_ID, FLAGS } from "./const.js";
import { preCreateAmbientSourceHook, preUpdateAmbientSourceHook } from "./preUpdate.js";

// Patches for the AmbientSoundConfig class
export const PATCHES = {};
PATCHES.BASIC = {};

/**
* Hook updateAmbientSound to set render flag based on change to the config.
* @param {Document} document The existing Document which was updated
* @param {object} change Differential data that was used to update the document
* @param {DocumentModificationContext} options Additional options which modified the update request
* @param {string} userId The ID of the User who triggered the update workflow
*/
export function updateAmbientSound(doc, data, _options, _userId) {
const changeFlags = [
`flags.${MODULE_ID}.${FLAGS.SHAPE}`,
`flags.${MODULE_ID}.${FLAGS.SIDES}`,
`flags.${MODULE_ID}.${FLAGS.POINTS}`,
`flags.${MODULE_ID}.${FLAGS.ROTATION}`,
`flags.${MODULE_ID}.${FLAGS.RELATIVE}`,
`flags.${MODULE_ID}.${FLAGS.CUSTOM_WALLS.IDS}`,
`flags.${MODULE_ID}.${FLAGS.CUSTOM_WALLS.EDGES}`,
`flags.${MODULE_ID}.${FLAGS.ELLIPSE.MINOR}`
];

const changed = new Set(Object.keys(flattenObject(data)));
if ( changeFlags.some(k => changed.has(k)) ) doc.object.renderFlags.set({
refresh: true
});
}

PATCHES.BASIC.HOOKS = {
updateAmbientSound,
preCreateAmbientSound: preCreateAmbientSourceHook,
preUpdateAmbientSound: preUpdateAmbientSourceHook
};
Loading

0 comments on commit 01bd846

Please sign in to comment.