UNPKG

5.7 kBJavaScriptView Raw
1"use strict";
2var __assign = (this && this.__assign) || function () {
3 __assign = Object.assign || function(t) {
4 for (var s, i = 1, n = arguments.length; i < n; i++) {
5 s = arguments[i];
6 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7 t[p] = s[p];
8 }
9 return t;
10 };
11 return __assign.apply(this, arguments);
12};
13var __spreadArrays = (this && this.__spreadArrays) || function () {
14 for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
15 for (var r = Array(s), k = 0, i = 0; i < il; i++)
16 for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
17 r[k] = a[j];
18 return r;
19};
20Object.defineProperty(exports, "__esModule", { value: true });
21var lg_share_settings_1 = require("./lg-share-settings");
22var lg_fb_share_utils_1 = require("./lg-fb-share-utils");
23var lg_twitter_share_utils_1 = require("./lg-twitter-share-utils");
24var lg_pinterest_share_utils_1 = require("./lg-pinterest-share-utils");
25var lg_events_1 = require("../../lg-events");
26var Share = /** @class */ (function () {
27 function Share(instance) {
28 this.shareOptions = [];
29 // get lightGallery core plugin instance
30 this.core = instance;
31 // extend module default settings with lightGallery core settings
32 this.settings = __assign(__assign({}, lg_share_settings_1.shareSettings), this.core.settings);
33 return this;
34 }
35 Share.prototype.init = function () {
36 if (!this.settings.share) {
37 return;
38 }
39 this.shareOptions = __spreadArrays(this.getDefaultShareOptions(), this.settings.additionalShareOptions);
40 this.setLgShareMarkup();
41 this.core.outer
42 .find('.lg-share .lg-dropdown')
43 .append(this.getShareListHtml());
44 this.core.LGel.on(lg_events_1.lGEvents.afterSlide + ".share", this.onAfterSlide.bind(this));
45 };
46 Share.prototype.getShareListHtml = function () {
47 var shareHtml = '';
48 this.shareOptions.forEach(function (shareOption) {
49 shareHtml += shareOption.dropdownHTML;
50 });
51 return shareHtml;
52 };
53 Share.prototype.setLgShareMarkup = function () {
54 var _this = this;
55 this.core.$toolbar.append("<button type=\"button\" aria-label=\"" + this.settings.sharePluginStrings['share'] + "\" aria-haspopup=\"true\" aria-expanded=\"false\" class=\"lg-share lg-icon\">\n <ul class=\"lg-dropdown\" style=\"position: absolute;\"></ul></button>");
56 this.core.outer.append('<div class="lg-dropdown-overlay"></div>');
57 var $shareButton = this.core.outer.find('.lg-share');
58 $shareButton.first().on('click.lg', function () {
59 _this.core.outer.toggleClass('lg-dropdown-active');
60 if (_this.core.outer.hasClass('lg-dropdown-active')) {
61 _this.core.outer.attr('aria-expanded', true);
62 }
63 else {
64 _this.core.outer.attr('aria-expanded', false);
65 }
66 });
67 this.core.outer
68 .find('.lg-dropdown-overlay')
69 .first()
70 .on('click.lg', function () {
71 _this.core.outer.removeClass('lg-dropdown-active');
72 _this.core.outer.attr('aria-expanded', false);
73 });
74 };
75 Share.prototype.onAfterSlide = function (event) {
76 var _this = this;
77 var index = event.detail.index;
78 var currentItem = this.core.galleryItems[index];
79 setTimeout(function () {
80 _this.shareOptions.forEach(function (shareOption) {
81 var selector = shareOption.selector;
82 _this.core.outer
83 .find(selector)
84 .attr('href', shareOption.generateLink(currentItem));
85 });
86 }, 100);
87 };
88 Share.prototype.getShareListItemHTML = function (type, text) {
89 return "<li><a class=\"lg-share-" + type + "\" rel=\"noopener\" target=\"_blank\"><span class=\"lg-icon\"></span><span class=\"lg-dropdown-text\">" + text + "</span></a></li>";
90 };
91 Share.prototype.getDefaultShareOptions = function () {
92 return __spreadArrays((this.settings.facebook
93 ? [
94 {
95 type: 'facebook',
96 generateLink: lg_fb_share_utils_1.getFacebookShareLink,
97 dropdownHTML: this.getShareListItemHTML('facebook', this.settings.facebookDropdownText),
98 selector: '.lg-share-facebook',
99 },
100 ]
101 : []), (this.settings.twitter
102 ? [
103 {
104 type: 'twitter',
105 generateLink: lg_twitter_share_utils_1.getTwitterShareLink,
106 dropdownHTML: this.getShareListItemHTML('twitter', this.settings.twitterDropdownText),
107 selector: '.lg-share-twitter',
108 },
109 ]
110 : []), (this.settings.pinterest
111 ? [
112 {
113 type: 'pinterest',
114 generateLink: lg_pinterest_share_utils_1.getPinterestShareLink,
115 dropdownHTML: this.getShareListItemHTML('pinterest', this.settings.pinterestDropdownText),
116 selector: '.lg-share-pinterest',
117 },
118 ]
119 : []));
120 };
121 Share.prototype.destroy = function () {
122 this.core.outer.find('.lg-dropdown-overlay').remove();
123 this.core.outer.find('.lg-share').remove();
124 this.core.LGel.off('.lg.share');
125 this.core.LGel.off('.share');
126 };
127 return Share;
128}());
129exports.default = Share;
130//# sourceMappingURL=lg-share.js.map
\No newline at end of file