123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 |
- /*
- * <<
- * 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 (
- <SharePanelComponent
- {...sharePanelStates}
- shareToken={shareToken}
- passwordShareToken={passwordShareToken}
- authorizedShareToken={authorizedShareToken}
- password={password}
- loading={shareLoading}
- projectRoles={projectRoles}
- organizationMembers={organizationMembers}
- onLoadDashboardShareLink={onLoadDashboardShareLink}
- onLoadWidgetShareLink={onLoadWidgetShareLink}
- onClose={onCloseSharePanel}
- />
- )
- }
- export default SharePanel
|