202 lines
4.0 KiB
TypeScript
202 lines
4.0 KiB
TypeScript
import { PrismaClient } from '@prisma/client';
|
|
|
|
export const seedViews = async (prisma: PrismaClient) => {
|
|
const workspaceId = 'twenty-7ed9d212-1c25-4d02-bf25-6aeccf7ea419';
|
|
const companyViewId = 'twenty-5e924b69-a619-41bf-bd31-a9e8551fc9d1';
|
|
const personViewId = 'twenty-db9e6c85-c091-4fd6-88b1-c1830f5e90d1';
|
|
const opportunitiesViewId = 'twenty-6abb47a2-7a91-4679-a538-59946f0c06a9';
|
|
|
|
await prisma.view.upsert({
|
|
where: { id: companyViewId },
|
|
update: {},
|
|
create: {
|
|
id: companyViewId,
|
|
name: 'All Companies',
|
|
objectId: 'company',
|
|
type: 'Table',
|
|
workspaceId,
|
|
},
|
|
});
|
|
|
|
await Promise.all(
|
|
[
|
|
{
|
|
key: 'name',
|
|
name: 'Name',
|
|
size: 180,
|
|
},
|
|
{
|
|
key: 'domainName',
|
|
name: 'URL',
|
|
size: 100,
|
|
},
|
|
{
|
|
key: 'accountOwner',
|
|
name: 'Account Owner',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'createdAt',
|
|
name: 'Creation',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'employees',
|
|
name: 'Employees',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'linkedin',
|
|
name: 'LinkedIn',
|
|
size: 170,
|
|
},
|
|
{
|
|
key: 'address',
|
|
name: 'Address',
|
|
size: 170,
|
|
},
|
|
{
|
|
key: 'annualRecurringRevenue',
|
|
name: 'ARR',
|
|
size: 150,
|
|
},
|
|
].map((viewField, index) =>
|
|
prisma.viewField.upsert({
|
|
where: { viewId_key: { key: viewField.key, viewId: companyViewId } },
|
|
update: {},
|
|
create: {
|
|
...viewField,
|
|
index,
|
|
isVisible: true,
|
|
objectId: 'company',
|
|
viewId: companyViewId,
|
|
workspaceId,
|
|
},
|
|
}),
|
|
),
|
|
);
|
|
|
|
await prisma.view.upsert({
|
|
where: { id: personViewId },
|
|
update: {},
|
|
create: {
|
|
id: personViewId,
|
|
name: 'All People',
|
|
objectId: 'person',
|
|
type: 'Table',
|
|
workspaceId,
|
|
},
|
|
});
|
|
|
|
await Promise.all(
|
|
[
|
|
{
|
|
key: 'displayName',
|
|
name: 'People',
|
|
size: 210,
|
|
},
|
|
{
|
|
key: 'email',
|
|
name: 'Email',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'company',
|
|
name: 'Company',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'phone',
|
|
name: 'Phone',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'createdAt',
|
|
name: 'Creation',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'city',
|
|
name: 'City',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'jobTitle',
|
|
name: 'Job title',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'linkedin',
|
|
name: 'LinkedIn',
|
|
size: 150,
|
|
},
|
|
{
|
|
key: 'x',
|
|
name: 'Twitter',
|
|
size: 150,
|
|
},
|
|
].map((viewField, index) =>
|
|
prisma.viewField.upsert({
|
|
where: { viewId_key: { key: viewField.key, viewId: personViewId } },
|
|
update: {},
|
|
create: {
|
|
...viewField,
|
|
index,
|
|
isVisible: true,
|
|
objectId: 'person',
|
|
viewId: personViewId,
|
|
workspaceId,
|
|
},
|
|
}),
|
|
),
|
|
);
|
|
|
|
await prisma.view.upsert({
|
|
where: { id: opportunitiesViewId },
|
|
update: {},
|
|
create: {
|
|
id: opportunitiesViewId,
|
|
name: 'All Opportunities',
|
|
objectId: 'company',
|
|
type: 'Pipeline',
|
|
workspaceId,
|
|
},
|
|
});
|
|
|
|
await Promise.all(
|
|
[
|
|
{
|
|
key: 'closeDate',
|
|
name: 'Close Date',
|
|
},
|
|
{
|
|
key: 'amount',
|
|
name: 'Amount',
|
|
},
|
|
{
|
|
key: 'probability',
|
|
name: 'Probability',
|
|
},
|
|
{
|
|
key: 'pointOfContact',
|
|
name: 'Point of Contact',
|
|
},
|
|
].map((viewField, index) =>
|
|
prisma.viewField.upsert({
|
|
where: {
|
|
viewId_key: { key: viewField.key, viewId: opportunitiesViewId },
|
|
},
|
|
update: {},
|
|
create: {
|
|
...viewField,
|
|
index,
|
|
isVisible: true,
|
|
objectId: 'company',
|
|
viewId: opportunitiesViewId,
|
|
workspaceId,
|
|
},
|
|
}),
|
|
),
|
|
);
|
|
};
|