Merge pull request #159 from frappe/develop

chore: Merge develop to main
This commit is contained in:
Shariq Ansari 2024-04-30 13:59:25 +05:30 committed by GitHub
commit 75d99ea0e8
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
13 changed files with 342 additions and 244 deletions

View File

@ -1,8 +1,8 @@
// Copyright (c) 2023, Frappe Technologies Pvt. Ltd. and contributors // Copyright (c) 2023, Frappe Technologies Pvt. Ltd. and contributors
// For license information, please see license.txt // For license information, please see license.txt
// frappe.ui.form.on("CRM Deal", { frappe.ui.form.on("CRM Deal", {
// refresh(frm) { refresh(frm) {
frm.add_web_link(`/crm/deals/${frm.doc.name}`, __("Open in Portal"));
// }, },
// }); });

View File

@ -1,8 +1,8 @@
// Copyright (c) 2023, Frappe Technologies Pvt. Ltd. and contributors // Copyright (c) 2023, Frappe Technologies Pvt. Ltd. and contributors
// For license information, please see license.txt // For license information, please see license.txt
// frappe.ui.form.on("CRM Lead", { frappe.ui.form.on("CRM Lead", {
// refresh(frm) { refresh(frm) {
frm.add_web_link(`/crm/leads/${frm.doc.name}`, __("Open in Portal"));
// }, },
// }); });

View File

@ -10,7 +10,7 @@
<div class="mb-3 flex flex-col"> <div class="mb-3 flex flex-col">
<SidebarLink <SidebarLink
id="notifications-btn" id="notifications-btn"
:label="__('Notifications')" label="Notifications"
:icon="NotificationsIcon" :icon="NotificationsIcon"
:isCollapsed="isSidebarCollapsed" :isCollapsed="isSidebarCollapsed"
@click="() => toggleNotificationPanel()" @click="() => toggleNotificationPanel()"
@ -67,7 +67,7 @@
<SidebarLink <SidebarLink
v-for="link in view.views" v-for="link in view.views"
:icon="link.icon" :icon="link.icon"
:label="__(link.label)" :label="link.label"
:to="link.to" :to="link.to"
:isCollapsed="isSidebarCollapsed" :isCollapsed="isSidebarCollapsed"
class="mx-2 my-0.5" class="mx-2 my-0.5"
@ -78,13 +78,13 @@
</div> </div>
<div class="m-2 flex flex-col gap-1"> <div class="m-2 flex flex-col gap-1">
<SidebarLink <SidebarLink
:label="__('Docs')" label="Docs"
:isCollapsed="isSidebarCollapsed" :isCollapsed="isSidebarCollapsed"
icon="book-open" icon="book-open"
@click="() => openDocs()" @click="() => openDocs()"
/> />
<SidebarLink <SidebarLink
:label="isSidebarCollapsed ? __('Expand') : __('Collapse')" :label="isSidebarCollapsed ? 'Expand' : 'Collapse'"
:isCollapsed="isSidebarCollapsed" :isCollapsed="isSidebarCollapsed"
@click="isSidebarCollapsed = !isSidebarCollapsed" @click="isSidebarCollapsed = !isSidebarCollapsed"
class="" class=""

View File

@ -22,10 +22,7 @@
v-slot="{ idx, column, item }" v-slot="{ idx, column, item }"
:row="row" :row="row"
> >
<ListRowItem <ListRowItem :item="item">
:item="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })"
>
<template #prefix> <template #prefix>
<div v-if="['caller', 'receiver'].includes(column.key)"> <div v-if="['caller', 'receiver'].includes(column.key)">
<Avatar <Avatar
@ -40,9 +37,13 @@
<FeatherIcon :name="item.icon" class="h-3 w-3" /> <FeatherIcon :name="item.icon" class="h-3 w-3" />
</div> </div>
</template> </template>
<template #default="{ label }">
<div <div
v-if="['modified', 'creation'].includes(column.key)" v-if="['modified', 'creation'].includes(column.key)"
class="truncate text-base" class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
> >
<Tooltip :text="item.label"> <Tooltip :text="item.label">
<div>{{ item.timeAgo }}</div> <div>{{ item.timeAgo }}</div>
@ -54,6 +55,9 @@
:theme="item.color" :theme="item.color"
size="md" size="md"
:label="__(item.label)" :label="__(item.label)"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
/> />
</div> </div>
<div v-else-if="column.type === 'Check'"> <div v-else-if="column.type === 'Check'">
@ -64,6 +68,16 @@
class="text-gray-900" class="text-gray-900"
/> />
</div> </div>
<div
v-else
class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
>
{{ label }}
</div>
</template>
</ListRowItem> </ListRowItem>
</ListRow> </ListRow>
</ListRows> </ListRows>

