@mopinion/survey
Version:
Collect customer feedback with the Mopinion survey library
474 lines (473 loc) • 20.8 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.listeners = exports["default"] = void 0;
var _preact = require("preact");
var _deepmerge = _interopRequireDefault(require("deepmerge"));
var _manager = require("./features/manager");
var _utils = require("./utils");
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
if (process.env.NODE_ENV === 'development') {
Promise.resolve().then(function () {
return _interopRequireWildcard(require('preact/debug'));
});
}
var disablePostFromCookie = (0, _utils.getCookie)('MopinionDisablePost') == 1;
function getDiv(div, useAll) {
return useAll ? (0, _utils.nodeListToArray)(document.querySelectorAll(div)) : document.querySelector(div);
}
function tryDiv(div) {
var useAll = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
try {
if (getDiv(div, useAll)) {
return getDiv(div, useAll);
} else {
return getDiv('#' + div, useAll);
}
} catch (e) {
return null;
}
}
function getContainerDiv(_ref) {
var container = _ref.container,
useAll = _ref.useAll,
existingContainer = _ref.existingContainer,
baseContainer = _ref.baseContainer;
if (!container) {
return existingContainer !== null && existingContainer !== void 0 ? existingContainer : baseContainer;
}
if (container instanceof Node) {
return container;
}
if (container instanceof NodeList) {
return (0, _utils.nodeListToArray)(container);
}
if (typeof container === 'string' && container.length && container.indexOf(',') === -1) {
return tryDiv(container, useAll);
}
if (typeof container === 'string' && container.indexOf(',') > -1) {
return container.split(',').map(function (n) {
return tryDiv(n);
});
}
return getDiv('#surveyContent:not(.mopinion-survey-content)');
}
function getDomain(_ref2) {
var domain = _ref2.domain,
existingDomain = _ref2.existingDomain,
baseDomain = _ref2.baseDomain;
if (domain) {
return domain;
}
if (existingDomain) {
return existingDomain;
}
return baseDomain;
}
var extraProps = {};
function setExtraProps(update) {
extraProps = (0, _deepmerge["default"])(extraProps, update, {
customMerge: function customMerge(key) {
if (key === 'values') {
return function (a, b) {
return b;
};
}
}
});
}
var listeners = exports.listeners = {};
var stateToArray = function stateToArray(obj) {
return Object.keys(obj).filter(function (key) {
return !isNaN(key);
}).map(function (key) {
return obj[key];
});
};
var srv = {
version: 2.0,
ALL_KEYS: [],
managerDiv: null,
render: function render() {
var _options$triggerMetho, _srv$options$key, _srv$srv$ALL_KEYS$, _options$formOpen, _ref3, _options$proxyCacheDo, _ref4, _options$proxyCustomD, _ref5, _options$proxyFeedbac, _ref6, _options$proxyMetrics, _ref7, _options$proxyFontsDo, _srv$options$key$inst, _srv$options$key2, _ref8, _options$proxyCssDoma, _options$getTrail, _options$container, _srv$srv$ALL_KEYS$2;
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var triggerMethod = (_options$triggerMetho = options.triggerMethod) !== null && _options$triggerMetho !== void 0 ? _options$triggerMetho : options.trigger_method;
var domain = getDomain({
domain: options.domain,
existingDomain: (_srv$options$key = srv[options.key]) === null || _srv$options$key === void 0 ? void 0 : _srv$options$key.domain,
baseDomain: (_srv$srv$ALL_KEYS$ = srv[srv.ALL_KEYS[0]]) === null || _srv$srv$ALL_KEYS$ === void 0 ? void 0 : _srv$srv$ALL_KEYS$.domain
});
var props = {
formKey: options.key,
domain: domain,
formOpen: (_options$formOpen = options.formOpen) !== null && _options$formOpen !== void 0 ? _options$formOpen : ['proactive', 'exit', 'force'].indexOf(triggerMethod) > -1 || null,
showButton: options.showButton || triggerMethod === 'passive',
cookieTime: options.cookie_expire || options.cookieTime || 30,
triggerMethod: triggerMethod,
forcePost: options.forcePost || false,
skipToLast: options.skipToLast || false,
forceType: options.forceType || false,
forceBreakPoint: options.forceBreakPoint || false,
forceButton: options.forceButton || false,
forceHeader: options.forceHeader || false,
webView: options.webView || false,
webViewShowHeader: options.webViewShowHeader || false,
proxyDomain: options.proxyDomain,
cacheDomain: (_ref3 = (_options$proxyCacheDo = options.proxyCacheDomain) !== null && _options$proxyCacheDo !== void 0 ? _options$proxyCacheDo : options.proxyDomain) !== null && _ref3 !== void 0 ? _ref3 : 'cacheorcheck.mopinion.com',
customDomain: (_ref4 = (_options$proxyCustomD = options.proxyCustomDomain) !== null && _options$proxyCustomD !== void 0 ? _options$proxyCustomD : options.proxyDomain) !== null && _ref4 !== void 0 ? _ref4 : domain,
feedbackDomain: (_ref5 = (_options$proxyFeedbac = options.proxyFeedbackDomain) !== null && _options$proxyFeedbac !== void 0 ? _options$proxyFeedbac : options.proxyDomain) !== null && _ref5 !== void 0 ? _ref5 : 'survey.mopinion.com',
metricsDomain: (_ref6 = (_options$proxyMetrics = options.proxyMetricsDomain) !== null && _options$proxyMetrics !== void 0 ? _options$proxyMetrics : options.proxyDomain) !== null && _ref6 !== void 0 ? _ref6 : 'metrics.mopinion.com',
fontsDomain: (_ref7 = (_options$proxyFontsDo = options.proxyFontsDomain) !== null && _options$proxyFontsDo !== void 0 ? _options$proxyFontsDo : options.proxyDomain) !== null && _ref7 !== void 0 ? _ref7 : 'fonts.mopinion.com',
isCompleted: options.isCompleted || false,
feedbackId: options.feedbackId || null,
disablePost: disablePostFromCookie || options.disablePost || false,
noCache: options.noCache || false,
instance: (_srv$options$key$inst = (_srv$options$key2 = srv[options.key]) === null || _srv$options$key2 === void 0 ? void 0 : _srv$options$key2.instance) !== null && _srv$options$key$inst !== void 0 ? _srv$options$key$inst : (0, _utils.rnd)(),
refresh: options.refresh ? (0, _utils.rnd)() : null,
cssDomain: (_ref8 = (_options$proxyCssDoma = options.proxyCssDomain) !== null && _options$proxyCssDoma !== void 0 ? _options$proxyCssDoma : options.proxyDomain) !== null && _ref8 !== void 0 ? _ref8 : 'collect.mopinion.com',
getTrail: (_options$getTrail = options.getTrail) !== null && _options$getTrail !== void 0 ? _options$getTrail : null
};
if (props.formOpen !== null) {
props.openAction = "form_open-".concat((0, _utils.rnd)());
}
if (!props.formKey) {
throw new Error('formKey required');
}
if (!srv.hasOwnProperty(props.formKey)) {
srv[props.formKey] = {};
srv.ALL_KEYS = [].concat(_toConsumableArray(srv.ALL_KEYS), [props.formKey]);
}
if (!options.hasOwnProperty('showButton') && srv[props.formKey].showButton) {
props.showButton = true;
}
var container = (_options$container = options.container) !== null && _options$container !== void 0 ? _options$container : options.divName;
var divName = getContainerDiv({
container: container,
useAll: options.useQuerySelectorAll,
existingContainer: srv[props.formKey].divName,
baseContainer: (_srv$srv$ALL_KEYS$2 = srv[srv.ALL_KEYS[0]]) === null || _srv$srv$ALL_KEYS$2 === void 0 ? void 0 : _srv$srv$ALL_KEYS$2.divName
});
props.divName = divName;
props.isMultiple = (0, _utils.isArray)(divName);
srv[props.formKey] = props;
(0, _utils.log)('Props', props);
(0, _utils.log)('Options', options);
(0, _utils.log)('Render div', srv[props.formKey].renderDiv);
return this.renderForms();
},
renderForms: function renderForms() {
if (!srv.managerDiv) {
var div = document.createElement('div');
document.body.appendChild(div);
srv.managerDiv = div;
}
var forms = srv.ALL_KEYS.map(function (key) {
return _objectSpread(_objectSpread({}, srv[key]), {}, {
extra: extraProps[key]
});
});
(0, _preact.render)((0, _preact.h)(_manager.FormManager, {
forms: forms
}), srv.managerDiv);
},
open: function open() {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
return srv.render(options);
},
isOpen: function isOpen(formKey) {
var _srv$formKey, _srv$formKey2;
return ((_srv$formKey = srv[formKey]) === null || _srv$formKey === void 0 ? void 0 : _srv$formKey._formOpen) && ((_srv$formKey2 = srv[formKey]) === null || _srv$formKey2 === void 0 ? void 0 : _srv$formKey2._formType) !== 'embed';
},
openModal: function openModal() {
var force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
var formKey = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : srv.ALL_KEYS[0];
try {
srv.open({
key: formKey,
formOpen: true
});
} catch (e) {}
},
closeModal: function closeModal() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : srv.ALL_KEYS[0];
try {
srv.open({
key: formKey,
formOpen: false
});
} catch (e) {}
},
send: function send() {
var skipToLast = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
var formKey = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
try {
if (!srv[formKey].isMultiple) {
srv.manager[formKey]._forcePost(skipToLast);
} else {
srv[formKey].divName.forEach(function (d, i) {
return srv.manager[formKey][i]._forcePost(skipToLast);
});
}
} catch (e) {}
},
clearForm: function clearForm() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
try {
delete srv[formKey];
var index = srv.ALL_KEYS.indexOf(formKey);
if (index !== -1) {
srv.ALL_KEYS.splice(srv.ALL_KEYS.indexOf(formKey), 1);
this.renderForms();
}
} catch (e) {}
},
setPage: function setPage() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var page = arguments.length > 1 ? arguments[1] : undefined;
try {
if (typeof page !== 'number') {
return;
}
setExtraProps(_defineProperty({}, formKey, {
page: page
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey,
domain: srv.ALL_KEYS[0].domain
});
} catch (e) {}
},
getFormConfig: function getFormConfig() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
try {
return srv[formKey]._config;
} catch (e) {}
},
getFormState: function getFormState(formKey) {
try {
if (srv[formKey].isMultiple) {
return srv[formKey]._multiple.map(function (data) {
return stateToArray(data._state);
});
}
return stateToArray(srv[formKey]._state);
} catch (e) {}
},
setValue: function setValue() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var field = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
var value = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';
try {
setExtraProps(_defineProperty({}, formKey, {
values: _defineProperty({}, field, value)
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey
});
} catch (e) {}
},
setBlock: function setBlock() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var id = arguments.length > 1 ? arguments[1] : undefined;
var obj = arguments.length > 2 ? arguments[2] : undefined;
try {
setExtraProps(_defineProperty({}, formKey, {
config: {
blocks: _defineProperty({}, id, obj)
}
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey
});
} catch (e) {}
},
setBlockProperties: function setBlockProperties() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var id = arguments.length > 1 ? arguments[1] : undefined;
var obj = arguments.length > 2 ? arguments[2] : undefined;
try {
setExtraProps(_defineProperty({}, formKey, {
config: {
blocks: _defineProperty({}, id, {
properties: obj
})
}
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey
});
} catch (e) {}
},
setBlockInnerElement: function setBlockInnerElement() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var _ref9 = arguments.length > 1 ? arguments[1] : undefined,
id = _ref9.id,
elementKey = _ref9.elementKey;
var obj = arguments.length > 2 ? arguments[2] : undefined;
try {
setExtraProps(_defineProperty({}, formKey, {
config: {
blocks: _defineProperty({}, id, {
properties: {
elements: obj
}
})
}
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey
});
} catch (e) {}
},
setProperties: function setProperties() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var obj = arguments.length > 1 ? arguments[1] : undefined;
try {
setExtraProps(_defineProperty({}, formKey, {
config: {
properties: obj
}
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey
});
} catch (e) {}
},
setText: function setText() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var obj = arguments.length > 1 ? arguments[1] : undefined;
try {
setExtraProps(_defineProperty({}, formKey, {
config: {
text: obj
}
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey
});
} catch (e) {}
},
setErrors: function setErrors() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var obj = arguments.length > 1 ? arguments[1] : undefined;
try {
setExtraProps(_defineProperty({}, formKey, {
config: {
text: {
errors: obj
}
}
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey
});
} catch (e) {}
},
setLanguage: function setLanguage() {
var formKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var language = arguments.length > 1 ? arguments[1] : undefined;
try {
setExtraProps(_defineProperty({}, formKey, {
language: language
}));
if (!srv[formKey]) {
return;
}
srv.render({
key: formKey
});
} catch (e) {}
},
setCookie: function setCookie() {
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var value = arguments.length > 1 ? arguments[1] : undefined;
var days = arguments.length > 2 ? arguments[2] : undefined;
return (0, _utils.setCookie)(name, value, days);
},
getCookie: function getCookie() {
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
return (0, _utils.getCookie)(name);
},
getUrlParam: function getUrlParam() {
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
return (0, _utils.getUrlParam)(name);
},
getStrParam: function getStrParam() {
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var str = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : document.location.href;
return (0, _utils.getStrParam)(name, str);
},
getParameterByName: function getParameterByName() {
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
var str = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : document.location.href;
return (0, _utils.getStrParam)(name, str);
},
triggerEvent: function triggerEvent() {
var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
return (0, _utils.triggerEvent)(data);
},
addEventListener: function addEventListener(event, fn) {
if (!listeners[event]) {
listeners[event] = [];
}
listeners[event].push(fn);
},
removeEventListener: function removeEventListener(event, fn) {
try {
listeners[event] = listeners[event].filter(function (ev) {
return ev.toString() !== fn.toString();
});
} catch (e) {}
},
reset: function reset(formKey) {
if (!srv[formKey]) {
return;
}
srv[formKey].instance = (0, _utils.rnd)();
this.renderForms();
}
};
if (typeof window !== 'undefined') {
window.srv = window.srv || srv;
window.mopinionSurvey = window.mopinionSurvey || srv;
}
var _default = exports["default"] = srv;
//# sourceMappingURL=index.js.map