botframework-webchat-component
Version:
React component of botframework-webchat
159 lines (152 loc) • 20.3 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = createBubbleStyle;
var _mirrorStyle = _interopRequireDefault(require("../mirrorStyle"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function createBubbleStyle(_ref) {
var bubbleBackground = _ref.bubbleBackground,
bubbleBorderColor = _ref.bubbleBorderColor,
bubbleBorderRadius = _ref.bubbleBorderRadius,
bubbleBorderStyle = _ref.bubbleBorderStyle,
bubbleBorderWidth = _ref.bubbleBorderWidth,
bubbleFromUserBackground = _ref.bubbleFromUserBackground,
bubbleFromUserBorderColor = _ref.bubbleFromUserBorderColor,
bubbleFromUserBorderRadius = _ref.bubbleFromUserBorderRadius,
bubbleFromUserBorderStyle = _ref.bubbleFromUserBorderStyle,
bubbleFromUserBorderWidth = _ref.bubbleFromUserBorderWidth,
bubbleFromUserNubOffset = _ref.bubbleFromUserNubOffset,
bubbleFromUserNubSize = _ref.bubbleFromUserNubSize,
bubbleFromUserTextColor = _ref.bubbleFromUserTextColor,
bubbleMinHeight = _ref.bubbleMinHeight,
bubbleNubOffset = _ref.bubbleNubOffset,
bubbleNubSize = _ref.bubbleNubSize,
bubbleTextColor = _ref.bubbleTextColor,
messageActivityWordBreak = _ref.messageActivityWordBreak,
paddingRegular = _ref.paddingRegular,
transitionDuration = _ref.transitionDuration;
var botNubCornerRadius = Math.min(bubbleBorderRadius, Math.abs(bubbleNubOffset));
var userNubCornerRadius = Math.min(bubbleFromUserBorderRadius, Math.abs(bubbleFromUserNubOffset));
return {
'&.webchat__bubble': _objectSpread({
'& .webchat__bubble__content': {
marginLeft: 0,
marginRight: 0,
transitionDuration: transitionDuration,
transitionProperty: 'margin-left, margin-right',
wordBreak: messageActivityWordBreak
},
'& .webchat__bubble__nub': {
overflow: 'hidden',
// This style is for IE11 because it doesn't respect SVG viewport
position: 'absolute'
},
'& .webchat__bubble__nub-pad': {
transitionDuration: transitionDuration,
transitionProperty: 'width',
width: 0
},
'&.webchat__bubble--hide-nub, &.webchat__bubble--show-nub': {
'& .webchat__bubble__nub-pad': {
width: paddingRegular
}
},
'&.webchat__bubble--rtl .webchat__bubble__nub': {
transform: 'scale(-1, 1)'
},
'&:not(.webchat__bubble--from-user)': _objectSpread(_objectSpread({
'& .webchat__bubble__content': {
background: bubbleBackground,
borderColor: bubbleBorderColor,
borderRadius: bubbleBorderRadius,
borderStyle: bubbleBorderStyle,
borderWidth: bubbleBorderWidth,
color: bubbleTextColor,
minHeight: bubbleMinHeight - bubbleBorderWidth * 2
}
}, typeof bubbleNubSize === 'number' ? {
'& .webchat__bubble__nub': {
height: bubbleNubSize,
width: bubbleNubSize
}
} : {}), {}, {
'&:not(.webchat__bubble--nub-on-top) .webchat__bubble__nub': {
bottom: -bubbleNubOffset
},
'&.webchat__bubble--nub-on-top .webchat__bubble__nub': {
top: bubbleNubOffset
},
'& .webchat__bubble__nub-outline': {
fill: bubbleBackground,
stroke: bubbleBorderColor,
strokeWidth: bubbleBorderWidth
}
}),
'&.webchat__bubble--from-user': _objectSpread(_objectSpread({
flexDirection: 'row-reverse',
'& .webchat__bubble__content': {
background: bubbleFromUserBackground,
borderColor: bubbleFromUserBorderColor,
borderRadius: bubbleFromUserBorderRadius,
borderStyle: bubbleFromUserBorderStyle,
borderWidth: bubbleFromUserBorderWidth,
color: bubbleFromUserTextColor,
minHeight: bubbleMinHeight - bubbleFromUserBorderWidth * 2
}
}, typeof bubbleFromUserNubSize === 'number' ? {
'& .webchat__bubble__nub': {
height: bubbleFromUserNubSize,
width: bubbleFromUserNubSize
}
} : {}), {}, {
'&:not(.webchat__bubble--nub-on-top) .webchat__bubble__nub': {
bottom: -bubbleFromUserNubOffset
},
'&.webchat__bubble--nub-on-top .webchat__bubble__nub': {
top: bubbleFromUserNubOffset
},
'& .webchat__bubble__nub-outline': {
fill: bubbleFromUserBackground,
stroke: bubbleFromUserBorderColor,
strokeWidth: bubbleFromUserBorderWidth
}
})
}, (0, _mirrorStyle.default)('&.webchat__bubble--rtl', {
'&:not(.webchat__bubble--from-user)': _objectSpread({
'&.webchat__bubble--show-nub': {
// Hide border radius if there is a nub on the top/bottom left corner
'&:not(.webchat__bubble--nub-on-top) .webchat__bubble__content': {
borderBottomLeftRadius: botNubCornerRadius
},
'&.webchat__bubble--nub-on-top .webchat__bubble__content': {
borderTopLeftRadius: botNubCornerRadius
}
}
}, typeof bubbleNubSize === 'number' ? {
'& .webchat__bubble__nub': {
left: bubbleBorderWidth - bubbleNubSize + paddingRegular
}
} : {}),
'&.webchat__bubble--from-user': _objectSpread({
'&.webchat__bubble--show-nub': {
// Hide border radius if there is a nub on the top/bottom right corner
'&:not(.webchat__bubble--nub-on-top) .webchat__bubble__content': {
borderBottomRightRadius: userNubCornerRadius
},
'&.webchat__bubble--nub-on-top .webchat__bubble__content': {
borderTopRightRadius: userNubCornerRadius
}
}
}, typeof bubbleFromUserNubSize === 'number' ? {
'& .webchat__bubble__nub': {
right: bubbleFromUserBorderWidth - bubbleFromUserNubSize + paddingRegular
}
} : {})
}))
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Styles/StyleSet/Bubble.js"],"names":["createBubbleStyle","bubbleBackground","bubbleBorderColor","bubbleBorderRadius","bubbleBorderStyle","bubbleBorderWidth","bubbleFromUserBackground","bubbleFromUserBorderColor","bubbleFromUserBorderRadius","bubbleFromUserBorderStyle","bubbleFromUserBorderWidth","bubbleFromUserNubOffset","bubbleFromUserNubSize","bubbleFromUserTextColor","bubbleMinHeight","bubbleNubOffset","bubbleNubSize","bubbleTextColor","messageActivityWordBreak","paddingRegular","transitionDuration","botNubCornerRadius","Math","min","abs","userNubCornerRadius","marginLeft","marginRight","transitionProperty","wordBreak","overflow","position","width","transform","background","borderColor","borderRadius","borderStyle","borderWidth","color","minHeight","height","bottom","top","fill","stroke","strokeWidth","flexDirection","borderBottomLeftRadius","borderTopLeftRadius","left","borderBottomRightRadius","borderTopRightRadius","right"],"mappings":";;;;;;;AAEA;;;;;;;;;;AAEe,SAASA,iBAAT,OAqBZ;AAAA,MApBDC,gBAoBC,QApBDA,gBAoBC;AAAA,MAnBDC,iBAmBC,QAnBDA,iBAmBC;AAAA,MAlBDC,kBAkBC,QAlBDA,kBAkBC;AAAA,MAjBDC,iBAiBC,QAjBDA,iBAiBC;AAAA,MAhBDC,iBAgBC,QAhBDA,iBAgBC;AAAA,MAfDC,wBAeC,QAfDA,wBAeC;AAAA,MAdDC,yBAcC,QAdDA,yBAcC;AAAA,MAbDC,0BAaC,QAbDA,0BAaC;AAAA,MAZDC,yBAYC,QAZDA,yBAYC;AAAA,MAXDC,yBAWC,QAXDA,yBAWC;AAAA,MAVDC,uBAUC,QAVDA,uBAUC;AAAA,MATDC,qBASC,QATDA,qBASC;AAAA,MARDC,uBAQC,QARDA,uBAQC;AAAA,MAPDC,eAOC,QAPDA,eAOC;AAAA,MANDC,eAMC,QANDA,eAMC;AAAA,MALDC,aAKC,QALDA,aAKC;AAAA,MAJDC,eAIC,QAJDA,eAIC;AAAA,MAHDC,wBAGC,QAHDA,wBAGC;AAAA,MAFDC,cAEC,QAFDA,cAEC;AAAA,MADDC,kBACC,QADDA,kBACC;AACD,MAAMC,kBAAkB,GAAGC,IAAI,CAACC,GAAL,CAASpB,kBAAT,EAA6BmB,IAAI,CAACE,GAAL,CAAST,eAAT,CAA7B,CAA3B;AACA,MAAMU,mBAAmB,GAAGH,IAAI,CAACC,GAAL,CAASf,0BAAT,EAAqCc,IAAI,CAACE,GAAL,CAASb,uBAAT,CAArC,CAA5B;AAEA,SAAO;AACL;AACE,qCAA+B;AAC7Be,QAAAA,UAAU,EAAE,CADiB;AAE7BC,QAAAA,WAAW,EAAE,CAFgB;AAG7BP,QAAAA,kBAAkB,EAAlBA,kBAH6B;AAI7BQ,QAAAA,kBAAkB,EAAE,2BAJS;AAK7BC,QAAAA,SAAS,EAAEX;AALkB,OADjC;AASE,iCAA2B;AACzBY,QAAAA,QAAQ,EAAE,QADe;AACL;AACpBC,QAAAA,QAAQ,EAAE;AAFe,OAT7B;AAcE,qCAA+B;AAC7BX,QAAAA,kBAAkB,EAAlBA,kBAD6B;AAE7BQ,QAAAA,kBAAkB,EAAE,OAFS;AAG7BI,QAAAA,KAAK,EAAE;AAHsB,OAdjC;AAoBE,kEAA4D;AAC1D,uCAA+B;AAC7BA,UAAAA,KAAK,EAAEb;AADsB;AAD2B,OApB9D;AA0BE,sDAAgD;AAC9Cc,QAAAA,SAAS,EAAE;AADmC,OA1BlD;AA8BE;AACE,uCAA+B;AAC7BC,UAAAA,UAAU,EAAEjC,gBADiB;AAE7BkC,UAAAA,WAAW,EAAEjC,iBAFgB;AAG7BkC,UAAAA,YAAY,EAAEjC,kBAHe;AAI7BkC,UAAAA,WAAW,EAAEjC,iBAJgB;AAK7BkC,UAAAA,WAAW,EAAEjC,iBALgB;AAM7BkC,UAAAA,KAAK,EAAEtB,eANsB;AAO7BuB,UAAAA,SAAS,EAAE1B,eAAe,GAAGT,iBAAiB,GAAG;AAPpB;AADjC,SAWM,OAAOW,aAAP,KAAyB,QAAzB,GACA;AACE,mCAA2B;AACzByB,UAAAA,MAAM,EAAEzB,aADiB;AAEzBgB,UAAAA,KAAK,EAAEhB;AAFkB;AAD7B,OADA,GAOA,EAlBN;AAoBE,qEAA6D;AAC3D0B,UAAAA,MAAM,EAAE,CAAC3B;AADkD,SApB/D;AAwBE,+DAAuD;AACrD4B,UAAAA,GAAG,EAAE5B;AADgD,SAxBzD;AA4BE,2CAAmC;AACjC6B,UAAAA,IAAI,EAAE3C,gBAD2B;AAEjC4C,UAAAA,MAAM,EAAE3C,iBAFyB;AAGjC4C,UAAAA,WAAW,EAAEzC;AAHoB;AA5BrC,QA9BF;AAiEE;AACE0C,QAAAA,aAAa,EAAE,aADjB;AAGE,uCAA+B;AAC7Bb,UAAAA,UAAU,EAAE5B,wBADiB;AAE7B6B,UAAAA,WAAW,EAAE5B,yBAFgB;AAG7B6B,UAAAA,YAAY,EAAE5B,0BAHe;AAI7B6B,UAAAA,WAAW,EAAE5B,yBAJgB;AAK7B6B,UAAAA,WAAW,EAAE5B,yBALgB;AAM7B6B,UAAAA,KAAK,EAAE1B,uBANsB;AAO7B2B,UAAAA,SAAS,EAAE1B,eAAe,GAAGJ,yBAAyB,GAAG;AAP5B;AAHjC,SAaM,OAAOE,qBAAP,KAAiC,QAAjC,GACA;AACE,mCAA2B;AACzB6B,UAAAA,MAAM,EAAE7B,qBADiB;AAEzBoB,UAAAA,KAAK,EAAEpB;AAFkB;AAD7B,OADA,GAOA,EApBN;AAsBE,qEAA6D;AAC3D8B,UAAAA,MAAM,EAAE,CAAC/B;AADkD,SAtB/D;AA0BE,+DAAuD;AACrDgC,UAAAA,GAAG,EAAEhC;AADgD,SA1BzD;AA8BE,2CAAmC;AACjCiC,UAAAA,IAAI,EAAEtC,wBAD2B;AAEjCuC,UAAAA,MAAM,EAAEtC,yBAFyB;AAGjCuC,UAAAA,WAAW,EAAEpC;AAHoB;AA9BrC;AAjEF,OAsGK,0BAAY,wBAAZ,EAAsC;AACvC;AACE,uCAA+B;AAC7B;AACA,2EAAiE;AAC/DsC,YAAAA,sBAAsB,EAAE3B;AADuC,WAFpC;AAM7B,qEAA2D;AACzD4B,YAAAA,mBAAmB,EAAE5B;AADoC;AAN9B;AADjC,SAYM,OAAOL,aAAP,KAAyB,QAAzB,GACA;AACE,mCAA2B;AAAEkC,UAAAA,IAAI,EAAE7C,iBAAiB,GAAGW,aAApB,GAAoCG;AAA5C;AAD7B,OADA,GAIA,EAhBN,CADuC;AAoBvC;AACE,uCAA+B;AAC7B;AACA,2EAAiE;AAC/DgC,YAAAA,uBAAuB,EAAE1B;AADsC,WAFpC;AAM7B,qEAA2D;AACzD2B,YAAAA,oBAAoB,EAAE3B;AADmC;AAN9B;AADjC,SAYM,OAAOb,qBAAP,KAAiC,QAAjC,GACA;AACE,mCAA2B;AAAEyC,UAAAA,KAAK,EAAE3C,yBAAyB,GAAGE,qBAA5B,GAAoDO;AAA7D;AAD7B,OADA,GAIA,EAhBN;AApBuC,KAAtC,CAtGL;AADK,GAAP;AAgJD","sourceRoot":"component:///","sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [0, 1, 2] }] */\n\nimport mirrorStyle from '../mirrorStyle';\n\nexport default function createBubbleStyle({\n  bubbleBackground,\n  bubbleBorderColor,\n  bubbleBorderRadius,\n  bubbleBorderStyle,\n  bubbleBorderWidth,\n  bubbleFromUserBackground,\n  bubbleFromUserBorderColor,\n  bubbleFromUserBorderRadius,\n  bubbleFromUserBorderStyle,\n  bubbleFromUserBorderWidth,\n  bubbleFromUserNubOffset,\n  bubbleFromUserNubSize,\n  bubbleFromUserTextColor,\n  bubbleMinHeight,\n  bubbleNubOffset,\n  bubbleNubSize,\n  bubbleTextColor,\n  messageActivityWordBreak,\n  paddingRegular,\n  transitionDuration\n}) {\n  const botNubCornerRadius = Math.min(bubbleBorderRadius, Math.abs(bubbleNubOffset));\n  const userNubCornerRadius = Math.min(bubbleFromUserBorderRadius, Math.abs(bubbleFromUserNubOffset));\n\n  return {\n    '&.webchat__bubble': {\n      '& .webchat__bubble__content': {\n        marginLeft: 0,\n        marginRight: 0,\n        transitionDuration,\n        transitionProperty: 'margin-left, margin-right',\n        wordBreak: messageActivityWordBreak\n      },\n\n      '& .webchat__bubble__nub': {\n        overflow: 'hidden', // This style is for IE11 because it doesn't respect SVG viewport\n        position: 'absolute'\n      },\n\n      '& .webchat__bubble__nub-pad': {\n        transitionDuration,\n        transitionProperty: 'width',\n        width: 0\n      },\n\n      '&.webchat__bubble--hide-nub, &.webchat__bubble--show-nub': {\n        '& .webchat__bubble__nub-pad': {\n          width: paddingRegular\n        }\n      },\n\n      '&.webchat__bubble--rtl .webchat__bubble__nub': {\n        transform: 'scale(-1, 1)'\n      },\n\n      '&:not(.webchat__bubble--from-user)': {\n        '& .webchat__bubble__content': {\n          background: bubbleBackground,\n          borderColor: bubbleBorderColor,\n          borderRadius: bubbleBorderRadius,\n          borderStyle: bubbleBorderStyle,\n          borderWidth: bubbleBorderWidth,\n          color: bubbleTextColor,\n          minHeight: bubbleMinHeight - bubbleBorderWidth * 2\n        },\n\n        ...(typeof bubbleNubSize === 'number'\n          ? {\n              '& .webchat__bubble__nub': {\n                height: bubbleNubSize,\n                width: bubbleNubSize\n              }\n            }\n          : {}),\n\n        '&:not(.webchat__bubble--nub-on-top) .webchat__bubble__nub': {\n          bottom: -bubbleNubOffset\n        },\n\n        '&.webchat__bubble--nub-on-top .webchat__bubble__nub': {\n          top: bubbleNubOffset\n        },\n\n        '& .webchat__bubble__nub-outline': {\n          fill: bubbleBackground,\n          stroke: bubbleBorderColor,\n          strokeWidth: bubbleBorderWidth\n        }\n      },\n\n      '&.webchat__bubble--from-user': {\n        flexDirection: 'row-reverse',\n\n        '& .webchat__bubble__content': {\n          background: bubbleFromUserBackground,\n          borderColor: bubbleFromUserBorderColor,\n          borderRadius: bubbleFromUserBorderRadius,\n          borderStyle: bubbleFromUserBorderStyle,\n          borderWidth: bubbleFromUserBorderWidth,\n          color: bubbleFromUserTextColor,\n          minHeight: bubbleMinHeight - bubbleFromUserBorderWidth * 2\n        },\n\n        ...(typeof bubbleFromUserNubSize === 'number'\n          ? {\n              '& .webchat__bubble__nub': {\n                height: bubbleFromUserNubSize,\n                width: bubbleFromUserNubSize\n              }\n            }\n          : {}),\n\n        '&:not(.webchat__bubble--nub-on-top) .webchat__bubble__nub': {\n          bottom: -bubbleFromUserNubOffset\n        },\n\n        '&.webchat__bubble--nub-on-top .webchat__bubble__nub': {\n          top: bubbleFromUserNubOffset\n        },\n\n        '& .webchat__bubble__nub-outline': {\n          fill: bubbleFromUserBackground,\n          stroke: bubbleFromUserBorderColor,\n          strokeWidth: bubbleFromUserBorderWidth\n        }\n      },\n\n      ...mirrorStyle('&.webchat__bubble--rtl', {\n        '&:not(.webchat__bubble--from-user)': {\n          '&.webchat__bubble--show-nub': {\n            // Hide border radius if there is a nub on the top/bottom left corner\n            '&:not(.webchat__bubble--nub-on-top) .webchat__bubble__content': {\n              borderBottomLeftRadius: botNubCornerRadius\n            },\n\n            '&.webchat__bubble--nub-on-top .webchat__bubble__content': {\n              borderTopLeftRadius: botNubCornerRadius\n            }\n          },\n\n          ...(typeof bubbleNubSize === 'number'\n            ? {\n                '& .webchat__bubble__nub': { left: bubbleBorderWidth - bubbleNubSize + paddingRegular }\n              }\n            : {})\n        },\n\n        '&.webchat__bubble--from-user': {\n          '&.webchat__bubble--show-nub': {\n            // Hide border radius if there is a nub on the top/bottom right corner\n            '&:not(.webchat__bubble--nub-on-top) .webchat__bubble__content': {\n              borderBottomRightRadius: userNubCornerRadius\n            },\n\n            '&.webchat__bubble--nub-on-top .webchat__bubble__content': {\n              borderTopRightRadius: userNubCornerRadius\n            }\n          },\n\n          ...(typeof bubbleFromUserNubSize === 'number'\n            ? {\n                '& .webchat__bubble__nub': { right: bubbleFromUserBorderWidth - bubbleFromUserNubSize + paddingRegular }\n              }\n            : {})\n        }\n      })\n    }\n  };\n}\n"]}
;