-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtemplate-119.html
101 lines (98 loc) · 3.17 KB
/
template-119.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
96
97
98
99
100
101
<h1 id="simple-link-formatter">Simple Link Formatter</h1>
<p>This formatter creates a link with text from the column's field by default.</p>
<h2 id="specific-options">Specific options</h2>
<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Attributes</th>
<th>Description</th>
</tr>
</thead>
<tbody><tr>
<td>urlField</td>
<td>string</td>
<td>optional</td>
<td>Field used for href attribute</td>
</tr>
</tbody></table>
<h2 id="example">Example</h2>
<code-sandbox hash="18f49e12"><pre><code class="language-css">efx-grid {
height: 320px;
}
</code></pre>
<pre><code class="language-html"><efx-grid id="grid"></efx-grid>
</code></pre>
<pre><code class="language-javascript">import { halo } from './theme-loader.js'; // This line is only required for demo purpose. It is not relevant for your application.
await halo(); // This line is only required for demo purpose. It is not relevant for your application.
/* ---------------------------------- Note ----------------------------------
DataGenerator, Formatters and extensions are exposed to global scope
in the bundle file to make it easier to create live examples.
Importing formatters and extensions is still required in your application.
Please see the document for further information.
---------------------------------------------------------------------------*/
var href = "https://www.lseg.com/#";
var fields = ["id", "url"];
var records = new Array(40);
for(var i = 0; i < 40; ++i) {
var record = records[i] = {};
record[fields[0]] = i;
record[fields[1]] = "https://www.lseg.com/#" + i;
}
var configObj = {
sorting: {
sortableColumns: true
},
columns: [
{
name: "Data",
field: fields[0],
alignment: "c"
},
{
name: "Simplest",
field: fields[0],
alignment: "c",
binding: SimpleLinkFormatter.create({
attributes: {
href: "https://www.lseg.com"
}
})
},
{
name: "Some options",
field: fields[0],
alignment: "c",
binding: SimpleLinkFormatter.create({
label: "click here",
attributes: {
href: "https://www.lseg.com"
},
styles: {
color: "red"
},
events: {
"click": function(e) {
console.log("clicked");
e.preventDefault();
}
}
})
},
{
name: "Dynamic URL",
field: fields[0],
alignment: "c",
binding: SimpleLinkFormatter.create({
label: "see URL",
urlField: fields[1]
})
}
],
staticDataRows: records
};
var grid = document.getElementById("grid");
grid.config = configObj;
</code></pre>
</code-sandbox>