UNPKG

node-red-contrib-chatbot

Version:

REDBot a Chat bot for a full featured chat bot for Telegram, Facebook Messenger and Slack. Almost no coding skills required

13 lines 45.6 kB
(self.webpackChunknode_red_contrib_chatbot=self.webpackChunknode_red_contrib_chatbot||[]).push([[460],{63460:(e,t,l)=>{"use strict";l.r(t);var r=l(67294),n=l(18985),a=l(78971),i=l(85631),o=l(16790);l(83751);const s=e=>"location"===e?"#5E8263":e?"#D36135":e?"#595D88":"#000000";l(54641);const c=()=>r.createElement(i.Z,{className:"map-marker",icon:"map-marker",size:"2x",style:{color:"red"}});var m=l(95990),u=l(73727),p=l(18499),d=l(87596),h=l(82122),g=l(69873),b=l(40660),y=l(45697),E=l.n(y),v=l(96486),w=l.n(v),f=l(94184),k=l.n(f);function x(e,t,l){return t in e?Object.defineProperty(e,t,{value:l,enumerable:!0,configurable:!0,writable:!0}):e[t]=l,e}class _ extends r.Component{render(){const{thumb:e,height:t,width:l,maxWidth:n,maxHeight:a}=this.props,i=t/l;let o=Math.floor(i*n);o>a&&(o=a);const s={backgroundImage:`url(${e})`,backgroundPosition:"center",width:`${n}px`,height:`${o}px`};return r.createElement("div",{style:s})}}x(_,"propTypes",{thumb:E().string,height:E().number,width:E().number,maxWidth:E().number,maxHeight:E().number,onClick:E().func}),x(_,"defaultProps",{thumb:null,height:null,width:null,maxWidth:200,maxHeight:400,onClick:()=>{}});const P=_;function C(){return C=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var l=arguments[t];for(var r in l)Object.prototype.hasOwnProperty.call(l,r)&&(e[r]=l[r])}return e},C.apply(this,arguments)}const S=({topic:e,ts:t,content:l,onDelete:n,onZoom:a,thumb:i,image:o,width:s,height:c,maxHeight:m,...u})=>{let p;return w().isEmpty(i)||(p=r.createElement(P,{thumb:i,topic:e,width:s,height:c,maxHeight:m,onClick:()=>{console.log("clicked"),a({})}})),r.createElement(g.Z,C({title:e},u,{onMouseLeave:()=>{}}),r.createElement("div",{className:"popover-map-marker"},"vario"))};function D(e,t,l){return t in e?Object.defineProperty(e,t,{value:l,enumerable:!0,configurable:!0,writable:!0}):e[t]=l,e}S.propTypes={topic:E().string,thumb:E().string,image:E().string,content:E().string,ts:E().instanceOf(Date),onDelete:E().func,width:E().number,height:E().number},S.defaultProps={topic:null,thumb:null,image:null,content:null,ts:null,onDelete:()=>{},width:null,height:null};class Z extends r.Component{constructor(e){super(e),this.handleLoaded=this.handleLoaded.bind(this),this.handleClick=this.handleClick.bind(this);const{thumb:t}=e;this.state={needPreload:!w().isEmpty(t),preload:!1,width:null,height:null}}componentDidMount(){const{type:e,color:t}=this.props;null!=this.tooltip&&"tooltip"===e&&(this.tooltip.querySelector(".rs-tooltip-inner").style.backgroundColor=t,this.tooltip.querySelector(".rs-tooltip-arrow").style.backgroundColor=t)}handleLoaded(e){this.setState({preload:!1,width:e.target.width,height:e.target.height},(()=>this.trigger.show()))}handleClick(e){e.preventDefault(),e.stopPropagation();const{thumb:t}=this.props;w().isEmpty(t)?this.trigger.show():this.setState({preload:!0})}render(){const{children:e,point:t,text:l,type:n,popover:a,showPopover:o,thumb:s,image:c,inkColor:m,maxHeight:u,onDeletePoint:p,onShowImage:d}=this.props;let{icon:y,color:E,size:v}=this.props;const{height:f,width:x,preload:_,needPreload:P}=this.state;let C;switch(w().isEmpty(y)&&(y="map-marker"),w().isEmpty(v)&&(v="lg"),w().isEmpty(E)&&(E="#FF3300"),w().isEmpty(m)&&(E="#000000"),new Date(parseInt(t.ts,10)),n){case"icon":C=r.createElement("a",{href:"#",className:k()("wrapper-map-marker",{preload:_}),onClick:this.handleClick},_&&r.createElement("img",{src:s,style:{display:"none"},onLoad:this.handleLoaded,alt:""}),r.createElement(i.Z,{className:k()("map-marker",{pointer:o}),icon:y,size:v,style:{color:E}}));break;case"tooltip":C=r.createElement("div",{ref:e=>this.tooltip=e,style:{height:20,backgroundColor:"#ff0000"}},r.createElement(h.Z,{visible:!0},r.createElement("span",{style:{color:m}},l)));break;default:C=null}if(o){if(P&&_)return C;const t=r.createElement(g.Z,{onMouseLeave:()=>{}},r.createElement("div",{className:"popover-map-marker"},e));return r.createElement(b.Z,{trigger:"click",placement:"top",speaker:t,triggerRef:e=>this.trigger=e},C)}return C}}D(Z,"propTypes",{point:E().shape({topic:E().string,text:E().string,ts:E().string}).isRequired,icon:E().string,size:E().string,color:E().string,text:E().string,popover:E().string,thumb:E().string,image:E().string,showPopover:E().bool,type:E().oneOf(["icon","tooltip"]),inkColor:E().string,maxHeight:E().number}),D(Z,"defaultProps",{icon:"map-marker",color:"#FF3300",text:null,size:"2x",popover:null,thumb:null,image:null,type:"icon",showPopover:!1,inkColor:"#ffffff",maxHeight:480});const N=Z,z=m.default` query($where: JSON) { records(limit: 50, order: "geohash", where: $where) { id, status, title, latitude, longitude, geohash, payload } }`;(0,n.plug)("sidebar",null,{id:"wiggle",label:"Panopticon",icon:"logo-survey",permission:"wiggle.view",options:[{id:"wiggle-secrets",label:"Secrets",url:"/secrets"},{id:"wiggle-secrets-map",label:"Secrets Map",url:"/secrets-map"}]}),(0,n.plug)("pages",(()=>{const[e,t]=(0,r.useState)(null),[l,n]=(0,r.useState)(!1),i=(0,p.xJ)();let o=(e||[]).filter((e=>null!=e.latitude&&null!=e.longitude)).map((e=>r.createElement(N,{key:e.id,lat:e.latitude,lng:e.longitude,point:{},popover:e.title,showPopover:!0},r.createElement("div",{style:{minHeight:"120px"}},r.createElement("strong",null,e.title),null!=e.payload.secret_url&&r.createElement("div",{style:{backgroundImage:`url(${e.payload.secret_url})`,backgroundPosition:"center",minWidth:"120px",backgroundRepeat:"no-repeat",backgroundSize:"contain",height:"120px"}}),null!=e.payload.secret&&r.createElement("div",null,e.payload.secret),r.createElement(u.rU,{to:`/record/${e.id}`},"view")))));return r.createElement(a._z,{className:"my-page"},r.createElement(a.Oo,{pages:["Secret locations"]}),r.createElement("div",{style:{width:"100%",height:"450px",position:"relative"}},l&&r.createElement("div",{style:{position:"absolute",top:"20px",left:"20px",zIndex:1e7}},r.createElement(d.Z,{size:"md"})),r.createElement(a.oe,{defaultCenter:{lat:45.4854739,lng:9.2022176},defaultZoom:11,height:450,onChange:async({bounds:e})=>{const{se:l,nw:r}=e;n(!0);const{data:{records:a}}=await i.query({query:z,variables:{where:{latitude:{gte:l.lat,lte:r.lat},longitude:{gte:r.lng,lte:l.lng}}},fetchPolicy:"network-only"});t(a),n(!1)}},o)))}),{url:"/secrets-map",title:"Secrets Map",id:"secrets-maps",permission:"wiggle.view",breadcrumbs:["Secrets Map"]}),(0,n.plug)("pages",a.Op,{url:"/secrets",title:"Secrets",id:"secrets",type:"secret",permission:"wiggle.view",breadcrumbs:["Secrets"],labels:{title:"Name",record:"secret"},columns:[{id:"secret-type",label:"Type",width:120,cell:({payload:e})=>r.createElement(a.vx,{color:s(e.secret_type)},e.secret_type)}]}),(0,n.plug)("permissions",null,{permission:"wiggle.view",name:"View Panopticon secret",description:"View secrets stored in Panopticon Bot",group:"Panopticon"}),(0,n.plug)("user-record-types",null,{type:"secret",name:"Secret",list:"Secrets",description:"List of Panopticon secrets",form:({record:e})=>{const{payload:t}=e,l=new Date(t.secret_duration),n=new Date,i=l.getTime()-n.getTime();return r.createElement("div",{className:"secret-viewer"},r.createElement(o.Z,{justify:"space-between",style:{marginTop:"30px"}},r.createElement(o.Z.Item,{colspan:7},r.createElement("div",null,r.createElement("b",null,"Secret is")," ",r.createElement(a.vx,{color:s(t.secret_type)},t.secret_type)),("time"===t.secret_type||"location+time"===t.secret_type)&&r.createElement("div",null,r.createElement("b",null,"Revealed when"),r.createElement("br",null),r.createElement("em",null,l.toLocaleDateString(),", ",l.toLocaleTimeString()),i>0&&r.createElement("div",{className:"secret-reveal-at"},Math.round(i/1e3/60)," minutes"),i<0&&r.createElement("div",null,"Secret date is due")),null!=t.secret_bounty&&r.createElement(r.Fragment,null,r.createElement("b",null,"ICE price:")," ",t.secret_bounty," EUR",r.createElement("br",null)),null!=t.secret_payment&&r.createElement(r.Fragment,null,r.createElement("br",null),r.createElement("b",null,"User paid to reveal the secret"),r.createElement("br",null),r.createElement("b",null,"Email: ")," ",t.secret_payment.order_info.email,r.createElement("br",null),r.createElement("b",null,"Currency: ")," ",t.secret_payment.currency,r.createElement("br",null),r.createElement("b",null,"Amount: ")," ",(t.secret_payment.total_amount/100).toFixed(2),r.createElement("br",null),r.createElement("b",null,"Payment ID: ")," ",t.secret_payment.provider_payment_charge_id,r.createElement("br",null))),r.createElement(o.Z.Item,{colspan:7},null!=t.secret_url&&r.createElement("div",null,r.createElement("b",null,"Secret image"),r.createElement("img",{src:t.secret_url,width:"100%"})),null!=t.secret&&r.createElement("div",null,r.createElement("b",null,"Secret text"),r.createElement("div",{className:"display-secret"},t.secret))),r.createElement(o.Z.Item,{colspan:7},null!=e.latitude&&r.createElement("div",{className:"ui-devices-map",style:{height:"300px"}},r.createElement(a.oe,{defaultCenter:{lat:e.latitude,lng:e.longitude},defaultZoom:11},r.createElement(c,null))),null==e.latitude&&r.createElement("div",null,r.createElement("em",null,"No location for this secret")))))},status:[{value:"private",label:"Private"},{value:"public",label:"Public"},{value:"crazy",label:"Crazy"},{value:"keyholder-free",label:"Keyholder free"},{value:"keyholder-taken",label:"Keyholder taken"}]})},4021:(e,t,l)=>{(t=l(23645)(!1)).push([e.id,".secret-viewer .display-secret{padding:4px 10px;font-family:monospace;background-color:#eeeeee;border:1px solid #bbbbbb}.secret-viewer .secret-reveal-at{font-size:40px;font-weight:bolder}\n",""]),e.exports=t},54641:(e,t,l)=>{var r=l(93379),n=l(4021);"string"==typeof(n=n.__esModule?n.default:n)&&(n=[[e.id,n,""]]);r(n,{insert:"head",singleton:!1}),e.exports=n.locals||{}}}]); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"460.main.js","mappings":"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","sources":["webpack://node-red-contrib-chatbot/./plugins/panopticon/helpers/secret-color.js","webpack://node-red-contrib-chatbot/./plugins/panopticon/views/secret-viewer.js","webpack://node-red-contrib-chatbot/./plugins/panopticon/views/image.js","webpack://node-red-contrib-chatbot/./plugins/panopticon/views/balloon.js","webpack://node-red-contrib-chatbot/./plugins/panopticon/views/pin-point.js","webpack://node-red-contrib-chatbot/./plugins/panopticon/pages/secret-map.js","webpack://node-red-contrib-chatbot/./plugins/panopticon/index.js","webpack://node-red-contrib-chatbot/./plugins/panopticon/styles/secret-viewer.scss","webpack://node-red-contrib-chatbot/./plugins/panopticon/styles/secret-viewer.scss?a248"],"sourcesContent":["export const secretColor = (type) => {\n  if (type === 'location') {\n    return '#5E8263';\n  } else if (type) {\n    return'#D36135';\n  } else if (type) {\n    return '#595D88';\n  } else {\n    return '#000000';\n  }\n};","import React from 'react';\nimport { Icon, FlexboxGrid } from 'rsuite';\n\nimport { SmallTag, Maps } from '../../../src/components';\nimport useSettings from '../../../src/hooks/settings';\n\nimport { secretColor } from '../helpers/secret-color';\nimport '../styles/secret-viewer.scss';\n\nconst PinPoint = () => {\n  return (\n    <Icon\n      className=\"map-marker\"\n      icon=\"map-marker\"\n      size=\"2x\"\n      style={{ color: 'red' }}\n    />\n  );\n}\n\nconst SecretViewer = ({ record }) => {\n  const { payload } = record;\n\n  const expireDate = new Date(payload.secret_duration);\n  const now = new Date();\n  const duration = expireDate.getTime() - now.getTime();\n\n  return (\n    <div className=\"secret-viewer\">\n      <FlexboxGrid justify=\"space-between\" style={{ marginTop: '30px' }}>\n        <FlexboxGrid.Item colspan={7}>\n          <div>\n            <b>Secret is</b> <SmallTag color={secretColor(payload.secret_type)}>{payload.secret_type}</SmallTag>\n          </div>\n          {(payload.secret_type === 'time' || payload.secret_type === 'location+time') && (\n            <div>\n              <b>Revealed when</b>\n              <br/>\n              <em>{expireDate.toLocaleDateString()}, {expireDate.toLocaleTimeString()}</em>\n              {(duration > 0) && (\n                <div className=\"secret-reveal-at\">{Math.round(duration/1000/60)} minutes</div>\n              )}\n              {(duration < 0) && (\n                <div>Secret date is due</div>\n              )}\n            </div>\n          )}\n          {payload.secret_bounty != null && (\n            <>\n              <b>ICE price:</b> {payload.secret_bounty} EUR<br/>\n            </>\n          )}\n          {payload.secret_payment != null && (\n            <>\n              <br/>\n              <b>User paid to reveal the secret</b><br/>\n              <b>Email: </b> {payload.secret_payment.order_info.email}<br />\n              <b>Currency: </b> {payload.secret_payment.currency}<br />\n              <b>Amount: </b> {(payload.secret_payment.total_amount / 100).toFixed(2)}<br />\n              <b>Payment ID: </b> {payload.secret_payment.provider_payment_charge_id}<br />\n            </>\n          )}\n        </FlexboxGrid.Item>\n        <FlexboxGrid.Item colspan={7}>\n          {payload.secret_url != null && (\n            <div>\n              <b>Secret image</b>\n              <img src={payload.secret_url} width=\"100%\"/>\n            </div>\n          )}\n          {payload.secret != null && (\n            <div>\n              <b>Secret text</b>\n              <div className=\"display-secret\">\n                {payload.secret}\n              </div>\n            </div>\n          )}\n        </FlexboxGrid.Item>\n        <FlexboxGrid.Item colspan={7}>\n          {record.latitude != null && (\n            <div className=\"ui-devices-map\" style={{ height: `300px` }}>\n              <Maps\n                defaultCenter={{ lat: record.latitude, lng: record.longitude }}\n                defaultZoom={11}\n              >\n                <PinPoint />\n              </Maps>\n            </div>\n          )}\n          {record.latitude == null && (\n            <div>\n              <em>No location for this secret</em>\n            </div>\n          )}\n        </FlexboxGrid.Item>\n      </FlexboxGrid>\n    </div>\n  );\n};\n/*SurveryViewer.propTypes = {\n  record: PropTypes.shape({\n    question: PropTypes.shape({\n      type: PropTypes.oneOf(['text', 'number', 'multiple', 'image']),\n      answer: PropTypes.string,\n      data: PropTypes.oneOfType([\n        PropTypes.string,\n        PropTypes.shape({\n          answer: PropTypes.string,\n          value: PropTypes.string\n        })\n      ])\n    })\n  })\n};*/\n\nexport default SecretViewer;","import React from 'react';\nimport PropTypes from 'prop-types';\n\nclass Image extends React.Component {\n\n  static propTypes = {\n    thumb: PropTypes.string,\n    height: PropTypes.number,\n    width: PropTypes.number,\n    maxWidth: PropTypes.number,\n    maxHeight: PropTypes.number,\n    onClick: PropTypes.func\n  };\n\n  static defaultProps = {\n    thumb: null,\n    height: null,\n    width: null,\n    maxWidth: 200,\n    maxHeight: 400,\n    onClick: () => {}\n  };\n\n  render() {\n    const { thumb, height, width, maxWidth, maxHeight } = this.props;\n\n    const ratio = height / width;\n    let imageHeight = Math.floor(ratio * maxWidth);\n    if (imageHeight > maxHeight) {\n      imageHeight = maxHeight;\n    }\n\n    const style = {\n      backgroundImage: `url(${thumb})`,\n      backgroundPosition: 'center',\n      width: `${maxWidth}px`,\n      height: `${imageHeight}px`\n    };\n\n    return (\n      <div style={style} />\n    );\n  }\n}\n\nexport default Image;\n","import React from 'react';\nimport { Icon, Popover } from 'rsuite';\nimport PropTypes from 'prop-types';\nimport _ from 'lodash';\n\nimport Image from './image';\n\nconst Balloon = ({ topic, ts, content, onDelete, onZoom, thumb, image, width, height, maxHeight, ...props }) => {\n  let thumbImage;\n  if (!_.isEmpty(thumb)) {\n    thumbImage = (\n      <Image\n        thumb={thumb}\n        topic={topic}\n        width={width}\n        height={height}\n        maxHeight={maxHeight}\n        onClick={() => {\n          console.log('clicked');\n          onZoom({ })\n        }}\n      />\n    );\n  }\n\n  return (\n    <Popover title={topic} {...props} onMouseLeave={() => {}}>\n      <div className=\"popover-map-marker\">\n        vario\n      </div>\n    </Popover>\n  );\n};\n\nBalloon.propTypes = {\n  topic: PropTypes.string,\n  thumb: PropTypes.string,\n  image: PropTypes.string,\n  content: PropTypes.string,\n  ts: PropTypes.instanceOf(Date),\n  onDelete: PropTypes.func,\n  width: PropTypes.number,\n  height: PropTypes.number,\n};\n\nBalloon.defaultProps = {\n  topic: null,\n  thumb: null,\n  image: null,\n  content: null,\n  ts: null,\n  onDelete: () => {},\n  width: null,\n  height: null\n};\n\nexport default Balloon;\n","import React from 'react';\nimport { Icon, Tooltip, Whisper, Popover } from 'rsuite';\nimport PropTypes from 'prop-types';\nimport _ from 'lodash';\nimport classNames from 'classnames';\n\nimport Balloon from './balloon';\n\nclass PinPoint extends React.Component {\n\n  static propTypes = {\n    point: PropTypes.shape({\n      topic: PropTypes.string,\n      text: PropTypes.string,\n      ts: PropTypes.string\n    }).isRequired,\n    icon: PropTypes.string,\n    size: PropTypes.string,\n    color: PropTypes.string,\n    text: PropTypes.string,\n    popover: PropTypes.string,\n    thumb: PropTypes.string,\n    image: PropTypes.string,\n    showPopover: PropTypes.bool,\n    type: PropTypes.oneOf(['icon', 'tooltip']),\n    inkColor: PropTypes.string,\n    maxHeight: PropTypes.number\n  };\n\n  static defaultProps = {\n    icon: 'map-marker',\n    color: '#FF3300',\n    text: null,\n    size: '2x',\n    popover: null,\n    thumb: null,\n    image: null,\n    type: 'icon',\n    showPopover: false,\n    inkColor: '#ffffff',\n    maxHeight: 480\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.handleLoaded = this.handleLoaded.bind(this);\n    this.handleClick = this.handleClick.bind(this);\n\n    const { thumb } = props;\n\n    this.state = {\n      needPreload: !_.isEmpty(thumb),\n      preload: false,\n      width: null,\n      height: null\n    };\n  }\n\n  componentDidMount() {\n    const { type, color} = this.props;\n\n    if (this.tooltip != null && type === 'tooltip') {\n      this.tooltip.querySelector('.rs-tooltip-inner').style.backgroundColor = color;\n      this.tooltip.querySelector('.rs-tooltip-arrow').style.backgroundColor = color;\n    }\n  }\n\n  handleLoaded(e) {\n    this.setState({\n      preload: false,\n      width: e.target.width,\n      height: e.target.height\n    }, () => this.trigger.show());\n  }\n\n  handleClick(e) {\n    e.preventDefault();\n    e.stopPropagation();\n\n    const { thumb } = this.props;\n\n    if (!_.isEmpty(thumb)) {\n      this.setState({ preload: true })\n    } else {\n      this.trigger.show();\n    }\n  }\n\n  render() {\n    const { children, point, text, type, popover, showPopover, thumb, image, inkColor, maxHeight, onDeletePoint, onShowImage } = this.props;\n    let { icon, color, size } = this.props;\n\n    const { height, width, preload, needPreload } = this.state;\n\n    if (_.isEmpty(icon)) {\n      icon = 'map-marker';\n    }\n    if (_.isEmpty(size)) {\n      size = 'lg';\n    }\n    if (_.isEmpty(color)) {\n      color = '#FF3300';\n    }\n    if (_.isEmpty(inkColor)) {\n      color = '#000000';\n    }\n    const ts = new Date(parseInt(point.ts, 10));\n\n    let content;\n    switch(type) {\n      case 'icon':\n        content = (\n          <a\n            href=\"#\"\n            className={classNames('wrapper-map-marker', { preload })}\n            onClick={this.handleClick}>\n            {preload && <img src={thumb} style={{display: 'none'}} onLoad={this.handleLoaded} alt=\"\"/>}\n            <Icon\n              className={classNames('map-marker', { 'pointer': showPopover })}\n              icon={icon}\n              size={size}\n              style={{ color }}\n            />\n          </a>\n        );\n        break;\n      case 'tooltip':\n        content = (\n          <div ref={ref => this.tooltip = ref} style={{ height: 20, backgroundColor: '#ff0000' }}>\n            <Tooltip visible><span style={{ color: inkColor }}>{text}</span></Tooltip>\n          </div>\n        );\n        break;\n      default:\n        content = null;\n        break;\n    }\n\n    // if show popover, then add whisper wrapper\n    if (showPopover) {\n      // if need preload and is preloading, then just show the marker and not the whisperer\n      if (needPreload && preload) {\n        return content;\n      }\n      const speaker = (\n        <Popover onMouseLeave={() => {}}>\n          <div className=\"popover-map-marker\">\n            {children}\n          </div>\n        </Popover>\n      );\n      return (\n        <Whisper trigger=\"click\" placement=\"top\" speaker={speaker} triggerRef={ref => this.trigger = ref}>\n          {content}\n        </Whisper>\n      );\n    }\n    return content;\n  }\n}\n\nexport default PinPoint;\n","import React, { useState } from 'react';\nimport gql from 'graphql-tag';\nimport { Link } from 'react-router-dom';\nimport { useApolloClient } from 'react-apollo';\nimport { Loader } from 'rsuite';\n\nimport { PageContainer, Breadcrumbs, Maps } from '../../../src/components';\n\nimport PinPoint from '../views/pin-point';\n\nconst GET_LOCATION_SECRETS = gql`\nquery($where: JSON) {\n  records(limit: 50, order: \"geohash\", where: $where) {\n    id,\n    status,\n    title,\n    latitude,\n    longitude,\n    geohash,\n    payload\n  }\n}`;\n\nconst SecretsMap = () => {\n  const [secrets, setSecrets] = useState(null);\n  const [loading, setLoading] = useState(false);\n  const client = useApolloClient();\n\n  let markers = (secrets || [])\n    .filter(secret => secret.latitude != null && secret.longitude != null)\n    .map(secret => (\n      <PinPoint\n        key={secret.id}\n        lat={secret.latitude}\n        lng={secret.longitude}\n        point={{}}\n        popover={secret.title}\n        showPopover={true}\n      >\n        <div style={{minHeight: '120px'}}><strong>{secret.title}</strong>\n        {secret.payload.secret_url != null && (\n          <div\n            style={{\n              backgroundImage: `url(${secret.payload.secret_url})`,\n              backgroundPosition: 'center',\n              minWidth: '120px',\n              backgroundRepeat: 'no-repeat',\n              backgroundSize: 'contain',\n              height: `120px`\n            }}\n          />\n        )}\n        {secret.payload.secret != null && (\n          <div>{secret.payload.secret}</div>\n        )}\n        <Link to={`/record/${secret.id}`}>view</Link>\n        </div>\n      </PinPoint>\n    ));\n\n  return (\n    <PageContainer className=\"my-page\">\n      <Breadcrumbs pages={['Secret locations']}/>\n      <div style={{ width: '100%', height: '450px', position: 'relative' }}>\n        {loading && (\n          <div style={{ position: 'absolute', top: '20px', left: '20px', zIndex: 10000000 }}>\n            <Loader size=\"md\" />\n          </div>\n        )}\n        <Maps\n          defaultCenter={{ lat: 45.4854739, lng: 9.2022176 }}\n          defaultZoom={11}\n          height={450}\n          onChange={async ({ bounds }) => {\n            const { se, nw } = bounds;\n            setLoading(true);\n            const { data: { records }} = await client.query({\n              query: GET_LOCATION_SECRETS,\n              variables: {\n                where: {\n                  latitude: { 'gte': se.lat, 'lte': nw.lat },\n                  longitude: { 'gte': nw.lng, 'lte': se.lng }\n                }\n              },\n              fetchPolicy: 'network-only'\n            });\n            setSecrets(records);\n            setLoading(false);\n          }}\n        >\n          {markers}\n        </Maps>\n      </div>\n    </PageContainer>\n  );\n};\n\nexport default SecretsMap;\n","import React from 'react';\nimport { plug } from 'code-plug';\n\nimport { UserRecords, SmallTag } from '../../src/components';\nimport SecretViewer from './views/secret-viewer';\nimport { secretColor } from './helpers/secret-color';\nimport SecretsMap from './pages/secret-map';\n\nplug('sidebar', null, {\n  id: 'wiggle',\n  label: 'Panopticon',\n  icon: 'logo-survey',\n  permission: 'wiggle.view',\n  options: [\n    {\n      id: 'wiggle-secrets',\n      label: 'Secrets',\n      url: '/secrets',\n    },\n    {\n      id: 'wiggle-secrets-map',\n      label: 'Secrets Map',\n      url: '/secrets-map',\n    }\n  ]\n});\n// register a page map for all secrets\nplug('pages', SecretsMap, {\n  url: '/secrets-map',\n  title: 'Secrets Map',\n  id: 'secrets-maps',\n\n  permission: 'wiggle.view',\n  breadcrumbs: ['Secrets Map']\n});\n\n// register a page for user records of type survey\nplug('pages', UserRecords, {\n  url: '/secrets',\n  title: 'Secrets',\n  id: 'secrets',\n  type: 'secret',\n  permission: 'wiggle.view',\n  breadcrumbs: ['Secrets'],\n  labels: {\n    title: 'Name',\n    record: 'secret'\n  },\n  columns: [\n    {\n      id: 'secret-type',\n      label: 'Type',\n      width: 120,\n      cell: ({ payload }) => (\n        <SmallTag color={secretColor(payload.secret_type)}>{payload.secret_type}</SmallTag>\n      )\n    }\n  ]\n});\n// register permissions\nplug(\n  'permissions',\n  null,\n  {\n    permission: 'wiggle.view',\n    name: 'View Panopticon secret',\n    description: `View secrets stored in Panopticon Bot`,\n    group: 'Panopticon'\n  }\n);\n// register user record type\nplug(\n  'user-record-types',\n  null,\n  {\n    type: 'secret',\n    name: 'Secret',\n    list: `Secrets`,\n    description: 'List of Panopticon secrets',\n    form: SecretViewer,\n    status: [\n      { value: 'private', label: 'Private' },\n      { value: 'public', label: 'Public' },\n      { value: 'crazy', label: 'Crazy' },\n      { value: 'keyholder-free', label: 'Keyholder free' },\n      { value: 'keyholder-taken', label: 'Keyholder taken' }\n    ]\n  }\n);\n// register button in the user modal to redirect to survey lists\n/*plug(\n  'user-button',\n  GoToSurveyButton\n);*/\n","// Imports\nvar ___CSS_LOADER_API_IMPORT___ = require(\"../../../node_modules/css-loader/dist/runtime/api.js\");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.id, \".secret-viewer .display-secret{padding:4px 10px;font-family:monospace;background-color:#eeeeee;border:1px solid #bbbbbb}.secret-viewer .secret-reveal-at{font-size:40px;font-weight:bolder}\\n\", \"\"]);\n// Exports\nmodule.exports = exports;\n","var api = require(\"!../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\");\n            var content = require(\"!!../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./secret-viewer.scss\");\n\n            content = content.__esModule ? content.default : content;\n\n            if (typeof content === 'string') {\n              content = [[module.id, content, '']];\n            }\n\nvar options = {};\n\noptions.insert = \"head\";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};"],"names":["secretColor","type","PinPoint","Icon","className","icon","size","style","color","Image","React","render","thumb","height","width","maxWidth","maxHeight","this","props","ratio","imageHeight","Math","floor","backgroundImage","backgroundPosition","PropTypes","onClick","Balloon","topic","ts","content","onDelete","onZoom","image","thumbImage","_","console","log","Popover","title","onMouseLeave","propTypes","Date","defaultProps","constructor","super","handleLoaded","bind","handleClick","state","needPreload","preload","componentDidMount","tooltip","querySelector","backgroundColor","e","setState","target","trigger","show","preventDefault","stopPropagation","children","point","text","popover","showPopover","inkColor","onDeletePoint","onShowImage","parseInt","href","classNames","src","display","onLoad","alt","ref","Tooltip","visible","speaker","Whisper","placement","triggerRef","isRequired","GET_LOCATION_SECRETS","gql","plug","id","label","permission","options","url","secrets","setSecrets","useState","loading","setLoading","client","useApolloClient","markers","filter","secret","latitude","longitude","map","key","lat","lng","minHeight","payload","secret_url","minWidth","backgroundRepeat","backgroundSize","to","pages","position","top","left","zIndex","Loader","defaultCenter","defaultZoom","onChange","async","bounds","se","nw","data","records","query","variables","where","fetchPolicy","breadcrumbs","UserRecords","labels","record","columns","cell","secret_type","name","description","group","list","form","expireDate","secret_duration","now","duration","getTime","FlexboxGrid","justify","marginTop","colspan","toLocaleDateString","toLocaleTimeString","round","secret_bounty","secret_payment","order_info","email","currency","total_amount","toFixed","provider_payment_charge_id","status","value","exports","___CSS_LOADER_API_IMPORT___","push","module","api","__esModule","default","locals"],"sourceRoot":""}