-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsearchable_text.html
95 lines (81 loc) · 2.26 KB
/
searchable_text.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Searchable text</title>
<!-- Include jQuery library -->
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js"></script>
<!-- Include the Custom Elements API-->
<script src="https://app.kontent.ai/js-api/custom-element.js"></script>
<!-- Custom element CSS styles -->
<style>
/* We recommended you always set margin to zero to avoid problems when displaying the element in UI */
@import url(https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,700,400italic,700italic);
html{
font-family:sans-serif;
-ms-text-size-adjust:100%;
-webkit-text-size-adjust:100%;
}
body {
margin: 0;
overflow-y: hidden;
overflow-x: hidden;
}
</style>
</head>
<body>
<div id="status"></div>
<script>
var source_text = '';
function updateSize() {
var height = 30;
try {
height = parseInt($("html").height());
} catch (err) {
console.error(err);
}
CustomElement.setHeight(height);
}
function initCustomElement() {
try {
CustomElement.init((element, _context) => {
if (element.config) {
if (element.config.source_text) {
source_text = element.config.source_text;
}
else {
showError("Missing source 'Text' element codename");
}
}
updateSize();
});
} catch (err) {
console.error(err);
}
}
initCustomElement();
CustomElement.observeElementChanges([], (changedElementCodenames) => {
if (changedElementCodenames[0] == source_text) {
returnValue(changedElementCodenames[0]);
}
})
function returnValue(codename) {
CustomElement.getElementValue(codename, (value) => {
setValue(value);
});
}
function showError(message) {
$('#status').css("color","#ef5350");
$('#status').text(message);
throw new Error(message);
}
function setValue(value) {
const segmenter = new Intl.Segmenter([], { granularity: 'word' });
const segmentedText = segmenter.segment(value);
const words = [...segmentedText].filter(s => s.isWordLike).map(s => s.segment);
console.log(words);
CustomElement.setValue(JSON.stringify(words));
}
</script>
</body>
</html>