diff --git a/src/modules/API.js b/src/modules/API.js index 8916b2e..36918a4 100644 --- a/src/modules/API.js +++ b/src/modules/API.js @@ -2,16 +2,14 @@ import { moduleId, SETTINGS } from '../constants.js'; import { addArgSpec, addModifier, addSection, addHook, addAction } from "./Specs.js"; import { sequences, actions } from "./stores.js"; import { DSequence } from "./Sequencer.js"; +import { get } from "svelte/store"; const API = { addArgSpec, addModifier, addSection, addHook, addAction, getSequence: async (name, overrides) => { let seq; - sequences.update(seqs => { - seq = seqs.find(s => s.title == name || s.id == name); - return seqs; - }); + seq = get(sequences).find(s => s.title == name || s.id == name); if (!seq) { logger.error(`Sequence ${name} not found`); return null; @@ -24,48 +22,26 @@ const API = { runAction: (id) => { let action; - actions.update(a => { - action = a.find(action => action.id == id || action.name == id); - return a; - }); + action = get(actions).find(action => action.id == id || action.name == id); if (action) { action.run(new MouseEvent("")) } }, listSequences: () => { - let seq; - sequences.update(seqs => { - seq = seqs; - return seqs; - }); - return seq; + return get(sequences); }, listActions: () => { - let acts; - actions.update(a => { - acts = a; - return a; - }); - return acts; + return get(actions); }, findSequence: (name) => { - let seq; - sequences.update(seqs => { - seq = seqs.find(s => s.title == name || s.id == name); - return seqs; - }); - return seq; + return get(sequences).find(s => s.title == name || s.id == name); }, playSequence: (name, overrides) => { - let seq; - sequences.update(seqs => { - seq = seqs.find(s => s.title == name || s.id == name); - return seqs; - }); + let seq = get(sequences).find(s => s.title == name || s.id == name); if (!seq) { logger.error(`Sequence ${name} not found`); } else { diff --git a/src/modules/Specs.js b/src/modules/Specs.js index 22054e9..f2f77a9 100644 --- a/src/modules/Specs.js +++ b/src/modules/Specs.js @@ -33,6 +33,14 @@ export const actionTypes = [ group: 'Tokens', execute: (object, action) => object && tools.revive(object?.document || object), }, + + { + id: 'another-action', + label: 'Another Action', + group: 'Macro', + args: [{ type: "action", label: "action" }], + execute: (object, action) => Director.runAction(action.args[0]), + }, { id: 'macro', label: 'Run Macro', @@ -736,6 +744,12 @@ export const argSpecs = [ } , control: "select" }, + { + id: "action", var_types: ["action"], options: (_) => { + return Director.listActions().filter(a => a.name != "").map(s => { return { value: s.id, label: s.name } }); + } + , control: "select" + }, { id: "animate-target", var_types: ["animate-target"], options: [ { value: "sprite", label: "sprite" }, diff --git a/src/styles/main.scss b/src/styles/main.scss index c61f5fb..e2f1cd8 100644 --- a/src/styles/main.scss +++ b/src/styles/main.scss @@ -36,7 +36,7 @@ max-width: 600px; border-radius: var(--rounded-btn, 0.5rem); background: #fff !important; - height: 3rem !important; + height: 2.5rem !important; input, .selection { font-size: 1rem !important; @@ -79,7 +79,7 @@ .ui-input-lg { border-color: #ddd !important; - height: 3rem !important; + height: 2.5rem !important; } .ui-text-base { @@ -101,6 +101,16 @@ button > i { margin: 0px !important; } + + .ui-btn { + height: 2.5rem !important; + min-height: 2.5rem !important; + } + .ui-btn-square { + width: 2.5rem !important; + height: 2.5rem !important; +} + .ui-tabs { justify-content: center; } @@ -112,7 +122,7 @@ .ui-toggle { flex-shrink: 0 !important; flex-basis: auto !important; - width: 3rem !important; + width: 2.5rem !important; height: 1.5rem !important; } diff --git a/src/view/MainUI.svelte b/src/view/MainUI.svelte index 67351e8..6416183 100644 --- a/src/view/MainUI.svelte +++ b/src/view/MainUI.svelte @@ -19,10 +19,13 @@ import FaCompressArrowsAlt from "svelte-icons/fa/FaCompressArrowsAlt.svelte"; import ArgInput from "./components/ArgInput.svelte"; + import { getContext, onDestroy, setContext } from "svelte"; import { tagsStore, actions } from "../modules/stores.js"; + setContext("tagsStore", tagsStore); + import Tag from "../modules/Tags.js"; + import TagComponent from "./components/Tag.svelte"; - import { getContext, onDestroy, setContext } from "svelte"; import Action from "../modules/Actions"; import { actionTypes } from "../modules/Specs"; const { application } = getContext("external"); @@ -49,7 +52,7 @@ }); pickerOpen = !pickerOpen; } - setContext("onTagClick", onTagClick); + setContext("tagRClick", onTagClick); function createAction(_, tags) { actions.update((actions) => { @@ -127,22 +130,7 @@