feat: add available ipc indicator
This commit is contained in:
parent
43549bfcf3
commit
51240bddbc
|
@ -1,4 +1,4 @@
|
|||
using Dalamud.Game.Text.SeStringHandling;
|
||||
using Dalamud.Game.Text.SeStringHandling;
|
||||
using Dalamud.Game.Text.SeStringHandling.Payloads;
|
||||
using Dalamud.Plugin;
|
||||
using Dalamud.Plugin.Ipc;
|
||||
|
@ -9,7 +9,8 @@ internal sealed class IpcManager : IDisposable {
|
|||
private DalamudPluginInterface Interface { get; }
|
||||
private ICallGateProvider<string> RegisterGate { get; }
|
||||
private ICallGateProvider<string, object?> UnregisterGate { get; }
|
||||
private ICallGateProvider<string, PlayerPayload?, ulong, Payload?, object?> InvokeGate { get; }
|
||||
private ICallGateProvider<object?> AvailableGate { get; }
|
||||
private ICallGateProvider<string, PlayerPayload?, ulong, Payload?, SeString?, SeString?, object?> InvokeGate { get; }
|
||||
|
||||
internal List<string> Registered { get; } = new();
|
||||
|
||||
|
@ -19,14 +20,18 @@ internal sealed class IpcManager : IDisposable {
|
|||
this.RegisterGate = this.Interface.GetIpcProvider<string>("ChatTwo.Register");
|
||||
this.RegisterGate.RegisterFunc(this.Register);
|
||||
|
||||
this.AvailableGate = this.Interface.GetIpcProvider<object?>("ChatTwo.Available");
|
||||
|
||||
this.UnregisterGate = this.Interface.GetIpcProvider<string, object?>("ChatTwo.Unregister");
|
||||
this.UnregisterGate.RegisterAction(this.Unregister);
|
||||
|
||||
this.InvokeGate = this.Interface.GetIpcProvider<string, PlayerPayload?, ulong, Payload?, object?>("ChatTwo.Invoke");
|
||||
this.InvokeGate = this.Interface.GetIpcProvider<string, PlayerPayload?, ulong, Payload?, SeString?, SeString?, object?>("ChatTwo.Invoke");
|
||||
|
||||
this.AvailableGate.SendMessage();
|
||||
}
|
||||
|
||||
internal void Invoke(string id, PlayerPayload? sender, ulong contentId, Payload? payload) {
|
||||
this.InvokeGate.SendMessage(id, sender, contentId, payload);
|
||||
internal void Invoke(string id, PlayerPayload? sender, ulong contentId, Payload? payload, SeString? senderString, SeString? content) {
|
||||
this.InvokeGate.SendMessage(id, sender, contentId, payload, senderString, content);
|
||||
}
|
||||
|
||||
private string Register() {
|
||||
|
|
|
@ -94,7 +94,7 @@ internal sealed class PayloadHandler {
|
|||
if (ImGui.BeginMenu("Integrations")) {
|
||||
foreach (var id in registered) {
|
||||
try {
|
||||
this.Ui.Plugin.Ipc.Invoke(id, sender, contentId, payload);
|
||||
this.Ui.Plugin.Ipc.Invoke(id, sender, contentId, payload, chunk.Message?.SenderSource, chunk.Message?.ContentSource);
|
||||
} catch (Exception ex) {
|
||||
PluginLog.Error(ex, "Error executing integration");
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue