platform/plugins/workbench-resources/src/components/Workbench.svelte
Alexander Platov 809a654cab
Show/hide navigator (#477)
Signed-off-by: Alexander Platov <sas_lord@mail.ru>
2021-12-02 10:05:09 +01:00

174 lines
5.7 KiB
Svelte

<!--
// Copyright © 2020 Anticrm Platform Contributors.
//
// Licensed under the Eclipse Public 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 https://www.eclipse.org/legal/epl-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.
-->
<script lang="ts">
import ActivityStatus from './ActivityStatus.svelte'
import Applications from './Applications.svelte'
import NavHeader from './NavHeader.svelte'
import { onDestroy } from 'svelte'
import type { Ref, Space, Client } from '@anticrm/core'
import type { Application, NavigatorModel, ViewConfiguration } from '@anticrm/workbench'
import { setClient, Avatar, createQuery } from '@anticrm/presentation'
import workbench from '@anticrm/workbench'
import Navigator from './Navigator.svelte'
import SpaceHeader from './SpaceHeader.svelte'
import SpaceView from './SpaceView.svelte'
import { AnyComponent, Component, location, Popup, showPopup, TooltipInstance } from '@anticrm/ui'
import core from '@anticrm/core'
import AccountPopup from './AccountPopup.svelte'
import AppItem from './AppItem.svelte'
import TopMenu from './icons/TopMenu.svelte'
export let client: Client
setClient(client)
let currentApp: Ref<Application> | undefined
let currentApplication: Application | undefined
let currentSpace: Ref<Space> | undefined
let specialComponent: AnyComponent | undefined
let currentView: ViewConfiguration | undefined
let createItemDialog: AnyComponent | undefined
let navigatorModel: NavigatorModel | undefined
onDestroy(location.subscribe(async (loc) => {
currentApp = loc.path[1] as Ref<Application>
currentApplication = (await client.findAll(workbench.class.Application, { _id: currentApp }))[0]
navigatorModel = currentApplication?.navigatorModel
let currentFolder = loc.path[2] as Ref<Space>
specialComponent = getSpecialComponent(currentFolder)
if (!specialComponent) {
currentSpace = currentFolder
const space = (await client.findAll(core.class.Space, { _id: currentSpace }))[0]
if (space) {
const spaceClass = client.getHierarchy().getClass(space._class) // (await client.findAll(core.class.Class, { _id: space._class }))[0]
const view = client.getHierarchy().as(spaceClass, workbench.mixin.SpaceView)
currentView = view.view
createItemDialog = currentView.createItemDialog
} else {
currentView = undefined
createItemDialog = undefined
}
}
}))
function getSpecialComponent (id: string): AnyComponent | undefined {
let special = navigatorModel?.specials?.find((x) => x.id === id)
return special?.component
}
let apps: Application[] = []
const query = createQuery()
$: query.query(workbench.class.Application, { hidden: false }, result => { apps = result })
let visibileNav: boolean = true
</script>
{#if client}
<svg class="mask">
<clipPath id="notify-normal">
<path d="M0,0v52.5h52.5V0H0z M34,23.2c-3.2,0-5.8-2.6-5.8-5.8c0-3.2,2.6-5.8,5.8-5.8c3.2,0,5.8,2.6,5.8,5.8 C39.8,20.7,37.2,23.2,34,23.2z"/>
</clipPath>
<clipPath id="notify-small">
<path d="M0,0v45h45V0H0z M29.5,20c-2.8,0-5-2.2-5-5s2.2-5,5-5s5,2.2,5,5S32.3,20,29.5,20z"/>
</clipPath>
</svg>
<div class="container">
<div class="panel-app">
<div class="flex-col">
<ActivityStatus status="active"/>
<AppItem icon={TopMenu} label={'Navigator'} selected={!visibileNav} action={async () => { visibileNav = !visibileNav }}/>
</div>
<Applications {apps} active={currentApp}/>
<div class="flex-center" style="min-height: 6.25rem;">
<div class="cursor-pointer" on:click={(el) => { showPopup(AccountPopup, { }, 'account') }}>
<Avatar size={'medium'} />
</div>
</div>
</div>
{#if navigator && visibileNav}
<div class="panel-navigator">
{#if currentApplication}
<NavHeader label={currentApplication.label} action={() => {}} />
{/if}
<Navigator model={navigatorModel} />
</div>
{/if}
<div class="panel-component">
{#if specialComponent}
<Component is={specialComponent} />
{:else}
<SpaceHeader space={currentSpace} {createItemDialog} />
{#if currentView && currentSpace}
<SpaceView space={currentSpace} _class={currentView.class} options={currentView.options} />
{/if}
{/if}
</div>
<!-- <div class="aside"><Chat thread/></div> -->
</div>
<Popup />
<TooltipInstance />
{:else}
No client
{/if}
<style lang="scss">
.mask {
position: absolute;
width: 0;
height: 0;
}
.container {
display: flex;
height: 100%;
padding-bottom: 1.25rem;
.panel-app {
display: flex;
flex-direction: column;
justify-content: space-between;
align-items: center;
min-width: 5rem;
width: 5rem;
height: 100%;
border-radius: 1.25rem;
}
.panel-navigator {
display: flex;
flex-direction: column;
margin-right: 1rem;
min-width: 18rem;
width: 18rem;
height: 100%;
border-radius: 1.25rem;
background-color: var(--theme-bg-color);
}
.panel-component {
flex-grow: 1;
display: flex;
flex-direction: column;
margin-right: 1rem;
height: 100%;
border-radius: 1.25rem;
background-color: var(--theme-bg-color);
}
}
</style>