feat: add available ipc indicator
This commit is contained in:
+10
-5
@@ -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");
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user