Compare commits
3 commits
78fca0e1c3
...
de9351746b
Author | SHA1 | Date | |
---|---|---|---|
de9351746b | |||
9d7316d7cb | |||
c048859c1d |
16 changed files with 61 additions and 68 deletions
|
@ -34,7 +34,7 @@ This project provides a set of template renderers.
|
|||
- **rife.render.Uncapitalize**
|
||||
- Un-capitalizes a template value.
|
||||
- **rife.render.Uppercase**
|
||||
- Convert a template value to uppercase.
|
||||
- Converts a template value to uppercase.
|
||||
- **rife.render.Year**
|
||||
- Renders the current year.
|
||||
|
||||
|
@ -49,7 +49,7 @@ All rendered can be used at follows:
|
|||
or
|
||||
|
||||
```
|
||||
{{v render:rife.render.RendererName:valueId}}
|
||||
{{v render:rife.render.RendererName:valueId/}}
|
||||
```
|
||||
|
||||
For example, to capitalize a template `foo` value:
|
||||
|
|
|
@ -19,8 +19,7 @@ package rife2.render;
|
|||
|
||||
import rife.template.Template;
|
||||
import rife.template.ValueRenderer;
|
||||
|
||||
import java.util.Locale;
|
||||
import rife.tools.Localization;
|
||||
|
||||
/**
|
||||
* <p>Capitalizes a template value.</p>
|
||||
|
@ -29,7 +28,7 @@ import java.util.Locale;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.Capitalize:valueId/-->
|
||||
* {{v render:rife.render.Capitalize:valueId}}
|
||||
* {{v render:rife.render.Capitalize:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,9 +40,9 @@ public class Capitalize implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
var value = template.getValue(differentiator);
|
||||
return value.substring(0, 1).toUpperCase(Locale.getDefault()) + value.substring(1);
|
||||
return value.substring(0, 1).toUpperCase(Localization.getLocale()) + value.substring(1);
|
||||
} else {
|
||||
return "";
|
||||
}
|
||||
|
|
|
@ -30,7 +30,7 @@ import java.nio.charset.StandardCharsets;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeBase64:valueId/-->
|
||||
* {{v render:rife.render.EncodeBase64:valueId}}
|
||||
* {{v render:rife.render.EncodeBase64:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -43,7 +43,7 @@ public class EncodeBase64 implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return StringUtils.encodeBase64(template.getValue(differentiator).getBytes(StandardCharsets.UTF_8));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -28,7 +28,7 @@ import rife.tools.StringUtils;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeHtml:valueId/-->
|
||||
* {{v render:rife.render.EncodeHtml:valueId}}
|
||||
* {{v render:rife.render.EncodeHtml:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,7 +41,7 @@ public class EncodeHtml implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return StringUtils.encodeHtml(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -27,7 +27,7 @@ import rife.template.ValueRenderer;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeHtmlEntities:valueId/-->
|
||||
* {{v render:rife.render.EncodeHtmlEntities:valueId}}
|
||||
* {{v render:rife.render.EncodeHtmlEntities:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* <p>For example {@code john@doe.com} would be encoded to:</p>
|
||||
|
@ -59,7 +59,7 @@ public class EncodeHtmlEntities implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return toHtmlEntities(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -28,7 +28,7 @@ import rife.tools.StringUtils;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeJson:valueId/-->
|
||||
* {{v render:rife.render.EncodeJson:valueId}}
|
||||
* {{v render:rife.render.EncodeJson:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,7 +41,7 @@ public class EncodeJson implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return StringUtils.encodeJson(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -19,8 +19,7 @@ package rife2.render;
|
|||
|
||||
import rife.template.Template;
|
||||
import rife.template.ValueRenderer;
|
||||
|
||||
import java.util.Locale;
|
||||
import rife.tools.Localization;
|
||||
|
||||
/**
|
||||
* <p>Converts a template value to a quoted-printable string.</p>
|
||||
|
@ -29,7 +28,7 @@ import java.util.Locale;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeQp:valueId/-->
|
||||
* {{v render:rife.render.EncodeQp:valueId}}
|
||||
* {{v render:rife.render.EncodeQp:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -65,7 +64,7 @@ public class EncodeQp implements ValueRenderer {
|
|||
buff.append('0');
|
||||
}
|
||||
|
||||
buff.append(hex.toUpperCase(Locale.getDefault()));
|
||||
buff.append(hex.toUpperCase(Localization.getLocale()));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -77,7 +76,7 @@ public class EncodeQp implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return toQuotedPrintable(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -28,7 +28,7 @@ import rife.tools.StringUtils;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeUnicode:valueId/-->
|
||||
* {{v render:rife.render.EncodeUnicode:valueId}}
|
||||
* {{v render:rife.render.EncodeUnicode:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,7 +41,7 @@ public class EncodeUnicode implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return StringUtils.encodeUnicode(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -28,7 +28,7 @@ import rife.tools.StringUtils;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeUrl:valueId/-->
|
||||
* {{v render:rife.render.EncodeUrl:valueId}}
|
||||
* {{v render:rife.render.EncodeUrl:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,7 +41,7 @@ public class EncodeUrl implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return StringUtils.encodeUrl(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -28,7 +28,7 @@ import rife.tools.StringUtils;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeXml:valueId/-->
|
||||
* {{v render:rife.render.EncodeXml:valueId}}
|
||||
* {{v render:rife.render.EncodeXml:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,7 +41,7 @@ public class EncodeXml implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return StringUtils.encodeXml(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -19,8 +19,7 @@ package rife2.render;
|
|||
|
||||
import rife.template.Template;
|
||||
import rife.template.ValueRenderer;
|
||||
|
||||
import java.util.Locale;
|
||||
import rife.tools.Localization;
|
||||
|
||||
/**
|
||||
* <p>Converts a template value to lowercase.</p>
|
||||
|
@ -29,7 +28,7 @@ import java.util.Locale;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.Lowercase:valueId/-->
|
||||
* {{v render:rife.render.Lowercase:valueId}}
|
||||
* {{v render:rife.render.Lowercase:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,8 +40,8 @@ public class Lowercase implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
return template.getValue(differentiator).toLowerCase(Locale.getDefault());
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return template.getValue(differentiator).toLowerCase(Localization.getLocale());
|
||||
} else {
|
||||
return "";
|
||||
}
|
||||
|
|
|
@ -27,7 +27,7 @@ import rife.template.ValueRenderer;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.Rot13:valueId/-->
|
||||
* {{v render:rife.render.Rot13:valueId}}
|
||||
* {{v render:rife.render.Rot13:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -77,7 +77,7 @@ public class Rot13 implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return rot13(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -27,7 +27,7 @@ import rife.template.ValueRenderer;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.SwapCase:valueId/-->
|
||||
* {{v render:rife.render.SwapCase:valueId}}
|
||||
* {{v render:rife.render.SwapCase:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -36,34 +36,32 @@ import rife.template.ValueRenderer;
|
|||
public class SwapCase implements ValueRenderer {
|
||||
/**
|
||||
* Swaps the case of a String.
|
||||
* @param s the String to swap the case of
|
||||
*
|
||||
* @param src the String to swap the case of
|
||||
* @return the modified String or null
|
||||
*/
|
||||
public static String swapCase(String s) {
|
||||
if (s == null || s.isEmpty()) {
|
||||
return s;
|
||||
public static String swapCase(final String src) {
|
||||
if (src == null || src.isEmpty()) {
|
||||
return src;
|
||||
}
|
||||
|
||||
var buffer = s.toCharArray();
|
||||
var whitespace = true;
|
||||
|
||||
for (var i = 0; i < buffer.length; i++) {
|
||||
var ch = buffer[i];
|
||||
if (Character.isUpperCase(ch) || Character.isTitleCase(ch)) {
|
||||
buffer[i] = Character.toLowerCase(ch);
|
||||
whitespace = false;
|
||||
} else if (Character.isLowerCase(ch)) {
|
||||
if (whitespace) {
|
||||
buffer[i] = Character.toTitleCase(ch);
|
||||
whitespace = false;
|
||||
} else {
|
||||
buffer[i] = Character.toUpperCase(ch);
|
||||
}
|
||||
int offset = 0;
|
||||
var len = src.length();
|
||||
var buff = new int[len];
|
||||
for (var i = 0; i < len; ) {
|
||||
int newCodePoint;
|
||||
var curCodePoint = src.codePointAt(i);
|
||||
if (Character.isUpperCase(curCodePoint) || Character.isTitleCase(curCodePoint)) {
|
||||
newCodePoint = Character.toLowerCase(curCodePoint);
|
||||
} else if (Character.isLowerCase(curCodePoint)) {
|
||||
newCodePoint = Character.toUpperCase(curCodePoint);
|
||||
} else {
|
||||
whitespace = Character.isWhitespace(ch);
|
||||
newCodePoint = curCodePoint;
|
||||
}
|
||||
buff[offset++] = newCodePoint;
|
||||
i += Character.charCount(newCodePoint);
|
||||
}
|
||||
return new String(buffer);
|
||||
return new String(buff, 0, offset);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -71,7 +69,7 @@ public class SwapCase implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return swapCase(template.getValue(differentiator));
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -27,7 +27,7 @@ import rife.template.ValueRenderer;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.Trim:valueId/-->
|
||||
* {{v render:rife.render.Trim:valueId}}
|
||||
* {{v render:rife.render.Trim:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -39,7 +39,7 @@ public class Trim implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return template.getValue(differentiator).trim();
|
||||
} else {
|
||||
return "";
|
||||
|
|
|
@ -19,8 +19,7 @@ package rife2.render;
|
|||
|
||||
import rife.template.Template;
|
||||
import rife.template.ValueRenderer;
|
||||
|
||||
import java.util.Locale;
|
||||
import rife.tools.Localization;
|
||||
|
||||
/**
|
||||
* <p>Un-capitalizes a template value.</p>
|
||||
|
@ -29,7 +28,7 @@ import java.util.Locale;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.Uncapitalize:valueId/-->
|
||||
* {{v render:rife.render.Uncapitalize:valueId}}
|
||||
* {{v render:rife.render.Uncapitalize:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,9 +40,9 @@ public class Uncapitalize implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
if (template.hasValueId(differentiator)) {
|
||||
var value = template.getValue(differentiator);
|
||||
return value.substring(0, 1).toLowerCase(Locale.getDefault()) + value.substring(1);
|
||||
return value.substring(0, 1).toLowerCase(Localization.getLocale()) + value.substring(1);
|
||||
} else {
|
||||
return "";
|
||||
}
|
||||
|
|
|
@ -19,8 +19,7 @@ package rife2.render;
|
|||
|
||||
import rife.template.Template;
|
||||
import rife.template.ValueRenderer;
|
||||
|
||||
import java.util.Locale;
|
||||
import rife.tools.Localization;
|
||||
|
||||
/**
|
||||
* <p>Convert a template value to uppercase.</p>
|
||||
|
@ -29,7 +28,7 @@ import java.util.Locale;
|
|||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.Uppercase:valueId/-->
|
||||
* {{v render:rife.render.Uppercase:valueId}}
|
||||
* {{v render:rife.render.Uppercase:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
|
@ -41,8 +40,8 @@ public class Uppercase implements ValueRenderer {
|
|||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
if (differentiator != null && !differentiator.isBlank() && template.hasValueId(differentiator)) {
|
||||
return template.getValue(differentiator).toUpperCase(Locale.getDefault());
|
||||
if (template.hasValueId(differentiator)) {
|
||||
return template.getValue(differentiator).toUpperCase(Localization.getLocale());
|
||||
} else {
|
||||
return "";
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue