Merge pull request #6967 from Trevor159/timestamp-config
Add customizable timestamps
This commit is contained in:
@@ -35,6 +35,7 @@ public interface TimestampConfig extends Config
|
||||
@ConfigItem(
|
||||
keyName = "opaqueTimestamp",
|
||||
name = "Timestamps (opaque)",
|
||||
position = 1,
|
||||
description = "Colour of Timestamps from the Timestamps plugin (opaque)"
|
||||
)
|
||||
Color opaqueTimestamp();
|
||||
@@ -42,7 +43,26 @@ public interface TimestampConfig extends Config
|
||||
@ConfigItem(
|
||||
keyName = "transparentTimestamp",
|
||||
name = "Timestamps (transparent)",
|
||||
position = 2,
|
||||
description = "Colour of Timestamps from the Timestamps plugin (transparent)"
|
||||
)
|
||||
Color transparentTimestamp();
|
||||
|
||||
@ConfigItem(
|
||||
keyName = "format",
|
||||
name = "Timestamp Format",
|
||||
position = 3,
|
||||
description = "Customize your timestamp format by using the following characters<br>" +
|
||||
"'yyyy' : year<br>" +
|
||||
"'MM' : month<br>" +
|
||||
"'dd' : day<br>" +
|
||||
"'HH' : hour in 24 hour format<br>" +
|
||||
"'hh' : hour in 12 hour format<br>" +
|
||||
"'mm' : minute<br>" +
|
||||
"'ss' : second"
|
||||
)
|
||||
default String timestampFormat()
|
||||
{
|
||||
return "[HH:mm]";
|
||||
}
|
||||
}
|
||||
|
||||
@@ -27,14 +27,17 @@ package net.runelite.client.plugins.timestamp;
|
||||
|
||||
import com.google.inject.Provides;
|
||||
import java.awt.Color;
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.time.Instant;
|
||||
import java.time.ZoneId;
|
||||
import java.time.ZonedDateTime;
|
||||
import java.time.temporal.ChronoField;
|
||||
import java.util.Date;
|
||||
import javax.inject.Inject;
|
||||
import lombok.Getter;
|
||||
import net.runelite.api.Client;
|
||||
import net.runelite.api.MessageNode;
|
||||
import net.runelite.api.Varbits;
|
||||
import net.runelite.api.events.ConfigChanged;
|
||||
import net.runelite.api.events.ScriptCallbackEvent;
|
||||
import net.runelite.client.config.ConfigManager;
|
||||
import net.runelite.client.eventbus.Subscribe;
|
||||
@@ -56,12 +59,36 @@ public class TimestampPlugin extends Plugin
|
||||
@Inject
|
||||
private TimestampConfig config;
|
||||
|
||||
@Getter
|
||||
private SimpleDateFormat formatter;
|
||||
|
||||
@Provides
|
||||
public TimestampConfig provideConfig(final ConfigManager configManager)
|
||||
{
|
||||
return configManager.getConfig(TimestampConfig.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void startUp() throws Exception
|
||||
{
|
||||
updateFormatter();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void shutDown() throws Exception
|
||||
{
|
||||
formatter = null;
|
||||
}
|
||||
|
||||
@Subscribe
|
||||
public void onConfigChanged(ConfigChanged event)
|
||||
{
|
||||
if (event.getGroup().equals("timestamp") && event.getKey().equals("format"))
|
||||
{
|
||||
updateFormatter();
|
||||
}
|
||||
}
|
||||
|
||||
@Subscribe
|
||||
public void onScriptCallbackEvent(ScriptCallbackEvent event)
|
||||
{
|
||||
@@ -80,13 +107,7 @@ public class TimestampPlugin extends Plugin
|
||||
|
||||
MessageNode messageNode = (MessageNode) client.getMessages().get(messageId);
|
||||
|
||||
final ZonedDateTime time = ZonedDateTime.ofInstant(
|
||||
Instant.ofEpochSecond(messageNode.getTimestamp()), ZoneId.systemDefault());
|
||||
|
||||
final String dateFormat = time.get(ChronoField.HOUR_OF_DAY) + ":" +
|
||||
String.format("%02d", time.get(ChronoField.MINUTE_OF_HOUR));
|
||||
|
||||
String timestamp = "[" + dateFormat + "] ";
|
||||
String timestamp = generateTimestamp(messageNode.getTimestamp(), ZoneId.systemDefault()) + " ";
|
||||
|
||||
Color timestampColour = getTimestampColour();
|
||||
if (timestampColour != null)
|
||||
@@ -103,4 +124,24 @@ public class TimestampPlugin extends Plugin
|
||||
|
||||
return isChatboxTransparent ? config.transparentTimestamp() : config.opaqueTimestamp();
|
||||
}
|
||||
|
||||
String generateTimestamp(int timestamp, ZoneId zoneId)
|
||||
{
|
||||
final ZonedDateTime time = ZonedDateTime.ofInstant(
|
||||
Instant.ofEpochSecond(timestamp), zoneId);
|
||||
|
||||
return formatter.format(Date.from(time.toInstant()));
|
||||
}
|
||||
|
||||
private void updateFormatter()
|
||||
{
|
||||
try
|
||||
{
|
||||
formatter = new SimpleDateFormat(config.timestampFormat());
|
||||
}
|
||||
catch (IllegalArgumentException e)
|
||||
{
|
||||
formatter = new SimpleDateFormat("[HH:mm]");
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,79 @@
|
||||
/*
|
||||
* Copyright (c) 2019, Trevor <https://github.com/Trevor159>
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||
* list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||||
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package net.runelite.client.plugins.timestamp;
|
||||
|
||||
import com.google.inject.Guice;
|
||||
import com.google.inject.testing.fieldbinder.Bind;
|
||||
import com.google.inject.testing.fieldbinder.BoundFieldModule;
|
||||
import java.util.TimeZone;
|
||||
import javax.inject.Inject;
|
||||
import net.runelite.api.Client;
|
||||
import net.runelite.api.events.ConfigChanged;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.Mock;
|
||||
import static org.mockito.Mockito.when;
|
||||
import org.mockito.runners.MockitoJUnitRunner;
|
||||
|
||||
@RunWith(MockitoJUnitRunner.class)
|
||||
public class TimestampPluginTest
|
||||
{
|
||||
@Mock
|
||||
@Bind
|
||||
Client client;
|
||||
|
||||
@Mock
|
||||
@Bind
|
||||
TimestampConfig config;
|
||||
|
||||
@Inject
|
||||
TimestampPlugin plugin;
|
||||
|
||||
@Before
|
||||
public void before()
|
||||
{
|
||||
Guice.createInjector(BoundFieldModule.of(this)).injectMembers(this);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testGenerateTimestamp()
|
||||
{
|
||||
when(config.timestampFormat()).thenReturn("[yyyy:MM:dd:HH:hh:mm:ss]");
|
||||
|
||||
ConfigChanged configChanged = new ConfigChanged();
|
||||
configChanged.setGroup("timestamp");
|
||||
configChanged.setKey("format");
|
||||
configChanged.setNewValue("true");
|
||||
plugin.onConfigChanged(configChanged);
|
||||
|
||||
int testInput = 1554667116;
|
||||
String testOutput = "[2019:04:07:15:03:58:36]";
|
||||
TimeZone timeZone = TimeZone.getTimeZone("America/New_York");
|
||||
plugin.getFormatter().setTimeZone(timeZone);
|
||||
assertTrue(plugin.generateTimestamp(testInput, timeZone.toZoneId()).equals(testOutput));
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user