FastComments.com

Z FastComments lahko na isti strani imamo poljubno število pripomočkov za komentarje. Lahko jih vse nastavimo na isto nit, in bodo sinhronizirane, ali pa hkrati predstavljajo različne niti. Lahko dodajamo, odstranjujemo, in spreminjamo komentarne niti po potrebi.

Dinamično dodajanje in zamenjava niti komentarjev Internal Link

Vse to se izvede z nastavitvijo urlId in sorodnih parametrov ter klicem update() na primerkih widgetov, da jih zamenjate z drugo nitjo.

Spodaj je interaktivni primer (pritisnite Run v zgornjem levem kotu), ki vam omogoča, da po potrebi dodate in zamenjate niti komentarjev. Lahko jih tudi odstranimo z klicem instance.destroy namesto update.

Dodaj in zamenjaj niti komentarjev
Copy CopyRun External Link
1
2 <script src="https://cdn.fastcomments.com/js/embed-v2.min.js"></script>
3
4 <div id="fastcomments-widgets"></div>
5 <div class="demo-form">
6 <section>
7 <h3>Add or Swap a Product/Comment Thread</h3>
8 <label>
9 Product Name
10 <input type="text" name="name" />
11 </label>
12 <label>
13 Product ID
14 <input type="text" name="id" />
15 </label>
16 <label>
17 Product URL
18 <input type="url" name="url" />
19 </label>
20 <label>
21 Replaces Product (id)
22 <input type="text" name="replaces_id" />
23 </label>
24 <button type="button">Add/Swap</button>
25 </section>
26 </div>
27 <script>
28 (function () {
29 const target = document.getElementById('fastcomments-widgets');
30 const tenantId = "demo"; // VSTAVITE TUKAJ SVOJ tenant ID
31
32 function setHeading(heading, {name, productID}) {
33 heading.innerHTML = `${name} (${productID})`;
34 }
35
36 function addWidget({name, productID, productURL}) {
37 const outer = document.createElement('div');
38 const heading = document.createElement('h5');
39 setHeading(heading, {name, productID});
40 const inner = document.createElement('div');
41 inner.append(heading);
42 outer.append(inner);
43 const widgetTarget = document.createElement('div');
44 outer.append(widgetTarget);
45 target.append(outer);
46 window.FastCommentsUI(widgetTarget, {
47 "tenantId": tenantId,
48 "pageTitle": name, // za e-poštna obvestila in nadzorno ploščo moderiranja
49 "url": productURL, // za e-poštna obvestila in nadzorno ploščo moderiranja
50 "urlId": productID,
51 "showLiveRightAway": true
52 });
53 }
54
55 function switchProduct(oldId, {name, productID, productURL}) {
56 for (const instanceWrapped of fcUIInstances) {
57 if (instanceWrapped.targetElement) {
58 const config = instanceWrapped.config;
59 if (config.urlId === oldId) {
60 const heading = instanceWrapped.targetElement.parentNode.querySelector('h5');
61 setHeading(heading, {name, productID});
62 config.pageTitle = name;
63 config.urlId = productID;
64 config.url = productURL;
65 instanceWrapped.instance.update(config);
66 return;
67 }
68 }
69 }
70 alert(`Product ${oldId} not found to replace!`);
71 }
72
73 // dodaj nekaj widgetov
74 addWidget({name: "Product A", productID: 'product-id-a', productURL: 'https://example.com/a'});
75 addWidget({name: "Product B", productID: 'product-id-b', productURL: 'https://example.com/b'});
76
77 const form = document.querySelector('.demo-form');
78 form.querySelector('button').addEventListener('click', function() {
79 const name = form.querySelector('input[name=name]').value;
80 const productID = form.querySelector('input[name=id]').value;
81 const productURL = form.querySelector('input[name=url]').value;
82 const replaces_id = form.querySelector('input[name=replaces_id]').value;
83
84 if (replaces_id) {
85 switchProduct(replaces_id, {
86 name,
87 productID,
88 productURL,
89 });
90 } else {
91 addWidget({name, productID, productURL});
92 }
93 });
94 })();
95 </script>
96 <style>
97 #fastcomments-widgets {
98 display: flex;
99 }
100 #fastcomments-widgets > div {
101 width: 100%;
102 }
103
104 .demo-form section label {
105 display: block;
106 margin-bottom: 20px;
107 }
108 </style>
109

To je podobno, kot deluje straničenje.

S knjižnicami React in sorodnimi lahko preprosto posodobimo konfiguracijo, knjižnica (React, Angular, Vue) bo poskrbela za osvežitev widgeta za nas. Pri VanillaJS pa ga moramo upravljati sami, kot je prikazano.

Prosto postavite kakršna koli vprašanja spodaj in potrudili se bomo pomagati!