UNPKG

42.7 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
5var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
7Object.defineProperty(exports, "__esModule", {
8 value: true
9});
10exports["default"] = void 0;
11
12var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
13
14var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
15
16var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
17
18var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
19
20var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
21
22var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
23
24var _emotion = require("emotion");
25
26var _react = _interopRequireWildcard(require("react"));
27
28var _propTypes = _interopRequireDefault(require("prop-types"));
29
30var _button = _interopRequireDefault(require("@lskjs/button"));
31
32var _helpers = _interopRequireDefault(require("./helpers"));
33
34function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
35
36function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
37
38function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
39
40var helpers = new _helpers["default"]();
41var styleDropdown = /*#__PURE__*/(0, _emotion.css)(process.env.NODE_ENV === "production" ? {
42 name: "16ybbt8-styleDropdown",
43 styles: "background-color:#fff;border:1px solid #9b9b9b;border-radius:2px;padding:5px 10px;margin-top:4px;> ul{margin-bottom:0;};label:styleDropdown;"
44} : {
45 name: "16ybbt8-styleDropdown",
46 styles: "background-color:#fff;border:1px solid #9b9b9b;border-radius:2px;padding:5px 10px;margin-top:4px;> ul{margin-bottom:0;};label:styleDropdown;",
47 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/AddToCalendar/AddToCalendar.jsx"],"names":[],"mappings":"AASyB","file":"../../src/AddToCalendar/AddToCalendar.jsx","sourcesContent":["import React, { Component } from 'react';\nimport { css } from 'emotion';\nimport PropTypes from 'prop-types';\nimport Button from '@lskjs/button';\n\nimport HelpersClass from './helpers';\n\nconst helpers = new HelpersClass();\n\nconst styleDropdown = css`\n  background-color: #fff;\n  border: 1px solid #9b9b9b;\n  border-radius: 2px;\n  padding: 5px 10px;\n  margin-top: 4px;\n  > ul {\n    margin-bottom: 0;\n  }\n`;\n\nexport default class ReactAddToCalendar extends Component {\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      optionsOpen: props.optionsOpen || false,\n      isCrappyIE: false,\n    };\n\n    this.toggleCalendarDropdown = this.toggleCalendarDropdown.bind(this);\n    this.handleDropdownLinkClick = this.handleDropdownLinkClick.bind(this);\n  }\n\n  componentWillMount() {\n    // polyfill for startsWith to fix IE bug\n    if (!String.prototype.startsWith) {\n      String.prototype.startsWith = function(searchString, position) {\n        position = position || 0;\n        return this.indexOf(searchString, position) === position;\n      };\n    }\n\n    let isCrappyIE = false;\n    if (typeof window !== 'undefined' && window.navigator.msSaveOrOpenBlob && window.Blob) {\n      isCrappyIE = true;\n    }\n\n    this.setState({ isCrappyIE });\n  }\n\n  toggleCalendarDropdown() {\n    const showOptions = !this.state.optionsOpen;\n\n    if (!isTouchDevice()) {\n      if (showOptions) {\n        document.addEventListener('click', this.toggleCalendarDropdown, false);\n      } else {\n        document.removeEventListener('click', this.toggleCalendarDropdown);\n      }\n    }\n\n    this.setState({ optionsOpen: showOptions });\n  }\n\n  handleDropdownLinkClick(e) {\n    e.preventDefault();\n    const url = e.currentTarget.getAttribute('href');\n\n    if (!helpers.isMobile() && (url.startsWith('data') || url.startsWith('BEGIN'))) {\n      const filename = 'download.ics';\n      const blob = new Blob([url], { type: 'text/calendar;charset=utf-8' });\n\n      if (this.state.isCrappyIE) {\n        window.navigator.msSaveOrOpenBlob(blob, filename);\n      } else {\n        /** **************************************************************\n         // many browsers do not properly support downloading data URIs\n         // (even with \"download\" attribute in use) so this solution\n         // ensures the event will download cross-browser\n         *************************************************************** */\n        const link = document.createElement('a');\n        link.href = window.URL.createObjectURL(blob);\n        link.setAttribute('download', filename);\n        document.body.appendChild(link);\n        link.click();\n        document.body.removeChild(link);\n      }\n    } else {\n      window.open(url, '_blank');\n    }\n\n    this.toggleCalendarDropdown();\n  }\n\n  renderDropdown() {\n    const self = this;\n\n    const items = this.props.listItems.map(listItem => {\n      const currentItem = Object.keys(listItem)[0];\n      const currentLabel = listItem[currentItem];\n\n      let icon = null;\n      if (self.props.displayItemIcons) {\n        const currentIcon = currentItem === 'outlook' || currentItem === 'outlookcom' ? 'windows' : currentItem;\n        icon = <i className={`fa fa-${currentIcon}`} />;\n      }\n\n      return (\n        <li key={helpers.getRandomKey()}>\n          <a\n            className={`${currentItem}-link`}\n            style={{ color: '#4a4a4a' }}\n            onClick={self.handleDropdownLinkClick}\n            href={helpers.buildUrl(self.props.event, currentItem, self.state.isCrappyIE)}\n            target=\"_blank\"\n            rel=\"noopener noreferrer\"\n          >\n            {icon}\n            {currentLabel}\n          </a>\n        </li>\n      );\n    });\n\n    return (\n      <div className={styleDropdown}>\n        <ul>{items}</ul>\n      </div>\n    );\n  }\n\n  renderButton() {\n    let { buttonLabel } = this.props;\n    let buttonIcon = null;\n    const template = Object.keys(this.props.buttonTemplate);\n\n    if (template[0] !== 'textOnly') {\n      const iconPlacement = this.props.buttonTemplate[template];\n      const buttonClassPrefix =\n        this.props.buttonIconClass === 'react-add-to-calendar__icon--'\n          ? `${this.props.buttonIconClass}${iconPlacement}`\n          : this.props.buttonIconClass;\n      const iconPrefix = this.props.useFontAwesomeIcons ? 'fa fa-' : '';\n\n      const mainButtonIconClass =\n        template[0] === 'caret' ? (this.state.optionsOpen ? 'caret-up' : 'caret-down') : template[0];\n\n      const buttonIconClass = `${buttonClassPrefix} ${iconPrefix}${mainButtonIconClass}`;\n\n      buttonIcon = <i className={buttonIconClass} />;\n      buttonLabel =\n        iconPlacement === 'right' ? (\n          <span>\n            {`${buttonLabel} `}\n            {buttonIcon}\n          </span>\n        ) : (\n          <span>\n            {buttonIcon}\n            {` ${buttonLabel}`}\n          </span>\n        );\n    }\n\n    const buttonClass = this.state.optionsOpen\n      ? `${this.props.buttonClassClosed} ${this.props.buttonClassOpen}`\n      : this.props.buttonClassClosed;\n\n    return (\n      <div className={this.props.buttonWrapperClass}>\n        <Button\n          componentClass=\"a\"\n          paint=\"primary\"\n          view=\"text\"\n          bordered\n          block\n          className={buttonClass}\n          onClick={this.toggleCalendarDropdown}\n        >\n          {buttonLabel}\n        </Button>\n      </div>\n    );\n  }\n\n  render() {\n    let options = null;\n    if (this.state.optionsOpen) {\n      options = this.renderDropdown();\n    }\n\n    let addToCalendarBtn = null;\n    if (this.props.event) {\n      addToCalendarBtn = this.renderButton();\n    }\n\n    return (\n      <div style={{ width: '100%' }} className={this.props.rootClass}>\n        {addToCalendarBtn}\n        {options}\n      </div>\n    );\n  }\n}\n\nReactAddToCalendar.displayName = 'Add To Calendar';\n\nReactAddToCalendar.propTypes = {\n  buttonClassClosed: PropTypes.string,\n  buttonClassOpen: PropTypes.string,\n  buttonLabel: PropTypes.string,\n  buttonTemplate: PropTypes.object,\n  buttonIconClass: PropTypes.string,\n  useFontAwesomeIcons: PropTypes.bool,\n  buttonWrapperClass: PropTypes.string,\n  displayItemIcons: PropTypes.bool,\n  optionsOpen: PropTypes.bool,\n  dropdownClass: PropTypes.string,\n  event: PropTypes.shape({\n    title: PropTypes.string,\n    description: PropTypes.string,\n    location: PropTypes.string,\n    startTime: PropTypes.string,\n    endTime: PropTypes.string,\n  }).isRequired,\n  listItems: PropTypes.arrayOf(PropTypes.object),\n  rootClass: PropTypes.string,\n};\n\nReactAddToCalendar.defaultProps = {\n  buttonClassClosed: 'react-add-to-calendar__button',\n  buttonClassOpen: 'react-add-to-calendar__button--light',\n  buttonLabel: 'Add to My Calendar',\n  buttonTemplate: { caret: 'right' },\n  buttonIconClass: 'react-add-to-calendar__icon--',\n  useFontAwesomeIcons: true,\n  buttonWrapperClass: 'react-add-to-calendar__wrapper',\n  displayItemIcons: true,\n  optionsOpen: false,\n  dropdownClass: 'react-add-to-calendar__dropdown',\n  event: {\n    title: 'Sample Event',\n    description: 'This is the sample event provided as an example only',\n    location: 'Portland, OR',\n    startTime: '2016-09-16T20:15:00-04:00',\n    endTime: '2016-09-16T21:45:00-04:00',\n  },\n  listItems: [\n    { apple: 'Apple Calendar' },\n    { google: 'Google' },\n    { outlook: 'Outlook' },\n    { outlookcom: 'Outlook.com' },\n    { yahoo: 'Yahoo' },\n  ],\n  rootClass: 'react-add-to-calendar',\n};\n"]} */",
48 toString: _EMOTION_STRINGIFIED_CSS_ERROR__
49});
50
51var ReactAddToCalendar = /*#__PURE__*/function (_Component) {
52 (0, _inherits2["default"])(ReactAddToCalendar, _Component);
53
54 var _super = _createSuper(ReactAddToCalendar);
55
56 function ReactAddToCalendar(props) {
57 var _this;
58
59 (0, _classCallCheck2["default"])(this, ReactAddToCalendar);
60 _this = _super.call(this, props);
61 _this.state = {
62 optionsOpen: props.optionsOpen || false,
63 isCrappyIE: false
64 };
65 _this.toggleCalendarDropdown = _this.toggleCalendarDropdown.bind((0, _assertThisInitialized2["default"])(_this));
66 _this.handleDropdownLinkClick = _this.handleDropdownLinkClick.bind((0, _assertThisInitialized2["default"])(_this));
67 return _this;
68 }
69
70 (0, _createClass2["default"])(ReactAddToCalendar, [{
71 key: "componentWillMount",
72 value: function componentWillMount() {
73 // polyfill for startsWith to fix IE bug
74 if (!String.prototype.startsWith) {
75 String.prototype.startsWith = function (searchString, position) {
76 position = position || 0;
77 return this.indexOf(searchString, position) === position;
78 };
79 }
80
81 var isCrappyIE = false;
82
83 if (typeof window !== 'undefined' && window.navigator.msSaveOrOpenBlob && window.Blob) {
84 isCrappyIE = true;
85 }
86
87 this.setState({
88 isCrappyIE: isCrappyIE
89 });
90 }
91 }, {
92 key: "toggleCalendarDropdown",
93 value: function toggleCalendarDropdown() {
94 var showOptions = !this.state.optionsOpen;
95
96 if (!isTouchDevice()) {
97 if (showOptions) {
98 document.addEventListener('click', this.toggleCalendarDropdown, false);
99 } else {
100 document.removeEventListener('click', this.toggleCalendarDropdown);
101 }
102 }
103
104 this.setState({
105 optionsOpen: showOptions
106 });
107 }
108 }, {
109 key: "handleDropdownLinkClick",
110 value: function handleDropdownLinkClick(e) {
111 e.preventDefault();
112 var url = e.currentTarget.getAttribute('href');
113
114 if (!helpers.isMobile() && (url.startsWith('data') || url.startsWith('BEGIN'))) {
115 var filename = 'download.ics';
116 var blob = new Blob([url], {
117 type: 'text/calendar;charset=utf-8'
118 });
119
120 if (this.state.isCrappyIE) {
121 window.navigator.msSaveOrOpenBlob(blob, filename);
122 } else {
123 /** **************************************************************
124 // many browsers do not properly support downloading data URIs
125 // (even with "download" attribute in use) so this solution
126 // ensures the event will download cross-browser
127 *************************************************************** */
128 var link = document.createElement('a');
129 link.href = window.URL.createObjectURL(blob);
130 link.setAttribute('download', filename);
131 document.body.appendChild(link);
132 link.click();
133 document.body.removeChild(link);
134 }
135 } else {
136 window.open(url, '_blank');
137 }
138
139 this.toggleCalendarDropdown();
140 }
141 }, {
142 key: "renderDropdown",
143 value: function renderDropdown() {
144 var self = this;
145 var items = this.props.listItems.map(function (listItem) {
146 var currentItem = Object.keys(listItem)[0];
147 var currentLabel = listItem[currentItem];
148 var icon = null;
149
150 if (self.props.displayItemIcons) {
151 var currentIcon = currentItem === 'outlook' || currentItem === 'outlookcom' ? 'windows' : currentItem;
152 icon = /*#__PURE__*/_react["default"].createElement("i", {
153 className: "fa fa-".concat(currentIcon)
154 });
155 }
156
157 return /*#__PURE__*/_react["default"].createElement("li", {
158 key: helpers.getRandomKey()
159 }, /*#__PURE__*/_react["default"].createElement("a", {
160 className: "".concat(currentItem, "-link"),
161 style: {
162 color: '#4a4a4a'
163 },
164 onClick: self.handleDropdownLinkClick,
165 href: helpers.buildUrl(self.props.event, currentItem, self.state.isCrappyIE),
166 target: "_blank",
167 rel: "noopener noreferrer"
168 }, icon, currentLabel));
169 });
170 return /*#__PURE__*/_react["default"].createElement("div", {
171 className: styleDropdown
172 }, /*#__PURE__*/_react["default"].createElement("ul", null, items));
173 }
174 }, {
175 key: "renderButton",
176 value: function renderButton() {
177 var buttonLabel = this.props.buttonLabel;
178 var buttonIcon = null;
179 var template = Object.keys(this.props.buttonTemplate);
180
181 if (template[0] !== 'textOnly') {
182 var iconPlacement = this.props.buttonTemplate[template];
183 var buttonClassPrefix = this.props.buttonIconClass === 'react-add-to-calendar__icon--' ? "".concat(this.props.buttonIconClass).concat(iconPlacement) : this.props.buttonIconClass;
184 var iconPrefix = this.props.useFontAwesomeIcons ? 'fa fa-' : '';
185 var mainButtonIconClass = template[0] === 'caret' ? this.state.optionsOpen ? 'caret-up' : 'caret-down' : template[0];
186 var buttonIconClass = "".concat(buttonClassPrefix, " ").concat(iconPrefix).concat(mainButtonIconClass);
187 buttonIcon = /*#__PURE__*/_react["default"].createElement("i", {
188 className: buttonIconClass
189 });
190 buttonLabel = iconPlacement === 'right' ? /*#__PURE__*/_react["default"].createElement("span", null, "".concat(buttonLabel, " "), buttonIcon) : /*#__PURE__*/_react["default"].createElement("span", null, buttonIcon, " ".concat(buttonLabel));
191 }
192
193 var buttonClass = this.state.optionsOpen ? "".concat(this.props.buttonClassClosed, " ").concat(this.props.buttonClassOpen) : this.props.buttonClassClosed;
194 return /*#__PURE__*/_react["default"].createElement("div", {
195 className: this.props.buttonWrapperClass
196 }, /*#__PURE__*/_react["default"].createElement(_button["default"], {
197 componentClass: "a",
198 paint: "primary",
199 view: "text",
200 bordered: true,
201 block: true,
202 className: buttonClass,
203 onClick: this.toggleCalendarDropdown
204 }, buttonLabel));
205 }
206 }, {
207 key: "render",
208 value: function render() {
209 var options = null;
210
211 if (this.state.optionsOpen) {
212 options = this.renderDropdown();
213 }
214
215 var addToCalendarBtn = null;
216
217 if (this.props.event) {
218 addToCalendarBtn = this.renderButton();
219 }
220
221 return /*#__PURE__*/_react["default"].createElement("div", {
222 style: {
223 width: '100%'
224 },
225 className: this.props.rootClass
226 }, addToCalendarBtn, options);
227 }
228 }]);
229 return ReactAddToCalendar;
230}(_react.Component);
231
232exports["default"] = ReactAddToCalendar;
233ReactAddToCalendar.displayName = 'Add To Calendar';
234ReactAddToCalendar.propTypes = {
235 buttonClassClosed: _propTypes["default"].string,
236 buttonClassOpen: _propTypes["default"].string,
237 buttonLabel: _propTypes["default"].string,
238 buttonTemplate: _propTypes["default"].object,
239 buttonIconClass: _propTypes["default"].string,
240 useFontAwesomeIcons: _propTypes["default"].bool,
241 buttonWrapperClass: _propTypes["default"].string,
242 displayItemIcons: _propTypes["default"].bool,
243 optionsOpen: _propTypes["default"].bool,
244 dropdownClass: _propTypes["default"].string,
245 event: _propTypes["default"].shape({
246 title: _propTypes["default"].string,
247 description: _propTypes["default"].string,
248 location: _propTypes["default"].string,
249 startTime: _propTypes["default"].string,
250 endTime: _propTypes["default"].string
251 }).isRequired,
252 listItems: _propTypes["default"].arrayOf(_propTypes["default"].object),
253 rootClass: _propTypes["default"].string
254};
255ReactAddToCalendar.defaultProps = {
256 buttonClassClosed: 'react-add-to-calendar__button',
257 buttonClassOpen: 'react-add-to-calendar__button--light',
258 buttonLabel: 'Add to My Calendar',
259 buttonTemplate: {
260 caret: 'right'
261 },
262 buttonIconClass: 'react-add-to-calendar__icon--',
263 useFontAwesomeIcons: true,
264 buttonWrapperClass: 'react-add-to-calendar__wrapper',
265 displayItemIcons: true,
266 optionsOpen: false,
267 dropdownClass: 'react-add-to-calendar__dropdown',
268 event: {
269 title: 'Sample Event',
270 description: 'This is the sample event provided as an example only',
271 location: 'Portland, OR',
272 startTime: '2016-09-16T20:15:00-04:00',
273 endTime: '2016-09-16T21:45:00-04:00'
274 },
275 listItems: [{
276 apple: 'Apple Calendar'
277 }, {
278 google: 'Google'
279 }, {
280 outlook: 'Outlook'
281 }, {
282 outlookcom: 'Outlook.com'
283 }, {
284 yahoo: 'Yahoo'
285 }],
286 rootClass: 'react-add-to-calendar'
287};
288//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/AddToCalendar/AddToCalendar.jsx"],"names":["helpers","HelpersClass","styleDropdown","ReactAddToCalendar","props","state","optionsOpen","isCrappyIE","toggleCalendarDropdown","bind","handleDropdownLinkClick","String","prototype","startsWith","searchString","position","indexOf","window","navigator","msSaveOrOpenBlob","Blob","setState","showOptions","isTouchDevice","document","addEventListener","removeEventListener","e","preventDefault","url","currentTarget","getAttribute","isMobile","filename","blob","type","link","createElement","href","URL","createObjectURL","setAttribute","body","appendChild","click","removeChild","open","self","items","listItems","map","listItem","currentItem","Object","keys","currentLabel","icon","displayItemIcons","currentIcon","getRandomKey","color","buildUrl","event","buttonLabel","buttonIcon","template","buttonTemplate","iconPlacement","buttonClassPrefix","buttonIconClass","iconPrefix","useFontAwesomeIcons","mainButtonIconClass","buttonClass","buttonClassClosed","buttonClassOpen","buttonWrapperClass","options","renderDropdown","addToCalendarBtn","renderButton","width","rootClass","Component","displayName","propTypes","PropTypes","string","object","bool","dropdownClass","shape","title","description","location","startTime","endTime","isRequired","arrayOf","defaultProps","caret","apple","google","outlook","outlookcom","yahoo"],"mappings":"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","sourcesContent":["import React, { Component } from 'react';\nimport { css } from 'emotion';\nimport PropTypes from 'prop-types';\nimport Button from '@lskjs/button';\n\nimport HelpersClass from './helpers';\n\nconst helpers = new HelpersClass();\n\nconst styleDropdown = css`\n  background-color: #fff;\n  border: 1px solid #9b9b9b;\n  border-radius: 2px;\n  padding: 5px 10px;\n  margin-top: 4px;\n  > ul {\n    margin-bottom: 0;\n  }\n`;\n\nexport default class ReactAddToCalendar extends Component {\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      optionsOpen: props.optionsOpen || false,\n      isCrappyIE: false,\n    };\n\n    this.toggleCalendarDropdown = this.toggleCalendarDropdown.bind(this);\n    this.handleDropdownLinkClick = this.handleDropdownLinkClick.bind(this);\n  }\n\n  componentWillMount() {\n    // polyfill for startsWith to fix IE bug\n    if (!String.prototype.startsWith) {\n      String.prototype.startsWith = function(searchString, position) {\n        position = position || 0;\n        return this.indexOf(searchString, position) === position;\n      };\n    }\n\n    let isCrappyIE = false;\n    if (typeof window !== 'undefined' && window.navigator.msSaveOrOpenBlob && window.Blob) {\n      isCrappyIE = true;\n    }\n\n    this.setState({ isCrappyIE });\n  }\n\n  toggleCalendarDropdown() {\n    const showOptions = !this.state.optionsOpen;\n\n    if (!isTouchDevice()) {\n      if (showOptions) {\n        document.addEventListener('click', this.toggleCalendarDropdown, false);\n      } else {\n        document.removeEventListener('click', this.toggleCalendarDropdown);\n      }\n    }\n\n    this.setState({ optionsOpen: showOptions });\n  }\n\n  handleDropdownLinkClick(e) {\n    e.preventDefault();\n    const url = e.currentTarget.getAttribute('href');\n\n    if (!helpers.isMobile() && (url.startsWith('data') || url.startsWith('BEGIN'))) {\n      const filename = 'download.ics';\n      const blob = new Blob([url], { type: 'text/calendar;charset=utf-8' });\n\n      if (this.state.isCrappyIE) {\n        window.navigator.msSaveOrOpenBlob(blob, filename);\n      } else {\n        /** **************************************************************\n         // many browsers do not properly support downloading data URIs\n         // (even with \"download\" attribute in use) so this solution\n         // ensures the event will download cross-browser\n         *************************************************************** */\n        const link = document.createElement('a');\n        link.href = window.URL.createObjectURL(blob);\n        link.setAttribute('download', filename);\n        document.body.appendChild(link);\n        link.click();\n        document.body.removeChild(link);\n      }\n    } else {\n      window.open(url, '_blank');\n    }\n\n    this.toggleCalendarDropdown();\n  }\n\n  renderDropdown() {\n    const self = this;\n\n    const items = this.props.listItems.map(listItem => {\n      const currentItem = Object.keys(listItem)[0];\n      const currentLabel = listItem[currentItem];\n\n      let icon = null;\n      if (self.props.displayItemIcons) {\n        const currentIcon = currentItem === 'outlook' || currentItem === 'outlookcom' ? 'windows' : currentItem;\n        icon = <i className={`fa fa-${currentIcon}`} />;\n      }\n\n      return (\n        <li key={helpers.getRandomKey()}>\n          <a\n            className={`${currentItem}-link`}\n            style={{ color: '#4a4a4a' }}\n            onClick={self.handleDropdownLinkClick}\n            href={helpers.buildUrl(self.props.event, currentItem, self.state.isCrappyIE)}\n            target=\"_blank\"\n            rel=\"noopener noreferrer\"\n          >\n            {icon}\n            {currentLabel}\n          </a>\n        </li>\n      );\n    });\n\n    return (\n      <div className={styleDropdown}>\n        <ul>{items}</ul>\n      </div>\n    );\n  }\n\n  renderButton() {\n    let { buttonLabel } = this.props;\n    let buttonIcon = null;\n    const template = Object.keys(this.props.buttonTemplate);\n\n    if (template[0] !== 'textOnly') {\n      const iconPlacement = this.props.buttonTemplate[template];\n      const buttonClassPrefix =\n        this.props.buttonIconClass === 'react-add-to-calendar__icon--'\n          ? `${this.props.buttonIconClass}${iconPlacement}`\n          : this.props.buttonIconClass;\n      const iconPrefix = this.props.useFontAwesomeIcons ? 'fa fa-' : '';\n\n      const mainButtonIconClass =\n        template[0] === 'caret' ? (this.state.optionsOpen ? 'caret-up' : 'caret-down') : template[0];\n\n      const buttonIconClass = `${buttonClassPrefix} ${iconPrefix}${mainButtonIconClass}`;\n\n      buttonIcon = <i className={buttonIconClass} />;\n      buttonLabel =\n        iconPlacement === 'right' ? (\n          <span>\n            {`${buttonLabel} `}\n            {buttonIcon}\n          </span>\n        ) : (\n          <span>\n            {buttonIcon}\n            {` ${buttonLabel}`}\n          </span>\n        );\n    }\n\n    const buttonClass = this.state.optionsOpen\n      ? `${this.props.buttonClassClosed} ${this.props.buttonClassOpen}`\n      : this.props.buttonClassClosed;\n\n    return (\n      <div className={this.props.buttonWrapperClass}>\n        <Button\n          componentClass=\"a\"\n          paint=\"primary\"\n          view=\"text\"\n          bordered\n          block\n          className={buttonClass}\n          onClick={this.toggleCalendarDropdown}\n        >\n          {buttonLabel}\n        </Button>\n      </div>\n    );\n  }\n\n  render() {\n    let options = null;\n    if (this.state.optionsOpen) {\n      options = this.renderDropdown();\n    }\n\n    let addToCalendarBtn = null;\n    if (this.props.event) {\n      addToCalendarBtn = this.renderButton();\n    }\n\n    return (\n      <div style={{ width: '100%' }} className={this.props.rootClass}>\n        {addToCalendarBtn}\n        {options}\n      </div>\n    );\n  }\n}\n\nReactAddToCalendar.displayName = 'Add To Calendar';\n\nReactAddToCalendar.propTypes = {\n  buttonClassClosed: PropTypes.string,\n  buttonClassOpen: PropTypes.string,\n  buttonLabel: PropTypes.string,\n  buttonTemplate: PropTypes.object,\n  buttonIconClass: PropTypes.string,\n  useFontAwesomeIcons: PropTypes.bool,\n  buttonWrapperClass: PropTypes.string,\n  displayItemIcons: PropTypes.bool,\n  optionsOpen: PropTypes.bool,\n  dropdownClass: PropTypes.string,\n  event: PropTypes.shape({\n    title: PropTypes.string,\n    description: PropTypes.string,\n    location: PropTypes.string,\n    startTime: PropTypes.string,\n    endTime: PropTypes.string,\n  }).isRequired,\n  listItems: PropTypes.arrayOf(PropTypes.object),\n  rootClass: PropTypes.string,\n};\n\nReactAddToCalendar.defaultProps = {\n  buttonClassClosed: 'react-add-to-calendar__button',\n  buttonClassOpen: 'react-add-to-calendar__button--light',\n  buttonLabel: 'Add to My Calendar',\n  buttonTemplate: { caret: 'right' },\n  buttonIconClass: 'react-add-to-calendar__icon--',\n  useFontAwesomeIcons: true,\n  buttonWrapperClass: 'react-add-to-calendar__wrapper',\n  displayItemIcons: true,\n  optionsOpen: false,\n  dropdownClass: 'react-add-to-calendar__dropdown',\n  event: {\n    title: 'Sample Event',\n    description: 'This is the sample event provided as an example only',\n    location: 'Portland, OR',\n    startTime: '2016-09-16T20:15:00-04:00',\n    endTime: '2016-09-16T21:45:00-04:00',\n  },\n  listItems: [\n    { apple: 'Apple Calendar' },\n    { google: 'Google' },\n    { outlook: 'Outlook' },\n    { outlookcom: 'Outlook.com' },\n    { yahoo: 'Yahoo' },\n  ],\n  rootClass: 'react-add-to-calendar',\n};\n"]}
289//# sourceMappingURL=AddToCalendar.js.map
\No newline at end of file