mirror of
https://github.com/hcengineering/platform.git
synced 2025-04-21 15:59:15 +00:00
Fix tags popup and Applicant Labels (#1958)
Signed-off-by: Andrey Sobolev <haiodo@gmail.com>
This commit is contained in:
parent
6739ce302d
commit
732fa0100b
changelog.md
plugins
recruit-resources/src/components
tags-resources/src/components
task-resources/src/components
view-resources/src/components
@ -6,6 +6,7 @@ Platform:
|
|||||||
|
|
||||||
- Fix first filter disappear
|
- Fix first filter disappear
|
||||||
- Adjust label editors design
|
- Adjust label editors design
|
||||||
|
- Fix skills/labels selection and show real usage counter
|
||||||
|
|
||||||
## 0.6.22
|
## 0.6.22
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@
|
|||||||
const dispatch = createEventDispatcher()
|
const dispatch = createEventDispatcher()
|
||||||
|
|
||||||
onMount(() => {
|
onMount(() => {
|
||||||
dispatch('open', { ignoreKeys: ['comments', 'number'] })
|
dispatch('open', { ignoreKeys: ['comments', 'number'], allowedCollections: ['labels'] })
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
@ -28,6 +28,9 @@
|
|||||||
{#each items as value}
|
{#each items as value}
|
||||||
<TagReferencePresenter {value} />
|
<TagReferencePresenter {value} />
|
||||||
{/each}
|
{/each}
|
||||||
|
<Button kind="link" on:click={tagsHandler}>
|
||||||
|
<Icon icon={IconAdd} slot="content" size="small" />
|
||||||
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
{:else if isEditable}
|
{:else if isEditable}
|
||||||
<Button kind="link" on:click={tagsHandler}>
|
<Button kind="link" on:click={tagsHandler}>
|
||||||
|
@ -64,20 +64,18 @@
|
|||||||
showPopup(CreateTagElement, { targetClass }, 'top')
|
showPopup(CreateTagElement, { targetClass }, 'top')
|
||||||
}
|
}
|
||||||
|
|
||||||
const isSelected = (element: TagElement): boolean => {
|
const isSelected = (selected: Ref<TagElement>[], element: TagElement): boolean => {
|
||||||
if (selected.filter((p) => p === element._id).length > 0) return true
|
if (selected.filter((p) => p === element._id).length > 0) return true
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
const checkSelected = (element: TagElement): void => {
|
const checkSelected = (_selected: Ref<TagElement>[], element: TagElement): void => {
|
||||||
if (isSelected(element)) {
|
if (isSelected(_selected, element)) {
|
||||||
selected = selected.filter((p) => p !== element._id)
|
selected = _selected.filter((p) => p !== element._id)
|
||||||
dispatch('update', { action: 'remove', tag: element })
|
dispatch('update', { action: 'remove', tag: element })
|
||||||
} else {
|
} else {
|
||||||
selected = [...selected, element._id]
|
selected = [..._selected, element._id]
|
||||||
dispatch('update', { action: 'add', tag: element })
|
dispatch('update', { action: 'add', tag: element })
|
||||||
}
|
}
|
||||||
objects = objects
|
|
||||||
categories = categories
|
|
||||||
dispatch('update', { action: 'selected', selected: selected })
|
dispatch('update', { action: 'selected', selected: selected })
|
||||||
}
|
}
|
||||||
const toggleGroup = (ev: MouseEvent): void => {
|
const toggleGroup = (ev: MouseEvent): void => {
|
||||||
@ -92,6 +90,13 @@
|
|||||||
onMount(() => {
|
onMount(() => {
|
||||||
if (searchElement) searchElement.focus()
|
if (searchElement) searchElement.focus()
|
||||||
})
|
})
|
||||||
|
const tagSort = (a: TagElement, b: TagElement) => {
|
||||||
|
const r = (b.refCount ?? 0) - (a.refCount ?? 0)
|
||||||
|
if (r === 0) {
|
||||||
|
return b.title.localeCompare(a.title)
|
||||||
|
}
|
||||||
|
return r
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="selectPopup maxHeight">
|
<div class="selectPopup maxHeight">
|
||||||
@ -133,9 +138,7 @@
|
|||||||
<div class="scroll">
|
<div class="scroll">
|
||||||
<div class="box">
|
<div class="box">
|
||||||
{#each categories as cat}
|
{#each categories as cat}
|
||||||
{@const catObjects = objects
|
{@const catObjects = objects.filter((el) => el.category === cat._id).sort(tagSort)}
|
||||||
.filter((el) => el.category === cat._id)
|
|
||||||
.sort((a, b) => (b.refCount ?? 0) - (a.refCount ?? 0))}
|
|
||||||
{#if catObjects.length > 0}
|
{#if catObjects.length > 0}
|
||||||
<div class="sticky-wrapper">
|
<div class="sticky-wrapper">
|
||||||
<button
|
<button
|
||||||
@ -167,14 +170,17 @@
|
|||||||
<button
|
<button
|
||||||
class="menu-item"
|
class="menu-item"
|
||||||
on:click={() => {
|
on:click={() => {
|
||||||
checkSelected(element)
|
checkSelected(selected, element)
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<div class="check pointer-events-none">
|
<div class="check pointer-events-none">
|
||||||
<CheckBox checked={isSelected(element)} primary />
|
<CheckBox checked={isSelected(selected, element)} primary />
|
||||||
</div>
|
</div>
|
||||||
<div class="tag" style="background-color: {getPlatformColor(element.color)};" />
|
<div class="tag" style="background-color: {getPlatformColor(element.color)};" />
|
||||||
{element.title}
|
{element.title}
|
||||||
|
<span class="ml-2 text-xs">
|
||||||
|
({element.refCount ?? 0})
|
||||||
|
</span>
|
||||||
</button>
|
</button>
|
||||||
{/each}
|
{/each}
|
||||||
</div>
|
</div>
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
export let mixins: Mixin<Doc>[]
|
export let mixins: Mixin<Doc>[]
|
||||||
export let ignoreKeys: string[]
|
export let ignoreKeys: string[]
|
||||||
export let vertical: boolean = false
|
export let vertical: boolean = false
|
||||||
|
export let allowedCollections: string[] = []
|
||||||
|
|
||||||
const client = getClient()
|
const client = getClient()
|
||||||
const hierarchy = client.getHierarchy()
|
const hierarchy = client.getHierarchy()
|
||||||
@ -77,7 +78,7 @@
|
|||||||
<AttributesBar {object} _class={object._class} keys={['doneState', 'state']} showHeader={false} />
|
<AttributesBar {object} _class={object._class} keys={['doneState', 'state']} showHeader={false} />
|
||||||
</div>
|
</div>
|
||||||
{:else}
|
{:else}
|
||||||
<DocAttributeBar {object} {ignoreKeys} {mixins} on:update />
|
<DocAttributeBar {object} {ignoreKeys} {mixins} {allowedCollections} on:update />
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
<style lang="scss">
|
<style lang="scss">
|
||||||
|
@ -88,6 +88,7 @@
|
|||||||
$: getMixins(parentClass, object)
|
$: getMixins(parentClass, object)
|
||||||
|
|
||||||
let ignoreKeys: string[] = []
|
let ignoreKeys: string[] = []
|
||||||
|
let allowedCollections: string[] = []
|
||||||
let ignoreMixins: Set<Ref<Mixin<Doc>>> = new Set<Ref<Mixin<Doc>>>()
|
let ignoreMixins: Set<Ref<Mixin<Doc>>> = new Set<Ref<Mixin<Doc>>>()
|
||||||
|
|
||||||
async function updateKeys (): Promise<void> {
|
async function updateKeys (): Promise<void> {
|
||||||
@ -238,11 +239,11 @@
|
|||||||
{#if headerEditor !== undefined}
|
{#if headerEditor !== undefined}
|
||||||
<Component
|
<Component
|
||||||
is={headerEditor}
|
is={headerEditor}
|
||||||
props={{ object, keys, mixins, ignoreKeys, vertical: dir === 'column' }}
|
props={{ object, keys, mixins, ignoreKeys, vertical: dir === 'column', allowedCollections }}
|
||||||
on:update={updateKeys}
|
on:update={updateKeys}
|
||||||
/>
|
/>
|
||||||
{:else if dir === 'column'}
|
{:else if dir === 'column'}
|
||||||
<DocAttributeBar {object} {mixins} {ignoreKeys} on:update={updateKeys} />
|
<DocAttributeBar {object} {mixins} {ignoreKeys} {allowedCollections} on:update={updateKeys} />
|
||||||
{:else}
|
{:else}
|
||||||
<AttributesBar {object} _class={realObjectClass} {keys} />
|
<AttributesBar {object} _class={realObjectClass} {keys} />
|
||||||
{/if}
|
{/if}
|
||||||
@ -256,12 +257,13 @@
|
|||||||
on:open={(ev) => {
|
on:open={(ev) => {
|
||||||
ignoreKeys = ev.detail.ignoreKeys
|
ignoreKeys = ev.detail.ignoreKeys
|
||||||
ignoreMixins = new Set(ev.detail.ignoreMixins)
|
ignoreMixins = new Set(ev.detail.ignoreMixins)
|
||||||
|
allowedCollections = ev.detail.allowedCollections ?? []
|
||||||
getMixins(parentClass, object)
|
getMixins(parentClass, object)
|
||||||
updateKeys()
|
updateKeys()
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
{/if}
|
{/if}
|
||||||
{#each collectionEditors as collection}
|
{#each collectionEditors.filter((it) => !allowedCollections.includes(it.key.key)) as collection}
|
||||||
{#if collection.editor}
|
{#if collection.editor}
|
||||||
<div class="mt-6">
|
<div class="mt-6">
|
||||||
<Component
|
<Component
|
||||||
|
Loading…
Reference in New Issue
Block a user