View File

@ -23,10 +23,7 @@
v-slot="{ idx, column, item }" v-slot="{ idx, column, item }"
:row="row" :row="row"
> >
<ListRowItem <ListRowItem :item="item">
:item="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })"
>
<template #prefix> <template #prefix>
<div v-if="column.key === 'full_name'"> <div v-if="column.key === 'full_name'">
<Avatar <Avatar
@ -50,9 +47,13 @@
<PhoneIcon class="h-4 w-4" /> <PhoneIcon class="h-4 w-4" />
</div> </div>
</template> </template>
<template #default="{ label }">
<div <div
v-if="['modified', 'creation'].includes(column.key)" v-if="['modified', 'creation'].includes(column.key)"
class="truncate text-base" class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
> >
<Tooltip :text="item.label"> <Tooltip :text="item.label">
<div>{{ item.timeAgo }}</div> <div>{{ item.timeAgo }}</div>
@ -66,6 +67,16 @@
class="text-gray-900" class="text-gray-900"
/> />
</div> </div>
<div
v-else
class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
>
{{ label }}
</div>
</template>
</ListRowItem> </ListRowItem>
</ListRow> </ListRow>
</ListRows> </ListRows>

View File

@ -20,18 +20,16 @@
v-slot="{ idx, column, item }" v-slot="{ idx, column, item }"
:row="row" :row="row"
> >
<div <div v-if="column.key === '_assign'" class="flex items-center">
v-if="column.key === '_assign'" <MultipleAvatar
class="flex items-center" :avatars="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })" size="sm"
> @click="
<MultipleAvatar :avatars="item" size="sm" /> (event) => emit('applyFilter', { event, idx, column, item })
"
/>
</div> </div>
<ListRowItem <ListRowItem v-else :item="item">
v-else
:item="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })"
>
<template #prefix> <template #prefix>
<div v-if="column.key === 'status'"> <div v-if="column.key === 'status'">
<IndicatorIcon :class="item.color" /> <IndicatorIcon :class="item.color" />
@ -58,6 +56,7 @@
<PhoneIcon class="h-4 w-4" /> <PhoneIcon class="h-4 w-4" />
</div> </div>
</template> </template>
<template #default="{ label }">
<div <div
v-if=" v-if="
[ [
@ -69,6 +68,9 @@
].includes(column.key) ].includes(column.key)
" "
class="truncate text-base" class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
> >
<Tooltip :text="item.label"> <Tooltip :text="item.label">
<div>{{ item.timeAgo }}</div> <div>{{ item.timeAgo }}</div>
@ -84,6 +86,9 @@
:theme="item.color" :theme="item.color"
size="md" size="md"
:label="item.value" :label="item.value"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
/> />
</div> </div>
<div v-else-if="column.type === 'Check'"> <div v-else-if="column.type === 'Check'">
@ -94,6 +99,16 @@
class="text-gray-900" class="text-gray-900"
/> />
</div> </div>
<div
v-else
class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
>
{{ label }}
</div>
</template>
</ListRowItem> </ListRowItem>
</ListRow> </ListRow>
</ListRows> </ListRows>

View File

@ -19,16 +19,17 @@
v-slot="{ idx, column, item }" v-slot="{ idx, column, item }"
:row="row" :row="row"
> >
<ListRowItem <ListRowItem :item="item">
:item="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })"
>
<!-- <template #prefix> <!-- <template #prefix>
</template> --> </template> -->
<template #default="{ label }">
<div <div
v-if="['modified', 'creation'].includes(column.key)" v-if="['modified', 'creation'].includes(column.key)"
class="truncate text-base" class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
> >
<Tooltip :text="item.label"> <Tooltip :text="item.label">
<div>{{ item.timeAgo }}</div> <div>{{ item.timeAgo }}</div>
@ -40,6 +41,9 @@
:theme="item.color" :theme="item.color"
size="md" size="md"
:label="item.label" :label="item.label"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
/> />
</div> </div>
<div v-else-if="column.type === 'Check'"> <div v-else-if="column.type === 'Check'">
@ -50,6 +54,16 @@
class="text-gray-900" class="text-gray-900"
/> />
</div> </div>
<div
v-else
class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
>
{{ label }}
</div>
</template>
</ListRowItem> </ListRowItem>
</ListRow> </ListRow>
</ListRows> </ListRows>

