summaryrefslogtreecommitdiff
path: root/Client/Assets/Scripts/XMainClient/Guild/XGuildLogBase.cs
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2021-01-25 14:28:30 +0800
committerchai <chaifix@163.com>2021-01-25 14:28:30 +0800
commit6eb915c129fc90c6f4c82ae097dd6ffad5239efc (patch)
tree7dd2be50edf41f36b60fac84696e731c13afe617 /Client/Assets/Scripts/XMainClient/Guild/XGuildLogBase.cs
+scripts
Diffstat (limited to 'Client/Assets/Scripts/XMainClient/Guild/XGuildLogBase.cs')
-rw-r--r--Client/Assets/Scripts/XMainClient/Guild/XGuildLogBase.cs79
1 files changed, 79 insertions, 0 deletions
diff --git a/Client/Assets/Scripts/XMainClient/Guild/XGuildLogBase.cs b/Client/Assets/Scripts/XMainClient/Guild/XGuildLogBase.cs
new file mode 100644
index 00000000..870c729a
--- /dev/null
+++ b/Client/Assets/Scripts/XMainClient/Guild/XGuildLogBase.cs
@@ -0,0 +1,79 @@
+using System;
+using KKSG;
+using XMainClient.UI;
+using XUtliPoolLib;
+
+namespace XMainClient
+{
+ internal class XGuildLogBase : XDataBase, ILogData, IComparable<ILogData>
+ {
+ public GuildLogType eType;
+
+ public ulong uid;
+
+ public string name;
+
+ public int time;
+
+ public virtual string GetContent()
+ {
+ return "";
+ }
+
+ public string GetTime()
+ {
+ return XSingleton<UiUtility>.singleton.TimeAgoFormatString(this.time);
+ }
+
+ public virtual void SetData(GHisRecord data)
+ {
+ this.uid = data.roleid;
+ this.name = data.rolename;
+ this.time = (int)data.time;
+ }
+
+ public static XGuildLogBase CreateLog(uint type)
+ {
+ XGuildLogBase result;
+ switch (type)
+ {
+ case 1u:
+ result = XDataPool<XGuildLogJoin>.GetData();
+ break;
+ case 2u:
+ result = XDataPool<XGuildLogLeave>.GetData();
+ break;
+ case 3u:
+ result = XDataPool<XGuildLogAppoint>.GetData();
+ break;
+ default:
+ if (type != 9u)
+ {
+ result = null;
+ }
+ else
+ {
+ result = XDataPool<XGuildLogBossMVP>.GetData();
+ }
+ break;
+ }
+ return result;
+ }
+
+ public int CompareTo(ILogData otherLog)
+ {
+ XGuildLogBase xguildLogBase = otherLog as XGuildLogBase;
+ bool flag = xguildLogBase.time == this.time;
+ int result;
+ if (flag)
+ {
+ result = this.uid.CompareTo(xguildLogBase.uid);
+ }
+ else
+ {
+ result = this.time.CompareTo(xguildLogBase.time);
+ }
+ return result;
+ }
+ }
+}