1 | ;
|
2 |
|
3 | var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
|
4 |
|
5 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
6 |
|
7 | Object.defineProperty(exports, "__esModule", {
|
8 | value: true
|
9 | });
|
10 | exports["default"] = void 0;
|
11 |
|
12 | var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
13 |
|
14 | var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
15 |
|
16 | var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
17 |
|
18 | var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
19 |
|
20 | var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
21 |
|
22 | var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
23 |
|
24 | var _emotion = require("emotion");
|
25 |
|
26 | var _react = _interopRequireWildcard(require("react"));
|
27 |
|
28 | var _propTypes = _interopRequireDefault(require("prop-types"));
|
29 |
|
30 | var _button = _interopRequireDefault(require("@lskjs/button"));
|
31 |
|
32 | var _helpers = _interopRequireDefault(require("./helpers"));
|
33 |
|
34 | function _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 |
|
36 | function _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 |
|
38 | function _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 |
|
40 | var helpers = new _helpers["default"]();
|
41 | var 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 |
|
51 | var 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 |
|
232 | exports["default"] = ReactAddToCalendar;
|
233 | ReactAddToCalendar.displayName = 'Add To Calendar';
|
234 | ReactAddToCalendar.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 | };
|
255 | ReactAddToCalendar.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 |