View File

@ -20,18 +20,16 @@
v-slot="{ idx, column, item }" v-slot="{ idx, column, item }"
:row="row" :row="row"
> >
<div <div v-if="column.key === '_assign'" class="flex items-center">
v-if="column.key === '_assign'" <MultipleAvatar
class="flex items-center" :avatars="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })" size="sm"
> @click="
<MultipleAvatar :avatars="item" size="sm" /> (event) => emit('applyFilter', { event, idx, column, item })
"
/>
</div> </div>
<ListRowItem <ListRowItem v-else :item="item">
v-else
:item="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })"
>
<template #prefix> <template #prefix>
<div v-if="column.key === 'status'"> <div v-if="column.key === 'status'">
<IndicatorIcon :class="item.color" /> <IndicatorIcon :class="item.color" />
@ -67,6 +65,7 @@
<PhoneIcon class="h-4 w-4" /> <PhoneIcon class="h-4 w-4" />
</div> </div>
</template> </template>
<template #default="{ label }">
<div <div
v-if=" v-if="
[ [
@ -78,6 +77,9 @@
].includes(column.key) ].includes(column.key)
" "
class="truncate text-base" class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
> >
<Tooltip :text="item.label"> <Tooltip :text="item.label">
<div>{{ item.timeAgo }}</div> <div>{{ item.timeAgo }}</div>
@ -93,6 +95,9 @@
:theme="item.color" :theme="item.color"
size="md" size="md"
:label="item.value" :label="item.value"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
/> />
</div> </div>
<div v-else-if="column.type === 'Check'"> <div v-else-if="column.type === 'Check'">
@ -103,6 +108,16 @@
class="text-gray-900" class="text-gray-900"
/> />
</div> </div>
<div
v-else
class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
>
{{ label }}
</div>
</template>
</ListRowItem> </ListRowItem>
</ListRow> </ListRow>
</ListRows> </ListRows>
@ -213,7 +228,9 @@ function editValues(selections, unselectAll) {
function deleteValues(selections, unselectAll) { function deleteValues(selections, unselectAll) {
$dialog({ $dialog({
title: __('Delete'), title: __('Delete'),
message: __('Are you sure you want to delete {0} item(s)?', [selections.size]), message: __('Are you sure you want to delete {0} item(s)?', [
selections.size,
]),
variant: 'danger', variant: 'danger',
actions: [ actions: [
{ {

View File

@ -22,10 +22,7 @@
v-slot="{ idx, column, item }" v-slot="{ idx, column, item }"
:row="row" :row="row"
> >
<ListRowItem <ListRowItem :item="item">
:item="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })"
>
<template #prefix> <template #prefix>
<div v-if="column.key === 'organization_name'"> <div v-if="column.key === 'organization_name'">
<Avatar <Avatar
@ -37,9 +34,13 @@
/> />
</div> </div>
</template> </template>
<template #default="{ label }">
<div <div
v-if="['modified', 'creation'].includes(column.key)" v-if="['modified', 'creation'].includes(column.key)"
class="truncate text-base" class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
> >
<Tooltip :text="item.label"> <Tooltip :text="item.label">
<div>{{ item.timeAgo }}</div> <div>{{ item.timeAgo }}</div>
@ -53,6 +54,16 @@
class="text-gray-900" class="text-gray-900"
/> />
</div> </div>
<div
v-else
class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
>
{{ label }}
</div>
</template>
</ListRowItem> </ListRowItem>
</ListRow> </ListRow>
</ListRows> </ListRows>

View File

@ -29,11 +29,7 @@
</div> </div>
</Tooltip> </Tooltip>
</div> </div>
<ListRowItem <ListRowItem v-else :item="item">
v-else
:item="item"
@click="(event) => emit('applyFilter', { event, idx, column, item })"
>
<template #prefix> <template #prefix>
<div v-if="column.key === 'status'"> <div v-if="column.key === 'status'">
<TaskStatusIcon :status="item" /> <TaskStatusIcon :status="item" />
@ -51,9 +47,13 @@
/> />
</div> </div>
</template> </template>
<template #default="{ label }">
<div <div
v-if="['modified', 'creation'].includes(column.key)" v-if="['modified', 'creation'].includes(column.key)"
class="truncate text-base" class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
> >
<Tooltip :text="item.label"> <Tooltip :text="item.label">
<div>{{ item.timeAgo }}</div> <div>{{ item.timeAgo }}</div>
@ -67,6 +67,16 @@
class="text-gray-900" class="text-gray-900"
/> />
</div> </div>
<div
v-else
class="truncate text-base"
@click="
(event) => emit('applyFilter', { event, idx, column, item })
"
>
{{ label }}
</div>
</template>
</ListRowItem> </ListRowItem>
</ListRow> </ListRow>
</ListRows> </ListRows>
@ -177,7 +187,9 @@ function editValues(selections, unselectAll) {
function deleteValues(selections, unselectAll) { function deleteValues(selections, unselectAll) {
$dialog({ $dialog({
title: __('Delete'), title: __('Delete'),
message: __('Are you sure you want to delete {0} item(s)?'), message: __('Are you sure you want to delete {0} item(s)?', [
selections.size,
]),
variant: 'danger', variant: 'danger',
actions: [ actions: [
{ {

View File

@ -17,7 +17,7 @@
<Switch v-model="chooseExistingContact" /> <Switch v-model="chooseExistingContact" />
</div> </div>
</div> </div>
<Fields class="border-t" :sections="sections" :data="deal" /> <Fields class="border-t pt-4" :sections="sections" :data="deal" />
<ErrorMessage class="mt-4" v-if="error" :message="__(error)" /> <ErrorMessage class="mt-4" v-if="error" :message="__(error)" />
</template> </template>
<template #actions> <template #actions>

View File

@ -6,10 +6,12 @@
:class="[field.hidden && 'hidden']" :class="[field.hidden && 'hidden']"
class="flex items-center gap-2 px-3 leading-5 first:mt-3" class="flex items-center gap-2 px-3 leading-5 first:mt-3"
> >
<div class="w-[106px] shrink-0 text-sm text-gray-600"> <Tooltip :text="__(field.label)" hoverDelay="1">
{{ __(field.label) }} <div class="w-[106px] shrink-0 truncate text-sm text-gray-600">
<span>{{ __(field.label) }}</span>
<span class="text-red-500">{{ field.reqd ? ' *' : '' }}</span> <span class="text-red-500">{{ field.reqd ? ' *' : '' }}</span>
</div> </div>
</Tooltip>
<div <div
class="grid min-h-[28px] flex-1 items-center overflow-hidden text-base" class="grid min-h-[28px] flex-1 items-center overflow-hidden text-base"
> >

View File

@ -8,8 +8,8 @@
class="flex w-full items-center justify-between duration-300 ease-in-out" class="flex w-full items-center justify-between duration-300 ease-in-out"
:class="isCollapsed ? 'ml-[3px] p-1' : 'px-2 py-1'" :class="isCollapsed ? 'ml-[3px] p-1' : 'px-2 py-1'"
> >
<div class="flex items-center"> <div class="flex items-center truncate">
<Tooltip :text="label" placement="right" :disabled="!isCollapsed"> <Tooltip :text="__(label)" placement="right" :disabled="!isCollapsed">
<slot name="icon"> <slot name="icon">
<span class="grid h-4.5 w-4.5 flex-shrink-0 place-items-center"> <span class="grid h-4.5 w-4.5 flex-shrink-0 place-items-center">
<FeatherIcon <FeatherIcon
@ -21,16 +21,18 @@
</span> </span>
</slot> </slot>
</Tooltip> </Tooltip>
<Tooltip :text="__(label)" placement="right" :disabled="isCollapsed" hoverDelay="1.5">
<span <span
class="flex-1 flex-shrink-0 text-base duration-300 ease-in-out" class="flex-1 flex-shrink-0 truncate text-base duration-300 ease-in-out"
:class=" :class="
isCollapsed isCollapsed
? 'ml-0 w-0 overflow-hidden opacity-0' ? 'ml-0 w-0 overflow-hidden opacity-0'
: 'ml-2 w-auto opacity-100' : 'ml-2 w-auto opacity-100'
" "
> >
{{ label }} {{ __(label) }}
</span> </span>
</Tooltip>
</div> </div>
<slot name="right" /> <slot name="right" />
</div> </div>