/* * << * Davinci * == * Copyright (C) 2016 - 2017 EDP * == * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * >> */ import React, { FC, useCallback } from 'react' import { useDispatch, useSelector } from 'react-redux' import SharePanelComponent from 'app/components/SharePanel' import DashboardActions from './actions' const { loadDashboardShareLink, loadWidgetShareLink, closeSharePanel } = DashboardActions import { makeSelectSharePanel, makeSelectCurrentDashboardShareToken, makeSelectCurrentDashboardAuthorizedShareToken, makeSelectCurrentDashboardPasswordSharePassword, makeSelectCurrentDashboardPasswordShareToken, makeSelectCurrentDashboardShareLoading, makeSelectCurrentItemsInfo } from './selectors' import { makeSelectCurrentOrganizationMembers } from 'containers/Organizations/selectors' import { makeSelectProjectRoles } from 'containers/Projects/selectors' const SharePanel: FC = () => { const dispatch = useDispatch() const sharePanelStates = useSelector(makeSelectSharePanel()) const dashboardShareToken = useSelector( makeSelectCurrentDashboardShareToken() ) const dashboardAuthorizedShareToken = useSelector( makeSelectCurrentDashboardAuthorizedShareToken() ) const dashboardPasswordShareToken = useSelector( makeSelectCurrentDashboardPasswordShareToken() ) const dashboardPasswordSharePassword = useSelector( makeSelectCurrentDashboardPasswordSharePassword() ) const dashboardShareLoading = useSelector( makeSelectCurrentDashboardShareLoading() ) const currentItemsInfo = useSelector(makeSelectCurrentItemsInfo()) const projectRoles = useSelector(makeSelectProjectRoles()) const organizationMembers = useSelector( makeSelectCurrentOrganizationMembers() ) const onLoadDashboardShareLink = useCallback( ({ id, mode, expired, permission, roles, viewers }) => { dispatch( loadDashboardShareLink({ id, mode, expired, permission, roles, viewers }) ) }, [] ) const onLoadWidgetShareLink = useCallback( ({ id, itemId, mode, expired, permission, roles, viewers }) => { dispatch( loadWidgetShareLink({ id, itemId, mode, expired, permission, roles, viewers }) ) }, [] ) const onCloseSharePanel = useCallback(() => { dispatch(closeSharePanel()) }, []) const { type, itemId } = sharePanelStates let shareToken = '' let authorizedShareToken = '' let passwordShareToken = '' let password = '' let shareLoading = false switch (type) { case 'dashboard': shareToken = dashboardShareToken authorizedShareToken = dashboardAuthorizedShareToken password = dashboardPasswordSharePassword passwordShareToken = dashboardPasswordShareToken shareLoading = dashboardShareLoading break case 'widget': const itemInfo = currentItemsInfo[itemId] shareToken = itemInfo.shareToken authorizedShareToken = itemInfo.authorizedShareToken password = itemInfo.password passwordShareToken = itemInfo.passwordShareToken shareLoading = itemInfo.shareLoading break } return ( ) } export default SharePanel