{ function deparam(query) { var match; var plus = /\+/g; var search = /([^&=]+)=?([^&]*)/g; var decode = function decode(s) { return decodeURIComponent(s.replace(plus, ' ')); }; var params = {}; while (match = search.exec(query)) { params[decode(match[1])] = decode(match[2]); } return params; } function param(obj) { var parts = []; for (var name in obj) { if (obj.hasOwnProperty(name) && obj[name]) { parts.push(encodeURIComponent(name) + "=" + encodeURIComponent(obj[name])); } } return parts.join('&'); } let script = document.currentScript; let attrs = {}; for (let i = 0; i < script.attributes.length; i++) { let attribute = script.attributes.item(i); attrs[attribute.name.replace(/^data-/, '')] = attribute.value; } let canonicalLink = document.querySelector("link[rel='canonical']"); attrs.url = canonicalLink ? canonicalLink.href : location.origin + location.pathname + location.search; attrs.origin = location.origin; attrs.pathname = location.pathname.length < 2 ? 'index' : location.pathname.substr(1).replace(/\.\w+$/, ''); attrs.title = document.title; let descriptionMeta = document.querySelector("meta[name='description']"); attrs.description = descriptionMeta ? descriptionMeta.content : ''; let ogtitleMeta = document.querySelector("meta[property='og:title'],meta[name='og:title']"); attrs['og:title'] = ogtitleMeta ? ogtitleMeta.content : ''; document.head.insertAdjacentHTML('afterbegin', "<style>.Gissues{position:relative;box-sizing:border-box;width:100%;margin-left:auto;margin-right:auto;}.Gissues-frame{position:absolute;left:0;right:0;width:1px;min-width:100%;max-width:100%;height:100%;border:0;}</style>"); let Origin = "https://gissues.gitee.io"; let url = Origin + "/Gissues.html"; script.insertAdjacentHTML('afterend', "<div class='Gissues'><iframe class='Gissues-frame' title='Comments' scrolling='no' src='" + url + "?" + (0, param)(attrs) + "'></iframe></div>"); let container = script.nextElementSibling; script.parentElement.removeChild(script); addEventListener('message', function (event) { if (event.origin !== Origin) { return; } let data = event.data; if (data && data.type === 'resize' && data.height) { container.style.height = data.height + "px"; } }); }