CustomPreviewWidgetsComponent.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. 'use strict';
  2. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  3. function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
  4. function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
  5. /**
  6. * Licensed Materials - Property of IBM
  7. * IBM Cognos Products: BI Cloud (C) Copyright IBM Corp. 2019
  8. * US Government Users Restricted Rights - Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
  9. */
  10. define(['react', 'ca-ui-toolkit', 'prop-types', './PreviewVisualItem', '../../../widgets/livewidget/nls/StringResources'], function (React, UI_Toolkit, PropTypes, PreviewVisualItem, StringResources) {
  11. var Component = React.Component;
  12. var FlexLayout = UI_Toolkit.FlexLayout,
  13. FlexItem = UI_Toolkit.FlexItem,
  14. VSpacer = UI_Toolkit.VSpacer,
  15. HSpacer = UI_Toolkit.HSpacer,
  16. Label = UI_Toolkit.Label,
  17. Separator = UI_Toolkit.Separator;
  18. var CustomPreviewWidgetsComponent = function (_Component) {
  19. _inherits(CustomPreviewWidgetsComponent, _Component);
  20. function CustomPreviewWidgetsComponent() {
  21. _classCallCheck(this, CustomPreviewWidgetsComponent);
  22. return _possibleConstructorReturn(this, _Component.apply(this, arguments));
  23. }
  24. CustomPreviewWidgetsComponent.prototype.render = function render() {
  25. var _this2 = this;
  26. var previewItems = this.props.previewItems;
  27. var length = previewItems.length;
  28. var content = [];
  29. var visSeparator = React.createElement(
  30. FlexItem,
  31. null,
  32. React.createElement(HSpacer, { size: 1.5 })
  33. );
  34. previewItems.forEach(function (item, idx) {
  35. content.push(_this2._renderPreviewItem(item));
  36. if (idx < length - 1) {
  37. content.push(visSeparator);
  38. }
  39. });
  40. return React.createElement(
  41. FlexLayout,
  42. {
  43. fullHeight: true,
  44. direction: 'column',
  45. justifyContent: 'flex-start'
  46. },
  47. React.createElement(
  48. FlexItem,
  49. null,
  50. React.createElement(VSpacer, { size: 2 })
  51. ),
  52. React.createElement(
  53. FlexItem,
  54. null,
  55. React.createElement(Label, { className: 'vis-custom-preview-widget-label', label: StringResources.get('extVisCustomPreviewWidgets') })
  56. ),
  57. React.createElement(
  58. FlexItem,
  59. null,
  60. React.createElement(VSpacer, null)
  61. ),
  62. React.createElement(
  63. FlexItem,
  64. { height: '150px' },
  65. React.createElement(
  66. FlexLayout,
  67. {
  68. fullHeight: true,
  69. direction: 'row',
  70. justifyContent: 'flex-start'
  71. },
  72. content
  73. )
  74. ),
  75. React.createElement(
  76. FlexItem,
  77. null,
  78. React.createElement(Separator, { className: 'vis-custom-separator', hMargin: 0, orientation: 'horizontal' })
  79. ),
  80. React.createElement(
  81. FlexItem,
  82. null,
  83. React.createElement(VSpacer, { size: 2.5 })
  84. )
  85. );
  86. };
  87. CustomPreviewWidgetsComponent.prototype._renderPreviewItem = function _renderPreviewItem(item) {
  88. var _props = this.props,
  89. handlers = _props.handlers,
  90. dashboardApi = _props.dashboardApi;
  91. var iconsFeature = dashboardApi.getFeature('Icons');
  92. return React.createElement(
  93. FlexItem,
  94. {
  95. grow: 1,
  96. shrink: 1,
  97. className: 'vis-custom-preview-item'
  98. },
  99. React.createElement(
  100. FlexLayout,
  101. {
  102. fullHeight: true,
  103. direction: 'column',
  104. justifyContent: 'flex-start'
  105. },
  106. React.createElement(
  107. FlexItem,
  108. null,
  109. React.createElement(PreviewVisualItem, {
  110. item: item,
  111. handlers: handlers,
  112. iconsFeature: iconsFeature
  113. })
  114. ),
  115. React.createElement(
  116. FlexItem,
  117. null,
  118. React.createElement(VSpacer, { size: 3 })
  119. )
  120. )
  121. );
  122. };
  123. return CustomPreviewWidgetsComponent;
  124. }(Component);
  125. CustomPreviewWidgetsComponent.propTypes = {
  126. previewItems: PropTypes.array.isRequired,
  127. dashboardApi: PropTypes.object.isRequired,
  128. handlers: PropTypes.shape({
  129. componentDidMountCallback: PropTypes.func.isRequired,
  130. componentWillUnmountCallback: PropTypes.func.isRequired,
  131. isSDKActive: PropTypes.func.isRequired
  132. }).isRequired
  133. };
  134. return CustomPreviewWidgetsComponent;
  135. });
  136. //# sourceMappingURL=CustomPreviewWidgetsComponent.js.map