UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

189 lines (186 loc) 33.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _imagePreview = _interopRequireDefault(require("../common/image-preview")); var _constants = require("@kepler.gl/constants"); var _styledComponents2 = require("../common/styled-components"); var _switch = _interopRequireDefault(require("../common/switch")); var _reactIntl = require("react-intl"); var _localization = require("@kepler.gl/localization"); var _templateObject; // 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; } var ImageOptionList = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n gap: 16px;\n width: 250px;\n\n .image-option-section {\n .image-option-section-title {\n font-weight: 500;\n font-size: 14px;\n }\n }\n\n .button-list {\n display: flex;\n flex-direction: row;\n padding: 8px 0px;\n flex-wrap: wrap;\n gap: 4px;\n }\n\n .resolution-dropdown {\n padding: 0px;\n margin-top: 8px;\n margin-bottom: 8px;\n\n select {\n width: 100%;\n padding: 6px 12px;\n border: 1px solid #d3d3d3;\n border-radius: 2px;\n font-size: 14px;\n cursor: pointer;\n background-color: white;\n font-family: inherit;\n appearance: none;\n height: 32px;\n\n &:hover {\n border-color: #999;\n background-color: #f9f9f9;\n }\n\n &:focus {\n outline: none;\n border-color: #0066cc;\n box-shadow: 0 0 0 3px rgba(0, 102, 204, 0.1);\n }\n\n &:disabled {\n background-color: #f5f5f5;\n color: #999;\n cursor: not-allowed;\n }\n }\n }\n\n input {\n margin-right: 8px;\n }\n"]))); // Define resolution options for each ratio as constants var SCREEN_RESOLUTION_OPTIONS = [_constants.OneXResolutionOption, _constants.TwoXResolutionOption]; var FOUR_BY_THREE_RESOLUTION_OPTIONS = [_constants.Resolution1024x768Option, _constants.Resolution1280x960Option, _constants.Resolution1600x1200Option, _constants.Resolution1920x1440Option]; var SIXTEEN_BY_NINE_RESOLUTION_OPTIONS = [_constants.Resolution1280x720Option, _constants.Resolution1600x900Option, _constants.Resolution1920x1080Option, _constants.Resolution2560x1440Option]; var ExportImageModalFactory = function ExportImageModalFactory() { var ExportImageModal = function ExportImageModal(_ref) { var mapW = _ref.mapW, mapH = _ref.mapH, exportImage = _ref.exportImage, onUpdateImageSetting = _ref.onUpdateImageSetting, cleanupExportImage = _ref.cleanupExportImage, intl = _ref.intl; var legend = exportImage.legend, ratio = exportImage.ratio, resolution = exportImage.resolution; // Filter resolutions based on selected ratio var filteredResolutions = (0, _react.useMemo)(function () { if (ratio === _constants.EXPORT_IMG_RATIOS.SCREEN) { return SCREEN_RESOLUTION_OPTIONS; } else if (ratio === _constants.EXPORT_IMG_RATIOS.FOUR_BY_THREE) { return FOUR_BY_THREE_RESOLUTION_OPTIONS; } else if (ratio === _constants.EXPORT_IMG_RATIOS.SIXTEEN_BY_NINE) { return SIXTEEN_BY_NINE_RESOLUTION_OPTIONS; } // For CUSTOM, don't show resolution options return []; }, [ratio]); (0, _react.useEffect)(function () { onUpdateImageSetting({ exporting: true }); return cleanupExportImage; }, [onUpdateImageSetting, cleanupExportImage]); (0, _react.useEffect)(function () { if (mapH !== exportImage.mapH || mapW !== exportImage.mapW) { onUpdateImageSetting({ mapH: mapH, mapW: mapW }); } }, [mapH, mapW, exportImage, onUpdateImageSetting]); (0, _react.useEffect)(function () { // Keep resolution in sync with the selected ratio and available options. // If the current resolution is not available for this ratio, reset it to the first option. if (!filteredResolutions || !filteredResolutions.length) { return; } var isValidResolution = Boolean(resolution) && filteredResolutions.some(function (op) { return op.id === resolution; }); if (!isValidResolution) { onUpdateImageSetting({ resolution: filteredResolutions[0].id }); } }, [ratio, filteredResolutions, resolution, onUpdateImageSetting]); return /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledModalContent, { className: "export-image-modal" }, /*#__PURE__*/_react["default"].createElement(ImageOptionList, null, /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section" }, /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.ratioTitle' })), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.ratioDescription' }), /*#__PURE__*/_react["default"].createElement("div", { className: "button-list", id: "export-image-modal__option_ratio" }, _constants.EXPORT_IMG_RATIO_OPTIONS.filter(function (op) { return !op.hidden; }).map(function (op) { return /*#__PURE__*/_react["default"].createElement(_styledComponents2.SelectionButton, { key: op.id, selected: ratio === op.id, onClick: function onClick() { return onUpdateImageSetting({ ratio: op.id }); } }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: op.label }), ratio === op.id && /*#__PURE__*/_react["default"].createElement(_styledComponents2.CheckMark, null)); }))), ratio !== _constants.EXPORT_IMG_RATIOS.CUSTOM && /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section" }, /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section-title", id: "export-image-modal__resolution-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.resolutionTitle' })), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.resolutionDescription' }), ratio === _constants.EXPORT_IMG_RATIOS.SCREEN ? /*#__PURE__*/_react["default"].createElement("div", { className: "button-list", id: "export-image-modal__option_resolution" }, filteredResolutions.map(function (op) { return /*#__PURE__*/_react["default"].createElement(_styledComponents2.SelectionButton, { key: op.id, selected: resolution === op.id, onClick: function onClick() { return op.available && onUpdateImageSetting({ resolution: op.id }); } }, op.label, resolution === op.id && /*#__PURE__*/_react["default"].createElement(_styledComponents2.CheckMark, null)); })) : /*#__PURE__*/_react["default"].createElement("div", { className: "resolution-dropdown", id: "export-image-modal__option_resolution" }, /*#__PURE__*/_react["default"].createElement("select", { value: resolution || '', "aria-labelledby": "export-image-modal__resolution-title", onChange: function onChange(e) { var value = e.target.value; // Only update if a valid resolution is selected if (value && filteredResolutions.some(function (op) { return op.id === value; })) { // Type-safe: we've verified the value exists in filteredResolutions onUpdateImageSetting({ resolution: value }); } // If empty string selected, optionally reset to first available resolution else if (!value && filteredResolutions.length > 0) { onUpdateImageSetting({ resolution: filteredResolutions[0].id }); } } }, /*#__PURE__*/_react["default"].createElement("option", { value: "" }, intl.formatMessage({ id: 'modal.exportImage.resolutionPlaceholder' })), filteredResolutions.map(function (op) { return /*#__PURE__*/_react["default"].createElement("option", { key: op.id, value: op.id, disabled: !op.available }, op.label); })))), /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section" }, /*#__PURE__*/_react["default"].createElement("div", { className: "image-option-section-title" }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: 'modal.exportImage.mapLegendTitle' })), /*#__PURE__*/_react["default"].createElement(_switch["default"], { type: "checkbox", id: "add-map-legend", checked: legend, label: intl.formatMessage({ id: 'modal.exportImage.mapLegendAdd' }), onChange: function onChange() { return onUpdateImageSetting({ legend: !legend }); } }))), /*#__PURE__*/_react["default"].createElement(_imagePreview["default"], { exportImage: exportImage })); }; return (0, _reactIntl.injectIntl)(ExportImageModal); }; var _default = exports["default"] = ExportImageModalFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_imagePreview","_constants","_styledComponents2","_switch","_reactIntl","_localization","_templateObject","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ImageOptionList","styled","div","_taggedTemplateLiteral2","SCREEN_RESOLUTION_OPTIONS","OneXResolutionOption","TwoXResolutionOption","FOUR_BY_THREE_RESOLUTION_OPTIONS","Resolution1024x768Option","Resolution1280x960Option","Resolution1600x1200Option","Resolution1920x1440Option","SIXTEEN_BY_NINE_RESOLUTION_OPTIONS","Resolution1280x720Option","Resolution1600x900Option","Resolution1920x1080Option","Resolution2560x1440Option","ExportImageModalFactory","ExportImageModal","_ref","mapW","mapH","exportImage","onUpdateImageSetting","cleanupExportImage","intl","legend","ratio","resolution","filteredResolutions","useMemo","EXPORT_IMG_RATIOS","SCREEN","FOUR_BY_THREE","SIXTEEN_BY_NINE","useEffect","exporting","length","isValidResolution","Boolean","some","op","id","createElement","StyledModalContent","className","FormattedMessage","EXPORT_IMG_RATIO_OPTIONS","filter","hidden","map","SelectionButton","key","selected","onClick","label","CheckMark","CUSTOM","available","value","onChange","target","formatMessage","disabled","type","checked","injectIntl","_default","exports"],"sources":["../../src/modals/export-image-modal.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useEffect, useMemo} from 'react';\nimport styled from 'styled-components';\nimport ImagePreview from '../common/image-preview';\nimport {SetExportImageSettingUpdaterAction} from '@kepler.gl/actions';\n\nimport {\n  EXPORT_IMG_RATIO_OPTIONS,\n  EXPORT_IMG_RATIOS,\n  OneXResolutionOption,\n  TwoXResolutionOption,\n  Resolution1024x768Option,\n  Resolution1280x960Option,\n  Resolution1600x1200Option,\n  Resolution1920x1440Option,\n  Resolution1280x720Option,\n  Resolution1600x900Option,\n  Resolution1920x1080Option,\n  Resolution2560x1440Option\n} from '@kepler.gl/constants';\nimport type {ExportResolutionOption} from '@kepler.gl/constants';\nimport type {ExportImage} from '@kepler.gl/types';\nimport {StyledModalContent, SelectionButton, CheckMark} from '../common/styled-components';\nimport Switch from '../common/switch';\nimport {injectIntl, IntlShape} from 'react-intl';\nimport {FormattedMessage} from '@kepler.gl/localization';\n\nconst ImageOptionList = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: 16px;\n  width: 250px;\n\n  .image-option-section {\n    .image-option-section-title {\n      font-weight: 500;\n      font-size: 14px;\n    }\n  }\n\n  .button-list {\n    display: flex;\n    flex-direction: row;\n    padding: 8px 0px;\n    flex-wrap: wrap;\n    gap: 4px;\n  }\n\n  .resolution-dropdown {\n    padding: 0px;\n    margin-top: 8px;\n    margin-bottom: 8px;\n\n    select {\n      width: 100%;\n      padding: 6px 12px;\n      border: 1px solid #d3d3d3;\n      border-radius: 2px;\n      font-size: 14px;\n      cursor: pointer;\n      background-color: white;\n      font-family: inherit;\n      appearance: none;\n      height: 32px;\n\n      &:hover {\n        border-color: #999;\n        background-color: #f9f9f9;\n      }\n\n      &:focus {\n        outline: none;\n        border-color: #0066cc;\n        box-shadow: 0 0 0 3px rgba(0, 102, 204, 0.1);\n      }\n\n      &:disabled {\n        background-color: #f5f5f5;\n        color: #999;\n        cursor: not-allowed;\n      }\n    }\n  }\n\n  input {\n    margin-right: 8px;\n  }\n`;\n\n// Define resolution options for each ratio as constants\nconst SCREEN_RESOLUTION_OPTIONS = [OneXResolutionOption, TwoXResolutionOption];\n\nconst FOUR_BY_THREE_RESOLUTION_OPTIONS = [\n  Resolution1024x768Option,\n  Resolution1280x960Option,\n  Resolution1600x1200Option,\n  Resolution1920x1440Option\n];\n\nconst SIXTEEN_BY_NINE_RESOLUTION_OPTIONS = [\n  Resolution1280x720Option,\n  Resolution1600x900Option,\n  Resolution1920x1080Option,\n  Resolution2560x1440Option\n];\n\nexport interface ExportImageModalProps {\n  exportImage: ExportImage;\n  mapW: number;\n  mapH: number;\n  onUpdateImageSetting: (payload: SetExportImageSettingUpdaterAction['payload']) => void;\n  cleanupExportImage: () => void;\n  intl: IntlShape;\n}\n\nconst ExportImageModalFactory = () => {\n  const ExportImageModal: React.FC<ExportImageModalProps> = ({\n    mapW,\n    mapH,\n    exportImage,\n    onUpdateImageSetting,\n    cleanupExportImage,\n    intl\n  }) => {\n    const {legend, ratio, resolution} = exportImage;\n\n    // Filter resolutions based on selected ratio\n    const filteredResolutions = useMemo(() => {\n      if (ratio === EXPORT_IMG_RATIOS.SCREEN) {\n        return SCREEN_RESOLUTION_OPTIONS;\n      } else if (ratio === EXPORT_IMG_RATIOS.FOUR_BY_THREE) {\n        return FOUR_BY_THREE_RESOLUTION_OPTIONS;\n      } else if (ratio === EXPORT_IMG_RATIOS.SIXTEEN_BY_NINE) {\n        return SIXTEEN_BY_NINE_RESOLUTION_OPTIONS;\n      }\n      // For CUSTOM, don't show resolution options\n      return [];\n    }, [ratio]);\n\n    useEffect(() => {\n      onUpdateImageSetting({\n        exporting: true\n      });\n      return cleanupExportImage;\n    }, [onUpdateImageSetting, cleanupExportImage]);\n\n    useEffect(() => {\n      if (mapH !== exportImage.mapH || mapW !== exportImage.mapW) {\n        onUpdateImageSetting({\n          mapH,\n          mapW\n        });\n      }\n    }, [mapH, mapW, exportImage, onUpdateImageSetting]);\n\n    useEffect(() => {\n      // Keep resolution in sync with the selected ratio and available options.\n      // If the current resolution is not available for this ratio, reset it to the first option.\n      if (!filteredResolutions || !filteredResolutions.length) {\n        return;\n      }\n\n      const isValidResolution =\n        Boolean(resolution) && filteredResolutions.some(op => op.id === resolution);\n\n      if (!isValidResolution) {\n        onUpdateImageSetting({resolution: filteredResolutions[0].id});\n      }\n    }, [ratio, filteredResolutions, resolution, onUpdateImageSetting]);\n\n    return (\n      <StyledModalContent className=\"export-image-modal\">\n        <ImageOptionList>\n          <div className=\"image-option-section\">\n            <div className=\"image-option-section-title\">\n              <FormattedMessage id={'modal.exportImage.ratioTitle'} />\n            </div>\n            <FormattedMessage id={'modal.exportImage.ratioDescription'} />\n            <div className=\"button-list\" id=\"export-image-modal__option_ratio\">\n              {EXPORT_IMG_RATIO_OPTIONS.filter(op => !op.hidden).map(op => (\n                <SelectionButton\n                  key={op.id}\n                  selected={ratio === op.id}\n                  onClick={() => onUpdateImageSetting({ratio: op.id})}\n                >\n                  <FormattedMessage id={op.label} />\n                  {ratio === op.id && <CheckMark />}\n                </SelectionButton>\n              ))}\n            </div>\n          </div>\n          {ratio !== EXPORT_IMG_RATIOS.CUSTOM && (\n            <div className=\"image-option-section\">\n              <div className=\"image-option-section-title\" id=\"export-image-modal__resolution-title\">\n                <FormattedMessage id={'modal.exportImage.resolutionTitle'} />\n              </div>\n              <FormattedMessage id={'modal.exportImage.resolutionDescription'} />\n              {ratio === EXPORT_IMG_RATIOS.SCREEN ? (\n                <div className=\"button-list\" id=\"export-image-modal__option_resolution\">\n                  {filteredResolutions.map(op => (\n                    <SelectionButton\n                      key={op.id}\n                      selected={resolution === op.id}\n                      onClick={() => op.available && onUpdateImageSetting({resolution: op.id})}\n                    >\n                      {op.label}\n                      {resolution === op.id && <CheckMark />}\n                    </SelectionButton>\n                  ))}\n                </div>\n              ) : (\n                <div className=\"resolution-dropdown\" id=\"export-image-modal__option_resolution\">\n                  <select\n                    value={resolution || ''}\n                    aria-labelledby=\"export-image-modal__resolution-title\"\n                    onChange={e => {\n                      const value = e.target.value;\n                      // Only update if a valid resolution is selected\n                      if (value && filteredResolutions.some(op => op.id === value)) {\n                        // Type-safe: we've verified the value exists in filteredResolutions\n                        onUpdateImageSetting({resolution: value as ExportResolutionOption});\n                      }\n                      // If empty string selected, optionally reset to first available resolution\n                      else if (!value && filteredResolutions.length > 0) {\n                        onUpdateImageSetting({resolution: filteredResolutions[0].id});\n                      }\n                    }}\n                  >\n                    <option value=\"\">\n                      {intl.formatMessage({id: 'modal.exportImage.resolutionPlaceholder'})}\n                    </option>\n                    {filteredResolutions.map(op => (\n                      <option key={op.id} value={op.id} disabled={!op.available}>\n                        {op.label}\n                      </option>\n                    ))}\n                  </select>\n                </div>\n              )}\n            </div>\n          )}\n          <div className=\"image-option-section\">\n            <div className=\"image-option-section-title\">\n              <FormattedMessage id={'modal.exportImage.mapLegendTitle'} />\n            </div>\n            <Switch\n              type=\"checkbox\"\n              id=\"add-map-legend\"\n              checked={legend}\n              label={intl.formatMessage({id: 'modal.exportImage.mapLegendAdd'})}\n              onChange={() => onUpdateImageSetting({legend: !legend})}\n            />\n          </div>\n        </ImageOptionList>\n        <ImagePreview exportImage={exportImage} />\n      </StyledModalContent>\n    );\n  };\n\n  return injectIntl(ExportImageModal);\n};\n\nexport default ExportImageModalFactory;\n"],"mappings":"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","ignoreList":[]}