kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
78 lines (76 loc) • 19.7 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.AiAssistantPanel = AiAssistantPanel;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactRedux = require("react-redux");
var _reactIntl = require("react-intl");
var _utils = require("@kepler.gl/utils");
var _localization = require("@kepler.gl/localization");
var _components = require("@kepler.gl/components");
var _actions = require("../actions");
var _aiAssistantConfig = require("./ai-assistant-config");
var _aiAssistantComponent = require("./ai-assistant-component");
var _localization2 = require("../localization");
var _templateObject, _templateObject2, _templateObject3, _templateObject4; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
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) { (0, _defineProperty2["default"])(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; }
var StyledAiAssistantPanelContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n pointer-events: none !important; /* prevent padding from blocking input */\n flex-grow: 1;\n justify-content: space-between;\n overflow: hidden;\n height: 100%;\n width: 100%;\n & > * {\n /* all children should allow input */\n pointer-events: all;\n }\n"])));
var StyledAiAssistantPanel = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n top: 0;\n background-color: ", ";\n display: flex;\n flex-direction: column;\n flex-grow: 1;\n overflow: hidden;\n"])), function (props) {
return props.theme.sidePanelBg;
});
var StyledAiAssistantPanelHeader = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 16px 16px 4px 16px;\n border-bottom: 1px solid ", ";\n color: ", ";\n"])), function (props) {
return props.theme.borderColor;
}, function (props) {
return props.theme.subtextColorActive;
});
var StyledAiAssistantPanelContent = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n color: ", ";\n padding: 10px 0px 10px 0px;\n overflow-y: auto;\n display: flex;\n flex-direction: column;\n height: 100%;\n"])), function (props) {
return props.theme.sidePanelScrollBar;
}, function (props) {
return props.theme.subtextColorActive;
});
var SidePanelTitle = (0, _components.SidePanelTitleFactory)();
function AiAssistantPanel() {
var dispatch = (0, _reactRedux.useDispatch)();
var aiAssistant = (0, _reactRedux.useSelector)(function (state) {
return state.demo.aiAssistant;
});
var locale = (0, _reactRedux.useSelector)(function (state) {
return state.demo.keplerGl.map.uiState.locale;
});
var onConfigButtonClick = (0, _react.useCallback)(function () {
if (aiAssistant) {
// set aiAssistant.config.isReady to false so we can render the config component
dispatch((0, _actions.updateAiAssistantConfig)(_objectSpread(_objectSpread({}, aiAssistant.config), {}, {
isReady: false
})));
}
}, [aiAssistant, dispatch]);
// combine keplerGlMessages and messages
var combinedMessages = (0, _react.useMemo)(function () {
return Object.keys(_localization2.messages).reduce(function (acc, language) {
return _objectSpread(_objectSpread({}, acc), {}, (0, _defineProperty2["default"])({}, language, _objectSpread(_objectSpread({}, _localization2.messages[language] || {}), _localization.messages[language] || {})));
}, {});
}, []);
return /*#__PURE__*/_react["default"].createElement(_reactIntl.IntlProvider, {
locale: locale,
messages: (0, _utils.flattenMessages)(combinedMessages[locale])
}, /*#__PURE__*/_react["default"].createElement(StyledAiAssistantPanelContainer, {
className: "ai-assistant-manager"
}, /*#__PURE__*/_react["default"].createElement(StyledAiAssistantPanel, null, /*#__PURE__*/_react["default"].createElement(StyledAiAssistantPanelHeader, null, /*#__PURE__*/_react["default"].createElement(SidePanelTitle, {
className: "ai-assistant-manager-title",
title: "AI Assistant"
}, /*#__PURE__*/_react["default"].createElement(_components.Icons.Settings, {
onClick: onConfigButtonClick
}))), /*#__PURE__*/_react["default"].createElement(StyledAiAssistantPanelContent, null, !(aiAssistant !== null && aiAssistant !== void 0 && aiAssistant.config.isReady) ? /*#__PURE__*/_react["default"].createElement(_aiAssistantConfig.AiAssistantConfig, null) : /*#__PURE__*/_react["default"].createElement(_aiAssistantComponent.AiAssistantComponent, null)))));
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_reactRedux","_reactIntl","_utils","_localization","_components","_actions","_aiAssistantConfig","_aiAssistantComponent","_localization2","_templateObject","_templateObject2","_templateObject3","_templateObject4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","StyledAiAssistantPanelContainer","styled","div","_taggedTemplateLiteral2","StyledAiAssistantPanel","props","theme","sidePanelBg","StyledAiAssistantPanelHeader","borderColor","subtextColorActive","StyledAiAssistantPanelContent","sidePanelScrollBar","SidePanelTitle","SidePanelTitleFactory","AiAssistantPanel","dispatch","useDispatch","aiAssistant","useSelector","state","demo","locale","keplerGl","map","uiState","onConfigButtonClick","useCallback","updateAiAssistantConfig","config","isReady","combinedMessages","useMemo","messages","reduce","acc","language","keplerGlMessages","createElement","IntlProvider","flattenMessages","className","title","Icons","Settings","onClick","AiAssistantConfig","AiAssistantComponent"],"sources":["../../src/components/ai-assistant-manager.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport styled from 'styled-components';\nimport {useSelector, useDispatch} from 'react-redux';\nimport {IntlProvider} from 'react-intl';\nimport {flattenMessages} from '@kepler.gl/utils';\nimport {messages as keplerGlMessages} from '@kepler.gl/localization';\n\nimport {MapStyle} from '@kepler.gl/reducers';\nimport {SidePanelTitleFactory, Icons} from '@kepler.gl/components';\nimport {VisState} from '@kepler.gl/schemas';\n\nimport {AiAssistantState} from '../index';\nimport {updateAiAssistantConfig} from '../actions';\nimport {AiAssistantConfig} from './ai-assistant-config';\nimport {AiAssistantComponent} from './ai-assistant-component';\nimport {messages} from '../localization';\n\nconst StyledAiAssistantPanelContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  pointer-events: none !important; /* prevent padding from blocking input */\n  flex-grow: 1;\n  justify-content: space-between;\n  overflow: hidden;\n  height: 100%;\n  width: 100%;\n  & > * {\n    /* all children should allow input */\n    pointer-events: all;\n  }\n`;\n\nconst StyledAiAssistantPanel = styled.div`\n  top: 0;\n  background-color: ${props => props.theme.sidePanelBg};\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n  overflow: hidden;\n`;\n\nconst StyledAiAssistantPanelHeader = styled.div`\n  padding: 16px 16px 4px 16px;\n  border-bottom: 1px solid ${props => props.theme.borderColor};\n  color: ${props => props.theme.subtextColorActive};\n`;\n\nconst StyledAiAssistantPanelContent = styled.div`\n  ${props => props.theme.sidePanelScrollBar};\n  color: ${props => props.theme.subtextColorActive};\n  padding: 10px 0px 10px 0px;\n  overflow-y: auto;\n  display: flex;\n  flex-direction: column;\n  height: 100%;\n`;\n\nconst SidePanelTitle = SidePanelTitleFactory();\n\nexport type State = {\n  demo: {\n    keplerGl: {\n      map: {\n        uiState: {locale: string};\n        visState: VisState;\n        mapStyle: MapStyle;\n      };\n    };\n    aiAssistant: AiAssistantState;\n  };\n};\n\nexport function AiAssistantPanel() {\n  const dispatch = useDispatch();\n  const aiAssistant = useSelector((state: State) => state.demo.aiAssistant);\n  const locale = useSelector((state: State) => state.demo.keplerGl.map.uiState.locale);\n\n  const onConfigButtonClick = useCallback(() => {\n    if (aiAssistant) {\n      // set aiAssistant.config.isReady to false so we can render the config component\n      dispatch(updateAiAssistantConfig({...aiAssistant.config, isReady: false}));\n    }\n  }, [aiAssistant, dispatch]);\n\n  // combine keplerGlMessages and messages\n  const combinedMessages = useMemo(() => {\n    return Object.keys(messages).reduce(\n      (acc, language) => ({\n        ...acc,\n        [language]: {\n          ...(messages[language] || {}),\n          ...(keplerGlMessages[language] || {})\n        }\n      }),\n      {}\n    );\n  }, []);\n\n  return (\n    <IntlProvider locale={locale} messages={flattenMessages(combinedMessages[locale])}>\n      <StyledAiAssistantPanelContainer className=\"ai-assistant-manager\">\n        <StyledAiAssistantPanel>\n          <StyledAiAssistantPanelHeader>\n            <SidePanelTitle className=\"ai-assistant-manager-title\" title=\"AI Assistant\">\n              <Icons.Settings onClick={onConfigButtonClick} />\n            </SidePanelTitle>\n          </StyledAiAssistantPanelHeader>\n\n          <StyledAiAssistantPanelContent>\n            {!aiAssistant?.config.isReady ? <AiAssistantConfig /> : <AiAssistantComponent />}\n          </StyledAiAssistantPanelContent>\n        </StyledAiAssistantPanel>\n      </StyledAiAssistantPanelContainer>\n    </IntlProvider>\n  );\n}\n"],"mappings":"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","ignoreList":[]}
;