@ribajs/bs4
Version:
Bootstrap 4 module for Riba.js
259 lines • 20 kB
JavaScript
import { Component } from "@ribajs/core";
import { getUrl } from "@ribajs/utils";
import labelTemplate from "./bs4-share.label.html?raw";
import { DropdownService } from "@ribajs/bs4";
import { hasChildNodesTrim } from "@ribajs/utils/src/dom.js";
export class Bs4ShareComponent extends Component {
static tagName = "bs4-share";
_debug = false;
static get observedAttributes() {
return [
"type",
"title",
"text",
"url",
"media-url",
"label",
"dropdown-direction",
];
}
dropdown;
static count = 0;
scope;
constructor() {
super();
this.scope = this.getScopeDefaults();
this.debug("constructor", this.scope);
Bs4ShareComponent.count++;
this.onExternalOpenEvent = this.onExternalOpenEvent.bind(this);
this.onExternalCloseEvent = this.onExternalCloseEvent.bind(this);
}
getDefaultShareServices() {
const newLine = "%0A";
const shareItems = [
{
id: "facebook",
label: "Facebook",
urlTemplate: "https://www.facebook.com/sharer/sharer.php?u={{url}}",
mediaUrlTemplate: "https://www.facebook.com/sharer/sharer.php?u={{media_url}}",
type: "popup",
url: "",
availableFor: ["page", "image", "video"],
},
{
id: "twitter",
label: "Twitter",
urlTemplate: "https://twitter.com/intent/tweet?text={{text}}&url={{url}}",
mediaUrlTemplate: `https://twitter.com/intent/tweet?text={{text}}&url={{media_url}}${newLine}({{url}})`,
url: "",
availableFor: ["page", "image", "video"],
},
{
id: "pinterest",
label: "Pinterest",
urlTemplate: "http://www.pinterest.com/pin/create/button/" +
"?url={{url}}&media={{media_url}}&description={{text}}",
type: "popup",
url: "",
availableFor: ["image", "video"],
},
{
id: "whatsapp",
label: "WhatsApp",
urlTemplate: `https://api.whatsapp.com/send?text={{text}}${newLine}${newLine}{{url}}`,
mediaUrlTemplate: `https://api.whatsapp.com/send?text={{text}}${newLine}${newLine}{{media_url}}${newLine}({{url}})`,
type: "popup",
url: "",
availableFor: ["page", "image", "video"],
},
{
id: "telegram",
label: "Telegram",
urlTemplate: `https://telegram.me/share/url?url={{media_url}}&text={{text}}`,
mediaUrlTemplate: `https://telegram.me/share/url?url={{media_url}}&text={{text}}${newLine}({{url}})`,
type: "popup",
url: "",
availableFor: ["page", "image", "video"],
},
{
id: "email",
label: "Email",
urlTemplate: `mailto:?subject={{title}}&body={{text}}${newLine}${newLine}{{url}}`,
mediaUrlTemplate: `mailto:?subject={{title}}&body={{text}}${newLine}${newLine}{{media_url}}${newLine}({{url}})`,
type: "href",
url: "",
availableFor: ["page", "image", "video"],
},
{
id: "download",
label: "Download image",
urlTemplate: "{{raw_media_url}}",
type: "download",
url: "",
availableFor: ["image", "video"],
},
];
return shareItems;
}
isIos() {
return navigator.userAgent.match(/iPhone|iPad|iPod/i) !== null;
}
isAndroid() {
return navigator.userAgent.match(/Android/i) !== null;
}
browserSupportsNativeShare() {
return typeof navigator.share === "function";
}
getScopeDefaults() {
const scope = {
type: "page",
title: document.title,
text: "Look at this! 👀🤩",
url: window.location.href,
label: "Share",
labelTemplate,
isAndroid: this.isAndroid(),
isIos: this.isIos(),
isDesktop: false,
isNative: this.browserSupportsNativeShare(),
dropdownId: "dropdownShare" + Bs4ShareComponent.count,
shareItems: this.getDefaultShareServices(),
dropdownDirection: "down",
share: this.share,
shareOnService: this.shareOnService,
};
scope.isDesktop = !scope.isIos && !scope.isAndroid;
return scope;
}
onExternalOpenEvent() {
this.dropdown?.show();
}
onExternalCloseEvent() {
this.dropdown?.close();
}
connectedCallback() {
super.connectedCallback();
this.init(Bs4ShareComponent.observedAttributes);
this.addEventListeners();
}
disconnectedCallback() {
super.disconnectedCallback();
this.removeEventListeners();
}
addEventListeners() {
this.addEventListener("open", this.onExternalOpenEvent);
this.addEventListener("close", this.onExternalCloseEvent);
}
removeEventListeners() {
this.removeEventListener("open", this.onExternalOpenEvent);
this.removeEventListener("close", this.onExternalOpenEvent);
}
getURLForShare() {
if (this.scope.type === "page" && this.scope.url) {
return getUrl(this.scope.url);
}
return window.location.href;
}
getMediaUrlForShare() {
if (this.scope.type !== "page" && this.scope.url) {
return getUrl(this.scope.url);
}
return "";
}
getTextForShare() {
return this.scope.text;
}
getTitleForShare() {
return this.scope.title;
}
updateShareURLs() {
for (const shareItem of this.scope.shareItems) {
const url = this.getURLForShare();
const mediaUrl = this.getMediaUrlForShare();
const shareText = this.getTextForShare();
const shareTitle = this.getTitleForShare();
let urlTemplate = shareItem.urlTemplate;
if (this.scope.type !== "page" && shareItem.mediaUrlTemplate) {
urlTemplate = shareItem.mediaUrlTemplate;
}
const shareURL = urlTemplate
.replace("{{url}}", encodeURIComponent(url))
.replace("{{url}}", encodeURIComponent(url))
.replace("{{media_url}}", encodeURIComponent(mediaUrl))
.replace("{{raw_media_url}}", mediaUrl)
.replace("{{text}}", encodeURIComponent(shareText))
.replace("{{title}}", encodeURIComponent(shareTitle));
shareItem.available = shareItem.availableFor.includes(this.scope.type);
shareItem.url = shareURL;
}
}
initDropdown() {
const dropDownButtonElement = this.querySelector(".dropdown-toggle-share");
if (!dropDownButtonElement) {
console.warn('Element with selector ".dropdown-toggle-share" not found!', this);
return;
}
this.dropdown = new DropdownService(dropDownButtonElement);
}
shareOnService(event, controller, el) {
this.debug("Open popup");
this.dropdown?.close();
if (!el || !el.href) {
console.error("No href attribute found");
return false;
}
if ((el.hasAttribute("type") && el.getAttribute("type") === "download") ||
el.getAttribute("type") === "href") {
return true;
}
event.preventDefault();
event.stopPropagation();
window.open(el.href, "Share", "scrollbars=yes,resizable=yes,toolbar=no," +
"location=yes,width=550,height=420,top=100,left=" +
(window.screen ? Math.round(screen.width / 2 - 275) : 100));
return false;
}
async share(event) {
this.debug("share", this.scope);
event.preventDefault();
event.stopPropagation();
if (this.scope.isNative && !this.scope.isDesktop) {
return navigator
.share({
title: this.scope.title,
text: `${this.scope.text}\r\n\r\n`,
url: this.scope.url || window.location.href,
})
.catch((error) => {
if (error.name === "AbortError") {
return;
}
console.error(`Error ${error.name}: ${error.message}`, error);
});
}
else {
this.updateShareURLs();
return this.dropdown?.toggle();
}
}
async beforeBind() {
await super.beforeBind();
}
async afterBind() {
this.initDropdown();
await super.afterBind();
}
requiredAttributes() {
return ["url"];
}
async template() {
this.debug("template", this, hasChildNodesTrim(this));
if (this && hasChildNodesTrim(this)) {
this.scope.labelTemplate = this.innerHTML;
this.debug("Custom label template: ", this.scope.labelTemplate);
}
const { default: template } = await import("./bs4-share.component.html?raw");
return template;
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs4-share.component.js","sourceRoot":"","sources":["../../../src/components/bs4-share/bs4-share.component.ts"],"names":[],"mappings":"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"}