001/*-
002 * #%L
003 * Smile CDR - CDR
004 * %%
005 * Copyright (C) 2016 - 2025 Smile CDR, Inc.
006 * %%
007 * All rights reserved.
008 * #L%
009 */
010package ca.cdr.api.i18n;
011
012import ca.cdr.api.annotations.CdrPublicAPI;
013import jakarta.annotation.Nonnull;
014
015import java.time.ZonedDateTime;
016import java.util.Date;
017
018/**
019 * This interface permits you to fetch messages out of the cdr-messages.properties file for localization
020 */
021@CdrPublicAPI
022public interface ILocalizer {
023
024        String formatDateDaysElapsed(Date theDate);
025
026        @Nonnull
027        String formatDateTime(Date theDate);
028
029        @Nonnull
030        String formatTime(Date theDate);
031
032        @SuppressWarnings("unused")
033        /**
034         * Used in Thymeleaf templates - Returns an empty string if the parameter is null
035         */
036        @Nonnull
037        String formatDate(Date theDate);
038
039        @SuppressWarnings("unused")
040        /**
041         * Used in Thymeleaf templates - Returns an empty string if the parameter is null
042         */
043        @Nonnull
044        String formatDateTimeMillis(Date theDate);
045
046        String getMessage(Class<?> theType, String theKey, Object... theParameters);
047
048        @SuppressWarnings("null")
049        @Nonnull
050        String getMessage(String theQualifiedKey, Object... theParameters);
051
052        String getMessageAndEvaluateAsMarkdown(String theQualifiedKey, Object... theParameters);
053
054        boolean hasKey(String theKey);
055
056        ZonedDateTime convertServerTimeToUserTime(Date theDate);
057}