platform/plugins/recruit-resources/src/components/CreateApplication.svelte

58 lines
1.9 KiB
Svelte
Raw Normal View History

<!--
// 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 { createEventDispatcher } from 'svelte'
import type { Ref, Space } from '@anticrm/core'
import { DatePicker, EditBox, Card, Tabs, Section, Grid, Row, Button } from '@anticrm/ui'
import { UserBox, UserInfo, Avatar } from '@anticrm/presentation'
import type { Person } from '@anticrm/contact'
import File from './icons/File.svelte'
import Address from './icons/Address.svelte'
import Attachment from './icons/Attachment.svelte'
import { getClient } from '@anticrm/presentation'
import recruit from '../plugin'
export let space: Ref<Space>
const dispatch = createEventDispatcher()
let candidate: Ref<Person>
const client = getClient()
function createCandidate() {
client.createDoc(recruit.class.Applicant, space, {
candidate,
})
dispatch('close')
}
</script>
<Card label={'Create Application'}
okLabel={'Save'}
okAction={createCandidate}
on:close={() => { dispatch('close') }}>
<Grid rowGap={1.5}>
<Row><EditBox label={'Name'} placeholder={'John Connor'} /></Row>
<Row><UserInfo value={{firstName: 'First', lastName: 'Last', city: 'Cityvech'}} size={'large'} subtitle={'Candidate'} /></Row>
<UserBox _class={recruit.class.Candidate} title='Candidate' caption='Candidates' bind:value={candidate} />
<DatePicker title={'Pick due date'} />
</Grid>
</Card>