Fix tags popup and Applicant Labels ()

Signed-off-by: Andrey Sobolev <haiodo@gmail.com>
This commit is contained in:
Andrey Sobolev 2022-05-31 20:35:10 +07:00 committed by GitHub
parent 6739ce302d
commit 732fa0100b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 30 additions and 17 deletions
changelog.md
plugins
recruit-resources/src/components
tags-resources/src/components
task-resources/src/components
view-resources/src/components

View File

@ -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

View File

@ -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>

View File

@ -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}>

View File

@ -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>

View File

@ -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">

View File

@ -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