Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BREAK] Move Multiple Department Creation to EE & [NEW] Department Archive #27753

Merged
merged 71 commits into from
Feb 13, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
985b025
Move save department functionality to EE
sampaiodiego Jan 13, 2023
4e24aba
[FE] Move Departments to EE
MartinSchoeler Jan 13, 2023
ff865e3
Merge branch 'departments-to-ee' into move-save-department-ee
MartinSchoeler Jan 13, 2023
d61b219
Fix weird caching issue
MartinSchoeler Jan 13, 2023
984da48
Fix TS & Better error message
MartinSchoeler Jan 16, 2023
88c6dd5
Tests and small changes
MartinSchoeler Jan 16, 2023
085c803
Better wording
MartinSchoeler Jan 16, 2023
c9a5070
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Jan 16, 2023
317bd12
Fix reviews & ee tests
MartinSchoeler Jan 16, 2023
6ea0021
Merge branch 'move-save-department-ee' of https://github.com/RocketCh…
MartinSchoeler Jan 16, 2023
df4d8e7
fix review again
MartinSchoeler Jan 16, 2023
050b0c2
Fix reviews
MartinSchoeler Jan 16, 2023
1919d18
reviews
MartinSchoeler Jan 16, 2023
49231b8
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Jan 16, 2023
f89b05d
Fix wrong conditional
MartinSchoeler Jan 17, 2023
31da816
Merge branch 'move-save-department-ee' of https://github.com/RocketCh…
MartinSchoeler Jan 17, 2023
cf29e81
Merge branch 'develop' into move-save-department-ee
tassoevan Jan 18, 2023
f8f1e65
Fix tests
MartinSchoeler Jan 19, 2023
fca41f8
Lint
MartinSchoeler Jan 19, 2023
a7a1c3d
Move department tests to ee
MartinSchoeler Jan 20, 2023
6500401
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Jan 20, 2023
61ad52d
Update NewDepartment.tsx
MartinSchoeler Jan 20, 2023
e8502c8
I love typescript ™
MartinSchoeler Jan 20, 2023
aa408af
Update apps/meteor/tests/data/livechat/rooms.ts
MartinSchoeler Jan 23, 2023
8a96b75
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Jan 23, 2023
1ef34e9
Fix TS
MartinSchoeler Jan 26, 2023
0713f98
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Jan 26, 2023
9be3049
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Jan 30, 2023
40cc2d5
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Jan 31, 2023
f5cab82
add jsdoc
MartinSchoeler Jan 31, 2023
235b605
Merge branch 'move-save-department-ee' of https://github.com/RocketCh…
MartinSchoeler Jan 31, 2023
8ad8a06
Remove extra skip
MartinSchoeler Jan 31, 2023
6f9c1f2
remove wrong field
MartinSchoeler Jan 31, 2023
dbdfffd
TS fixes
MartinSchoeler Jan 31, 2023
55457ec
Fix TS
MartinSchoeler Jan 31, 2023
5f783b5
Move some tests to EE for now
MartinSchoeler Feb 1, 2023
d4edfdf
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Feb 1, 2023
8535bd7
Use correct image
MartinSchoeler Feb 3, 2023
56be13d
Fix reviews on test
MartinSchoeler Feb 3, 2023
e1b7494
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Feb 3, 2023
dfa6298
Reviews
MartinSchoeler Feb 6, 2023
94a81ab
Review
MartinSchoeler Feb 6, 2023
0c107c2
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Feb 6, 2023
dd77129
update wording
MartinSchoeler Feb 6, 2023
fafaaeb
Merge branch 'move-save-department-ee' of https://github.com/RocketCh…
MartinSchoeler Feb 6, 2023
2f5007c
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Feb 7, 2023
1b6b47b
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Feb 7, 2023
6ea6659
Update raw model
KevLehman Feb 7, 2023
8422b8b
Merge branch 'move-save-department-ee' of github.com:RocketChat/Rocke…
KevLehman Feb 7, 2023
d39c13d
lint
MartinSchoeler Feb 7, 2023
0d3df9a
Remove empty line
MartinSchoeler Feb 7, 2023
ce5dab8
Small wording & link changes to modal
MartinSchoeler Feb 8, 2023
27f0d33
Merge branch 'develop' into move-save-department-ee
KevLehman Feb 8, 2023
fc420e0
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Feb 9, 2023
c77addb
[NEW] Department Archivation (#27966)
MartinSchoeler Feb 9, 2023
ca8a7ca
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Feb 9, 2023
6d059b2
Fix typo
MartinSchoeler Feb 10, 2023
d17a769
Merge branch 'develop' into move-save-department-ee
MartinSchoeler Feb 10, 2023
fafc64c
Fix reviews & pagination
MartinSchoeler Feb 10, 2023
680ad26
Merge branch 'move-save-department-ee' of https://github.com/RocketCh…
MartinSchoeler Feb 10, 2023
38c5694
Chore: Add archived department tests (#27992)
MartinSchoeler Feb 10, 2023
b5a75a5
Improve coverage
MartinSchoeler Feb 10, 2023
0ca3edc
Merge branch 'develop' of github.com:RocketChat/Rocket.Chat into move…
tassoevan Feb 11, 2023
679c67f
Refactor minor pet peeves
tassoevan Feb 11, 2023
0282109
Refactor minor pet peeves
tassoevan Feb 11, 2023
e199349
Refactor minor pet peeves
tassoevan Feb 11, 2023
d604602
Merge branch 'develop' into move-save-department-ee
murtaza98 Feb 13, 2023
d22906e
Fix error on edit forward
MartinSchoeler Feb 13, 2023
ebbfb21
Merge branch 'move-save-department-ee' of https://github.com/RocketCh…
MartinSchoeler Feb 13, 2023
cff00b7
Fix some reviews
MartinSchoeler Feb 13, 2023
b84d8ed
Merge branch 'develop' into move-save-department-ee
kodiakhq[bot] Feb 13, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
112 changes: 99 additions & 13 deletions apps/meteor/app/livechat/imports/server/rest/departments.ts
Original file line number Diff line number Diff line change
@@ -1,17 +1,19 @@
import { isGETLivechatDepartmentProps, isPOSTLivechatDepartmentProps } from '@rocket.chat/rest-typings';
import { Match, check } from 'meteor/check';
import { LivechatDepartment, LivechatDepartmentAgents } from '@rocket.chat/models';

import { API } from '../../../../api/server';
import { hasPermission } from '../../../../authorization/server';
import { LivechatDepartment, LivechatDepartmentAgents } from '../../../../models/server';
import { Livechat } from '../../../server/lib/Livechat';
import {
findDepartments,
findDepartmentById,
findDepartmentsToAutocomplete,
findDepartmentsBetweenIds,
findDepartmentAgents,
findArchivedDepartments,
} from '../../../server/api/lib/departments';
import { LivechatEnterprise } from '../../../../../ee/app/livechat-enterprise/server/lib/LivechatEnterprise';
import { DepartmentHelper } from '../../../server/lib/Departments';

API.v1.addRoute(
Expand All @@ -29,12 +31,13 @@ API.v1.addRoute(
const { offset, count } = this.getPaginationItems();
const { sort } = this.parseJsonQuery();

const { text, enabled, onlyMyDepartments, excludeDepartmentId } = this.queryParams;
const { text, enabled, onlyMyDepartments, excludeDepartmentId, showArchived } = this.queryParams;

const { departments, total } = await findDepartments({
userId: this.userId,
text,
enabled: enabled === 'true',
showArchived: showArchived === 'true',
onlyMyDepartments: onlyMyDepartments === 'true',
excludeDepartmentId,
pagination: {
Expand All @@ -55,12 +58,12 @@ API.v1.addRoute(
});

const agents = this.bodyParams.agents ? { upsert: this.bodyParams.agents } : {};
const department = Livechat.saveDepartment(null, this.bodyParams.department, agents);
const department = await LivechatEnterprise.saveDepartment(null, this.bodyParams.department, agents);

if (department) {
return API.v1.success({
department,
agents: LivechatDepartmentAgents.find({ departmentId: department._id }).fetch(),
agents: await LivechatDepartmentAgents.find({ departmentId: department._id }).toArray(),
});
}

Expand Down Expand Up @@ -118,7 +121,7 @@ API.v1.addRoute(

let success;
if (permissionToSave) {
success = Livechat.saveDepartment(_id, department);
success = await LivechatEnterprise.saveDepartment(_id, department);
}

if (success && agents && permissionToAddAgents) {
Expand All @@ -127,8 +130,8 @@ API.v1.addRoute(

if (success) {
return API.v1.success({
department: LivechatDepartment.findOneById(_id),
agents: LivechatDepartmentAgents.find({ departmentId: _id }).fetch(),
department: await LivechatDepartment.findOneById(_id),
agents: await LivechatDepartmentAgents.find({ departmentId: _id }).toArray(),
});
}

Expand All @@ -146,12 +149,79 @@ API.v1.addRoute(
},
);

API.v1.addRoute(
'livechat/departments/archived',
{
authRequired: true,
validateParams: { GET: isGETLivechatDepartmentProps },
permissionsRequired: {
GET: { permissions: ['view-livechat-departments', 'view-l-room'], operation: 'hasAny' },
},
},
{
async get() {
const { offset, count } = this.getPaginationItems();
const { sort } = this.parseJsonQuery();

const { text, onlyMyDepartments, excludeDepartmentId } = this.queryParams;

const { departments, total } = await findArchivedDepartments({
userId: this.userId,
text,
onlyMyDepartments: onlyMyDepartments === 'true',
excludeDepartmentId,
pagination: {
offset,
count,
sort: sort as any,
},
});

return API.v1.success({ departments, count: departments.length, offset, total });
},
},
);

API.v1.addRoute(
'livechat/department/:_id/archive',
{
authRequired: true,
permissionsRequired: ['manage-livechat-departments'],
},
{
async post() {
if (await Livechat.archiveDepartment(this.urlParams._id)) {
return API.v1.success();
}

return API.v1.failure();
},
},
);

API.v1.addRoute(
'livechat/department/:_id/unarchive',
{
authRequired: true,
permissionsRequired: ['manage-livechat-departments'],
},
{
async post() {
if (await Livechat.unarchiveDepartment(this.urlParams._id)) {
return API.v1.success();
}

return API.v1.failure();
},
},
);

API.v1.addRoute(
'livechat/department.autocomplete',
{ authRequired: true, permissionsRequired: { GET: { permissions: ['view-livechat-departments', 'view-l-room'], operation: 'hasAny' } } },
{
async get() {
const { selector, onlyMyDepartments } = this.queryParams;
const { selector, onlyMyDepartments, showArchived } = this.queryParams;
if (!selector) {
return API.v1.failure("The 'selector' param is required");
}
Expand All @@ -161,14 +231,15 @@ API.v1.addRoute(
uid: this.userId,
selector: JSON.parse(selector),
onlyMyDepartments: onlyMyDepartments === 'true',
showArchived: showArchived === 'true',
}),
);
},
},
);

API.v1.addRoute(
'livechat/department/:departmentId/agents',
'livechat/department/:_id/agents',
{
authRequired: true,
permissionsRequired: {
Expand All @@ -179,15 +250,15 @@ API.v1.addRoute(
{
async get() {
check(this.urlParams, {
departmentId: String,
_id: String,
});

const { offset, count } = this.getPaginationItems();
const { sort } = this.parseJsonQuery();

const agents = await findDepartmentAgents({
userId: this.userId,
departmentId: this.urlParams.departmentId,
departmentId: this.urlParams._id,
pagination: {
offset,
count,
Expand All @@ -199,7 +270,7 @@ API.v1.addRoute(
},
async post() {
check(this.urlParams, {
departmentId: String,
_id: String,
});

check(
Expand All @@ -209,7 +280,7 @@ API.v1.addRoute(
remove: Array,
}),
);
Livechat.saveDepartmentAgents(this.urlParams.departmentId, this.bodyParams);
Livechat.saveDepartmentAgents(this.urlParams._id, this.bodyParams);

return API.v1.success();
},
Expand Down Expand Up @@ -239,3 +310,18 @@ API.v1.addRoute(
},
},
);
API.v1.addRoute(
'livechat/department/isDepartmentCreationAvailable',
{
authRequired: true,
permissionsRequired: {
GET: { permissions: ['view-livechat-departments', 'manage-livechat-departments'], operation: 'hasAny' },
},
},
{
async get() {
const isDepartmentCreationAvailable = await LivechatEnterprise.isDepartmentCreationAvailable();
return API.v1.success({ isDepartmentCreationAvailable });
},
},
);
43 changes: 42 additions & 1 deletion apps/meteor/app/livechat/server/api/lib/departments.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ type FindDepartmentParams = {
text?: string;
enabled?: boolean;
excludeDepartmentId?: string;
showArchived?: boolean;
} & Pagination<ILivechatDepartmentRecord>;
type FindDepartmentByIdParams = {
userId: string;
Expand All @@ -29,6 +30,7 @@ type FindDepartmentToAutocompleteParams = {
term: string;
};
onlyMyDepartments?: boolean;
showArchived?: boolean;
};
type FindDepartmentAgentsParams = {
userId: string;
Expand All @@ -41,10 +43,12 @@ export async function findDepartments({
text,
enabled,
excludeDepartmentId,
showArchived = false,
pagination: { offset, count, sort },
}: FindDepartmentParams): Promise<PaginatedResult<{ departments: ILivechatDepartmentRecord[] }>> {
let query = {
$or: [{ type: { $eq: 'd' } }, { type: { $exists: false } }],
...(!showArchived && { archived: { $ne: !showArchived } }),
...(enabled && { enabled: Boolean(enabled) }),
...(text && { name: new RegExp(escapeRegExp(text), 'i') }),
...(excludeDepartmentId && { _id: { $ne: excludeDepartmentId } }),
Expand All @@ -70,6 +74,40 @@ export async function findDepartments({
};
}

export async function findArchivedDepartments({
userId,
onlyMyDepartments = false,
text,
excludeDepartmentId,
pagination: { offset, count, sort },
}: FindDepartmentParams): Promise<PaginatedResult<{ departments: ILivechatDepartmentRecord[] }>> {
let query = {
$or: [{ type: { $eq: 'd' } }, { type: { $exists: false } }],
archived: { $eq: true },
...(text && { name: new RegExp(escapeRegExp(text), 'i') }),
...(excludeDepartmentId && { _id: { $ne: excludeDepartmentId } }),
};

if (onlyMyDepartments) {
query = callbacks.run('livechat.applyDepartmentRestrictions', query, { userId });
}

const { cursor, totalCount } = LivechatDepartment.findPaginated(query, {
sort: sort || { name: 1 },
skip: offset,
limit: count,
});

const [departments, total] = await Promise.all([cursor.toArray(), totalCount]);

return {
departments,
count: departments.length,
offset,
total,
};
}

export async function findDepartmentById({
userId,
departmentId,
Expand Down Expand Up @@ -102,6 +140,7 @@ export async function findDepartmentsToAutocomplete({
uid,
selector,
onlyMyDepartments = false,
showArchived = false,
}: FindDepartmentToAutocompleteParams): Promise<{ items: ILivechatDepartmentRecord[] }> {
const { exceptions = [] } = selector;
let { conditions = {} } = selector;
Expand All @@ -110,7 +149,9 @@ export async function findDepartmentsToAutocomplete({
conditions = callbacks.run('livechat.applyDepartmentRestrictions', conditions, { userId: uid });
}

const items = await LivechatDepartment.findByNameRegexWithExceptionsAndConditions(selector.term, exceptions, conditions, {
const conditionsWithArchived = { archived: { $ne: !showArchived }, ...conditions };

const items = await LivechatDepartment.findByNameRegexWithExceptionsAndConditions(selector.term, exceptions, conditionsWithArchived, {
projection: {
_id: 1,
name: 1,
Expand Down
9 changes: 9 additions & 0 deletions apps/meteor/app/livechat/server/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -413,6 +413,15 @@ Meteor.startup(function () {
enableQuery: [{ _id: 'Livechat_enable_transcript', value: true }, omnichannelEnabledQuery],
});

this.add('Omnichannel_enable_department_removal', false, {
type: 'boolean',
group: 'Omnichannel',
public: true,
i18nLabel: 'Omnichannel_enable_department_removal',
alert: 'Omnichannel_enable_department_removal_alert',
enableQuery: omnichannelEnabledQuery,
});

this.add('Livechat_registration_form_message', '', {
type: 'string',
group: 'Omnichannel',
Expand Down
Loading