platform/plugins/setting-resources/src/components/ClassSetting.svelte
Alexander Platov 3ac0e6e259
Updated layout of Project Types (#4345)
Signed-off-by: Alexander Platov <sas_lord@mail.ru>
2024-01-12 13:57:34 +07:00

147 lines
4.7 KiB
Svelte

<!--
// Copyright © 2022 Hardcore Engineering Inc.
//
// 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 { createEventDispatcher } from 'svelte'
import core, { Class, Doc, Obj, Ref } from '@hcengineering/core'
import { IntlString } from '@hcengineering/platform'
import { createQuery, getClient } from '@hcengineering/presentation'
import {
AnySvelteComponent,
Scroller,
ButtonIcon,
IconDescription,
Label,
getLocation,
navigate,
Header,
Breadcrumb,
defineSeparators,
settingsSeparators,
Separator,
NavGroup
} from '@hcengineering/ui'
import setting from '../plugin'
import { filterDescendants } from '../utils'
import ClassAttributes from './ClassAttributes.svelte'
import ClassHierarchy from './ClassHierarchy.svelte'
import { clearSettingsStore } from '../store'
export let ofClass: Ref<Class<Obj>> | undefined = undefined
export let attributeMapper:
| {
component: AnySvelteComponent
label: IntlString
props: Record<string, any>
}
| undefined = undefined
export let withoutHeader = false
export let useOfClassAttributes = true
export let visibleNav: boolean = true
const dispatch = createEventDispatcher()
const loc = getLocation()
const client = getClient()
const hierarchy = client.getHierarchy()
let _class: Ref<Class<Doc>> | undefined = ofClass ?? (loc.query?._class as Ref<Class<Doc>> | undefined)
$: if (_class !== undefined && ofClass === undefined) {
const loc = getLocation()
loc.query = undefined
navigate(loc)
}
const clQuery = createQuery()
let classes: Ref<Class<Doc>>[] = []
let rawClasses: Class<Doc>[] = []
clQuery.query(core.class.Class, {}, (res) => {
rawClasses = res
})
$: classes = filterDescendants(hierarchy, ofClass, rawClasses)
$: if (ofClass !== undefined) {
// We need to include all possible mixins as well
for (const ancestor of hierarchy.getAncestors(ofClass)) {
if (ancestor === ofClass) {
continue
}
const mixins = hierarchy.getDescendants(ancestor).filter((it) => hierarchy.isMixin(it))
for (const m of mixins) {
const mm = hierarchy.getClass(m)
if (
!classes.includes(m) &&
mm.extends === ancestor &&
mm.label !== undefined &&
client.getHierarchy().hasMixin(mm, setting.mixin.Editable)
) {
// Check if parent of
classes.push(m)
}
}
}
}
$: if (ofClass !== undefined && _class !== undefined && !client.getHierarchy().isDerived(_class, ofClass)) {
_class = ofClass
}
defineSeparators('workspaceSettings', settingsSeparators)
</script>
<div class="hulyComponent">
{#if !withoutHeader}
<Header minimize={!visibleNav} on:resize={(event) => dispatch('change', event.detail)}>
<Breadcrumb icon={setting.icon.Clazz} label={setting.string.ClassSetting} size={'large'} isCurrent />
</Header>
{/if}
<div class="hulyComponent-content__container columns">
<div class="hulyComponent-content__column">
<div class="hulyComponent-content__navHeader divide">
<div class="hulyComponent-content__navHeader-menu">
<ButtonIcon kind={'tertiary'} icon={IconDescription} size={'small'} inheritColor />
</div>
<div class="hulyComponent-content__navHeader-hint paragraph-regular-14">
<Label label={setting.string.ClassSettingHint} />
</div>
</div>
<Scroller>
<NavGroup label={setting.string.Classes} selected={_class !== undefined} categoryName={'classes'} second>
<ClassHierarchy
{classes}
{_class}
{ofClass}
on:select={(e) => {
_class = e.detail
clearSettingsStore()
}}
/>
</NavGroup>
</Scroller>
</div>
<Separator name={'workspaceSettings'} index={0} color={'var(--theme-divider-color)'} />
<div class="hulyComponent-content__column content">
<Scroller align={'center'} padding={'var(--spacing-3)'} bottomPadding={'var(--spacing-3)'}>
<div class="hulyComponent-content">
{#if _class !== undefined}
<ClassAttributes {_class} {ofClass} {attributeMapper} />
{/if}
</div>
</Scroller>
</div>
</div>
</div>