Added EncodeJS
This commit is contained in:
parent
79fcc243de
commit
54f40eb41e
5 changed files with 113 additions and 32 deletions
50
README.md
50
README.md
|
@ -10,39 +10,39 @@ This project provides a collection of template renderers.
|
|||
## Date/Time Renderers
|
||||
|
||||
| Renderer | Description |
|
||||
|:---------------------------------|:-----------------------------------------------------------------|
|
||||
| `rife.render.BeatTime` | Renders the current time in Swatch Internet (.beat) Time format. |
|
||||
| `rife.render.DateIso` | Renders the current date in ISO 8061 format. |
|
||||
| `rife.render.DateTimeIso` | Renders the current date and time in ISO 8061 format. |
|
||||
| `rife.render.DateTimeRfc2822` | Renders the current date and time in RFC 2822 format. |
|
||||
| `rife.render.DateTimeUtc` | Renders the current UTC date and time in ISO 8061 format. |
|
||||
| `rife.render.TimeIso` | Renders the current time in ISO 8061 format. |
|
||||
| `rife.render.Year` | Renders the current year. |
|
||||
|:---------------------------------|:----------------------------------------------------------------|
|
||||
| `rife.render.BeatTime` | Renders the current time in Swatch Internet (.beat) Time format |
|
||||
| `rife.render.DateIso` | Renders the current date in ISO 8061 format |
|
||||
| `rife.render.DateTimeIso` | Renders the current date and time in ISO 8061 format |
|
||||
| `rife.render.DateTimeRfc2822` | Renders the current date and time in RFC 2822 format |
|
||||
| `rife.render.DateTimeUtc` | Renders the current UTC date and time in ISO 8061 format |
|
||||
| `rife.render.TimeIso` | Renders the current time in ISO 8061 format |
|
||||
| `rife.render.Year` | Renders the current year |
|
||||
|
||||
## Encoding Renderers
|
||||
|
||||
| Renderer | Description |
|
||||
|:-----------------------------------|:--------------------------------------------------------|
|
||||
| `rife.render.EncodeBase64` | Encodes a template value to Base64. |
|
||||
| `rife.render.EncodeHtml` | Encodes a template value to HTML. |
|
||||
| `rife.render.EncodeHtmlEntities` | Encodes a template value to HTML decimal entities. |
|
||||
| `rife.render.EncodeJson` | Encodes a template value to JSON. |
|
||||
| `rife.render.EncodeQp` | Converts a template value to a quoted-printable string. |
|
||||
| `rife.render.EncodeUnicode` | Encodes a template value to Unicode escape codes. |
|
||||
| `rife.render.EncodeUrl` | URL-encodes a template value. |
|
||||
| `rife.render.EncodeXml` | Encodes a template value to XML. |
|
||||
|:---------------------------------|:-------------------------------------------------------|
|
||||
| `rife.render.EncodeBase64` | Encodes a template value to Base64 |
|
||||
| `rife.render.EncodeHtml` | Encodes a template value to HTML |
|
||||
| `rife.render.EncodeHtmlEntities` | Encodes a template value to HTML decimal entities |
|
||||
| `rife.render.EncodeJS` | Encodes a template value to JavaScript/ECMAScript |
|
||||
| `rife.render.EncodeQp` | Converts a template value to a quoted-printable string |
|
||||
| `rife.render.EncodeUnicode` | Encodes a template value to Unicode escape codes |
|
||||
| `rife.render.EncodeUrl` | URL-encodes a template value |
|
||||
| `rife.render.EncodeXml` | Encodes a template value to XML |
|
||||
|
||||
## Text Renderers
|
||||
|
||||
| Renderer | Description |
|
||||
|:----------------------------|:---------------------------------------------------------------|
|
||||
| `rife.render.Capitalize` | Capitalizes a template value. |
|
||||
| `rife.render.Lowercase` | Converts a template value to lowercase. |
|
||||
| `rife.render.Rot13` | Translates a template value to/from ROT13. |
|
||||
| `rife.render.SwapCase` | Swap case of a template value. |
|
||||
| `rife.render.Trim` | Removes leading and trailing whitespace from a template value. |
|
||||
| `rife.render.Uncapitalize` | Un-capitalizes a template value. |
|
||||
| `rife.render.Uppercase` | Converts a template value to uppercase. |
|
||||
|:----------------------------|:--------------------------------------------------------------|
|
||||
| `rife.render.Capitalize` | Capitalizes a template value |
|
||||
| `rife.render.Lowercase` | Converts a template value to lowercase |
|
||||
| `rife.render.Rot13` | Translates a template value to/from ROT13 |
|
||||
| `rife.render.SwapCase` | Swap case of a template value |
|
||||
| `rife.render.Trim` | Removes leading and trailing whitespace from a template value |
|
||||
| `rife.render.Uncapitalize` | Un-capitalizes a template value |
|
||||
| `rife.render.Uppercase` | Converts a template value to uppercase |
|
||||
|
||||
## Usage in Templates
|
||||
|
||||
|
|
74
lib/src/main/java/rife/render/EncodeJS.java
Normal file
74
lib/src/main/java/rife/render/EncodeJS.java
Normal file
|
@ -0,0 +1,74 @@
|
|||
/*
|
||||
* Copyright 2023 the original author or authors.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* https://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*
|
||||
*/
|
||||
|
||||
package rife.render;
|
||||
|
||||
import rife.template.Template;
|
||||
import rife.template.ValueRenderer;
|
||||
import rife.tools.StringUtils;
|
||||
|
||||
/**
|
||||
* <p>Encodes a template value to JavaScript/ECMAScript.</p>
|
||||
*
|
||||
* <p>Usage:</p>
|
||||
*
|
||||
* <pre>
|
||||
* <!--v render:rife.render.EncodeJS:valueId/-->
|
||||
* {{v render:rife.render.EncodeJS:valueId/}}
|
||||
* </pre>
|
||||
*
|
||||
* @author <a href="https://erik.thauvin.net/">Erik C. Thauvin</a>
|
||||
* @see StringUtils#encodeJson(String)
|
||||
* @since 1.0
|
||||
*/
|
||||
public class EncodeJS implements ValueRenderer {
|
||||
/**
|
||||
* Encodes a string to JavaScript/ECMAScript.
|
||||
*
|
||||
* @param src the source string.
|
||||
* @return the enocded string
|
||||
*/
|
||||
public static String encodeJS(String src) {
|
||||
if (src == null || src.isBlank()) {
|
||||
return src;
|
||||
}
|
||||
|
||||
var sb = new StringBuilder();
|
||||
var len = src.length();
|
||||
|
||||
char c;
|
||||
for (var i = 0; i < len; i++) {
|
||||
c = src.charAt(i);
|
||||
switch (c) {
|
||||
case '\'' -> sb.append("\\'");
|
||||
case '"' -> sb.append("\\\"");
|
||||
case '\\' -> sb.append("\\\\");
|
||||
case '/' -> sb.append("\\/");
|
||||
default -> sb.append(c);
|
||||
}
|
||||
}
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*/
|
||||
@Override
|
||||
public String render(Template template, String valueId, String differentiator) {
|
||||
return encodeJS(RenderUtils.fetchValue(template, differentiator));
|
||||
}
|
||||
}
|
|
@ -49,7 +49,7 @@ class TestDateTime {
|
|||
}
|
||||
|
||||
@Test
|
||||
void testDateTimeUtc2() {
|
||||
void testDateTimeUtc() {
|
||||
var t = TemplateFactory.HTML.get("dateTimeUtc");
|
||||
assertThatCode(() -> DateTimeIso.iso8601Formatter.parse(t.getContent())).doesNotThrowAnyException();
|
||||
}
|
||||
|
|
|
@ -44,6 +44,13 @@ class TestEncode {
|
|||
assertThat(t.getContent()).isEqualTo("<a href=\"mailto:john@doe.com\">Email</a>");
|
||||
}
|
||||
|
||||
@Test
|
||||
void testEncodeJS() {
|
||||
var t = TemplateFactory.TXT.get("encodeJS");
|
||||
t.setAttribute(TestCase.FOO, "'\"\\/");
|
||||
assertThat(t.getContent()).isEqualTo("\\'\\\"\\\\\\/");
|
||||
}
|
||||
|
||||
@Test
|
||||
void testEncodeJson() {
|
||||
var t = TemplateFactory.JSON.get("encodeJson");
|
||||
|
@ -61,17 +68,16 @@ class TestEncode {
|
|||
@Test
|
||||
void testEncodeRot13() {
|
||||
var t = TemplateFactory.TXT.get("rot13");
|
||||
var value = TestCase.SAMPLE_TEXT;
|
||||
var rot13 = "Guvf vf n grfg.";
|
||||
|
||||
// Encode
|
||||
var bean = new ValueBean(value);
|
||||
var bean = new ValueBean(TestCase.SAMPLE_TEXT);
|
||||
t.setBean(bean);
|
||||
assertThat(t.getContent()).isEqualTo(bean.getValue() + ": " + rot13);
|
||||
|
||||
// Decode
|
||||
t.setValue("value", rot13);
|
||||
assertThat(t.getContent()).isEqualTo(rot13 + ": " + value);
|
||||
assertThat(t.getContent()).isEqualTo(rot13 + ": " + TestCase.SAMPLE_TEXT);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
1
lib/src/test/resources/templates/encodeJS.txt
Normal file
1
lib/src/test/resources/templates/encodeJS.txt
Normal file
|
@ -0,0 +1 @@
|
|||
{{v render:rife.render.EncodeJS:foo/}}
|
Loading…
Add table
Add a link
Reference in a new issue