Compare commits
11 Commits
1bf75ed35c
...
395c6de2c6
| Author | SHA1 | Date | |
|---|---|---|---|
| 395c6de2c6 | |||
|
|
6a2e16e503 | ||
|
|
615c4353b8 | ||
|
|
19e1317e3a | ||
|
|
f32a3fd40f | ||
|
|
b1aae3304b | ||
|
|
6dba6fb1a9 | ||
|
|
f5f4d58321 | ||
|
|
eb572913eb | ||
|
|
85012058e5 | ||
|
|
97d9a95208 |
@@ -1,14 +1,20 @@
|
|||||||
import { Controller, Get } from '@nestjs/common';
|
import { Controller, Get } from '@nestjs/common';
|
||||||
import { AppService } from './app.service';
|
import { ApiTags, ApiOperation } from '@nestjs/swagger';
|
||||||
import { ApiExcludeEndpoint } from '@nestjs/swagger';
|
import { APP_VERSION } from './version';
|
||||||
|
|
||||||
@Controller()
|
@ApiTags('Main')
|
||||||
|
@Controller('v1')
|
||||||
export class AppController {
|
export class AppController {
|
||||||
constructor(private readonly appService: AppService) {}
|
@Get('version')
|
||||||
|
@ApiOperation({ summary: 'Get App Version' })
|
||||||
|
getVersion() {
|
||||||
|
return { version: APP_VERSION };
|
||||||
|
}
|
||||||
|
|
||||||
@Get()
|
@Get('health')
|
||||||
@ApiExcludeEndpoint()
|
@ApiOperation({ summary: 'Health check' })
|
||||||
getHello(): string {
|
healthCheck() {
|
||||||
return this.appService.getHello();
|
return { status: 'ok' };
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1637,6 +1637,9 @@ export class Pcclient {
|
|||||||
@Column({ name: 'CODSUBCATEGORIA' })
|
@Column({ name: 'CODSUBCATEGORIA' })
|
||||||
codsubcategoria: number;
|
codsubcategoria: number;
|
||||||
|
|
||||||
|
@Column({ name: 'TIPOENDERECO' })
|
||||||
|
tipoendereco: string;
|
||||||
|
|
||||||
@OneToMany(() => Pcnfsaid, notas => notas.pcclient)
|
@OneToMany(() => Pcnfsaid, notas => notas.pcclient)
|
||||||
notas: Pcnfsaid[];
|
notas: Pcnfsaid[];
|
||||||
|
|
||||||
|
|||||||
@@ -76,6 +76,9 @@ export class Pcclientendent {
|
|||||||
@Column({name: 'CODPAISRECEBEDOR'})
|
@Column({name: 'CODPAISRECEBEDOR'})
|
||||||
codpaisrecebedor: number;
|
codpaisrecebedor: number;
|
||||||
|
|
||||||
|
@Column({name: 'TIPOENDERECO'})
|
||||||
|
tipoendereco: string;
|
||||||
|
|
||||||
@OneToMany(() => Pcpedc, pedidos => pedidos.pcclientendent)
|
@OneToMany(() => Pcpedc, pedidos => pedidos.pcclientendent)
|
||||||
pedidos: Pcpedc[];
|
pedidos: Pcpedc[];
|
||||||
|
|
||||||
|
|||||||
@@ -23,5 +23,6 @@ export class Address {
|
|||||||
emailRecebedor: string;
|
emailRecebedor: string;
|
||||||
latitude: number;
|
latitude: number;
|
||||||
longitude: number;
|
longitude: number;
|
||||||
|
addressType?: string;
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -19,14 +19,16 @@ export class Customer {
|
|||||||
public category: Category,
|
public category: Category,
|
||||||
public subCategory: SubCategory,
|
public subCategory: SubCategory,
|
||||||
public place: Place,
|
public place: Place,
|
||||||
|
public placeId: number,
|
||||||
public sellerId: number,
|
public sellerId: number,
|
||||||
public ibgeCode: string,
|
public ibgeCode: string,
|
||||||
public birthdate: Date,
|
public birthdate?: Date,
|
||||||
public ramo: Ramo,
|
public ramo?: Ramo,
|
||||||
public communicate?: string,
|
public communicate?: string,
|
||||||
public idUser?: number,
|
public idUser?: number,
|
||||||
public latitude?: number,
|
public latitude?: number,
|
||||||
public longitude?: number,
|
public longitude?: number,
|
||||||
|
public addressType?: string,
|
||||||
){}
|
){}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -234,6 +234,7 @@ export class PartnerService {
|
|||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
data.place,
|
data.place,
|
||||||
|
data.place.id,
|
||||||
data.sellerId,
|
data.sellerId,
|
||||||
data.ibgeCode,
|
data.ibgeCode,
|
||||||
null,
|
null,
|
||||||
|
|||||||
@@ -37,6 +37,7 @@ export class AddressCustomerService {
|
|||||||
.addSelect('\"pcclientendent\".codpracaent', 'placeId')
|
.addSelect('\"pcclientendent\".codpracaent', 'placeId')
|
||||||
.addSelect('\"pcclientendent\".latitude', 'latitude')
|
.addSelect('\"pcclientendent\".latitude', 'latitude')
|
||||||
.addSelect('\"pcclientendent\".longitude', 'longitude')
|
.addSelect('\"pcclientendent\".longitude', 'longitude')
|
||||||
|
.addSelect('\"pcclientendent\".tipoendereco', 'addressType')
|
||||||
.where("\"pcclientendent\".codcli = :idCustomer", { idCustomer })
|
.where("\"pcclientendent\".codcli = :idCustomer", { idCustomer })
|
||||||
.getRawMany();
|
.getRawMany();
|
||||||
return new ResultModel(true, null, addresses, null);
|
return new ResultModel(true, null, addresses, null);
|
||||||
@@ -79,6 +80,7 @@ export class AddressCustomerService {
|
|||||||
' ,pcclientendent.codpracaent as "placeId" ' +
|
' ,pcclientendent.codpracaent as "placeId" ' +
|
||||||
' ,pcclientendent.latitude as "latitude" ' +
|
' ,pcclientendent.latitude as "latitude" ' +
|
||||||
' ,pcclientendent.longitude as "longitude" ' +
|
' ,pcclientendent.longitude as "longitude" ' +
|
||||||
|
' ,pcclientendent.tipoendereco as "addressType" ' +
|
||||||
' FROM pcclientendent ' +
|
' FROM pcclientendent ' +
|
||||||
' WHERE pcclientendent.codcli = :idCustomer ' +
|
' WHERE pcclientendent.codcli = :idCustomer ' +
|
||||||
' AND pcclientendent.codendentcli = :idAddress ';
|
' AND pcclientendent.codendentcli = :idAddress ';
|
||||||
@@ -122,6 +124,7 @@ export class AddressCustomerService {
|
|||||||
' ,pcclientendent.codpracaent as "placeId" ' +
|
' ,pcclientendent.codpracaent as "placeId" ' +
|
||||||
' ,pcclientendent.latitude as "latitude" ' +
|
' ,pcclientendent.latitude as "latitude" ' +
|
||||||
' ,pcclientendent.longitude as "longitude" ' +
|
' ,pcclientendent.longitude as "longitude" ' +
|
||||||
|
' ,pcclientendent.tipoendereco as "addressType" ' +
|
||||||
' FROM pcclientendent ' +
|
' FROM pcclientendent ' +
|
||||||
' WHERE pcclientendent.codcli = :idCustomer ' +
|
' WHERE pcclientendent.codcli = :idCustomer ' +
|
||||||
" AND REGEXP_REPLACE(pcclientendent.cepent, '[^0-9]', '') = REGEXP_REPLACE(:cepent, '[^0-9]', '')";
|
" AND REGEXP_REPLACE(pcclientendent.cepent, '[^0-9]', '') = REGEXP_REPLACE(:cepent, '[^0-9]', '')";
|
||||||
@@ -183,6 +186,7 @@ export class AddressCustomerService {
|
|||||||
emailRecebedor: customer[0].email,
|
emailRecebedor: customer[0].email,
|
||||||
latitude: ( data.latitude ) ? data.latitude.toString() : '0',
|
latitude: ( data.latitude ) ? data.latitude.toString() : '0',
|
||||||
longitude:( data.longitude ) ? data.longitude.toString() : '0',
|
longitude:( data.longitude ) ? data.longitude.toString() : '0',
|
||||||
|
tipoendereco: data.addressType
|
||||||
})
|
})
|
||||||
.where("\"PCCLIENTENDENT\".codcli = :codcli and \"PCCLIENTENDENT\".codendentcli = :codendentcli",
|
.where("\"PCCLIENTENDENT\".codcli = :codcli and \"PCCLIENTENDENT\".codendentcli = :codendentcli",
|
||||||
{ codcli: data.idCustomer, codendentcli: data.idAddress })
|
{ codcli: data.idCustomer, codendentcli: data.idAddress })
|
||||||
@@ -250,6 +254,7 @@ export class AddressCustomerService {
|
|||||||
newPcclientendent.emailRecebedor = customer.email;
|
newPcclientendent.emailRecebedor = customer.email;
|
||||||
newPcclientendent.latitude = ( data.latitude ) ? data.latitude.toString() : '0';
|
newPcclientendent.latitude = ( data.latitude ) ? data.latitude.toString() : '0';
|
||||||
newPcclientendent.longitude = ( data.longitude ) ? data.longitude.toString() : '0';
|
newPcclientendent.longitude = ( data.longitude ) ? data.longitude.toString() : '0';
|
||||||
|
newPcclientendent.tipoendereco = data.addressType;
|
||||||
|
|
||||||
await queryRunner.manager
|
await queryRunner.manager
|
||||||
.createQueryBuilder()
|
.createQueryBuilder()
|
||||||
@@ -257,6 +262,7 @@ export class AddressCustomerService {
|
|||||||
.into(Pcclientendent)
|
.into(Pcclientendent)
|
||||||
.values(newPcclientendent)
|
.values(newPcclientendent)
|
||||||
.execute();
|
.execute();
|
||||||
|
|
||||||
const newAddress: Address = {
|
const newAddress: Address = {
|
||||||
idCustomer: data.idCustomer,
|
idCustomer: data.idCustomer,
|
||||||
idAddress: id,
|
idAddress: id,
|
||||||
@@ -282,6 +288,7 @@ export class AddressCustomerService {
|
|||||||
emailRecebedor: customer.email,
|
emailRecebedor: customer.email,
|
||||||
latitude: data.latitude,
|
latitude: data.latitude,
|
||||||
longitude: data.longitude,
|
longitude: data.longitude,
|
||||||
|
addressType: data.addressType,
|
||||||
}
|
}
|
||||||
|
|
||||||
return newAddress;
|
return newAddress;
|
||||||
|
|||||||
@@ -49,6 +49,7 @@ export class CustomerService {
|
|||||||
' ,pcclient.longitude as "longitude" ' +
|
' ,pcclient.longitude as "longitude" ' +
|
||||||
' ,pcclient.codmunicipio as "ibgeCode" ' +
|
' ,pcclient.codmunicipio as "ibgeCode" ' +
|
||||||
' ,pcclient.codcidade as "cityId" ' +
|
' ,pcclient.codcidade as "cityId" ' +
|
||||||
|
' ,pcclient.tipoendereco as "addressType" ' +
|
||||||
' FROM pcclient, pccidade ' +
|
' FROM pcclient, pccidade ' +
|
||||||
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
||||||
let where = ` AND ( pcclient.cliente like '%'||'${auxName.replace('@', '%')}'||'%' OR ` +
|
let where = ` AND ( pcclient.cliente like '%'||'${auxName.replace('@', '%')}'||'%' OR ` +
|
||||||
@@ -59,7 +60,18 @@ export class CustomerService {
|
|||||||
const pagination = ` OFFSET 0 ROWS FETCH NEXT 100 ROWS ONLY`;
|
const pagination = ` OFFSET 0 ROWS FETCH NEXT 100 ROWS ONLY`;
|
||||||
const customers = await queryRunner.manager
|
const customers = await queryRunner.manager
|
||||||
.query(sql + where + orderBy + pagination) as Customer[];
|
.query(sql + where + orderBy + pagination) as Customer[];
|
||||||
return customers;
|
let customerList: Customer[] = [];
|
||||||
|
for (let i = 0; i < customers.length; i++) {
|
||||||
|
let customer = customers[i];
|
||||||
|
const place = await queryRunner.query(`SELECT PCPRACA.CODPRACA as "placeId"
|
||||||
|
,PCPRACA.PRACA as "name"
|
||||||
|
FROM PCPRACA
|
||||||
|
WHERE PCPRACA.CODPRACA = ${customer.placeId}`);
|
||||||
|
|
||||||
|
customer.place = place[0];
|
||||||
|
customerList.push(customer);
|
||||||
|
}
|
||||||
|
return customerList;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.log(error);
|
console.log(error);
|
||||||
throw error;
|
throw error;
|
||||||
@@ -102,6 +114,7 @@ export class CustomerService {
|
|||||||
' ,pcclient.longitude as "longitude" ' +
|
' ,pcclient.longitude as "longitude" ' +
|
||||||
' ,pcclient.codmunicipio as "ibgeCode" ' +
|
' ,pcclient.codmunicipio as "ibgeCode" ' +
|
||||||
' ,pcclient.codcidade as "cityId" ' +
|
' ,pcclient.codcidade as "cityId" ' +
|
||||||
|
' ,pcclient.tipoendereco as "addressType" ' +
|
||||||
' FROM pcclient, pccidade ' +
|
' FROM pcclient, pccidade ' +
|
||||||
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
||||||
const where = ` AND REGEXP_REPLACE(pcclient.cgcent, '[^0-9]', '') =REGEXP_REPLACE('${cpf}', '[^0-9]', '')`;
|
const where = ` AND REGEXP_REPLACE(pcclient.cgcent, '[^0-9]', '') =REGEXP_REPLACE('${cpf}', '[^0-9]', '')`;
|
||||||
@@ -150,11 +163,17 @@ export class CustomerService {
|
|||||||
' ,pcclient.longitude as "longitude" ' +
|
' ,pcclient.longitude as "longitude" ' +
|
||||||
' ,pcclient.codmunicipio as "ibgeCode" ' +
|
' ,pcclient.codmunicipio as "ibgeCode" ' +
|
||||||
' ,pcclient.codcidade as "cityId" ' +
|
' ,pcclient.codcidade as "cityId" ' +
|
||||||
|
' ,pcclient.tipoendereco as "addressType" ' +
|
||||||
' FROM pcclient, pccidade ' +
|
' FROM pcclient, pccidade ' +
|
||||||
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
||||||
const where = ` AND pcclient.codcli = ${idCustomer}`;
|
const where = ` AND pcclient.codcli = ${idCustomer}`;
|
||||||
const customer = await queryRunner.query(sql + where);
|
const customer = await queryRunner.query(sql + where);
|
||||||
return customer[0];
|
const place = await queryRunner.query(`SELECT PCPRACA.CODPRACA as "placeId"
|
||||||
|
,PCPRACA.PRACA as "name"
|
||||||
|
FROM PCPRACA
|
||||||
|
WHERE PCPRACA.CODPRACA = ${customer[0].placeId}`);
|
||||||
|
|
||||||
|
return {...customer[0], place: place[0]};
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.log(error);
|
console.log(error);
|
||||||
throw error;
|
throw error;
|
||||||
@@ -216,6 +235,7 @@ export class CustomerService {
|
|||||||
.addSelect("\"pcclient\".longitude as \"longitude\"")
|
.addSelect("\"pcclient\".longitude as \"longitude\"")
|
||||||
.addSelect("\"pcclient\".codmunicipio as \"ibgeCode\"")
|
.addSelect("\"pcclient\".codmunicipio as \"ibgeCode\"")
|
||||||
.addSelect("\"pcclient\".codcidade as \"cityId\"")
|
.addSelect("\"pcclient\".codcidade as \"cityId\"")
|
||||||
|
.addSelect("\"pcclient\".esc_tipoeclieente as \"addressType\"")
|
||||||
.where(where)
|
.where(where)
|
||||||
.andWhere("\"pcclient\".CODCLI NOT IN (2) AND \"pcclient\".DTEXCLUSAO IS NULL")
|
.andWhere("\"pcclient\".CODCLI NOT IN (2) AND \"pcclient\".DTEXCLUSAO IS NULL")
|
||||||
.getRawMany();
|
.getRawMany();
|
||||||
@@ -304,6 +324,7 @@ export class CustomerService {
|
|||||||
newCustomer.dtultalter = new Date();
|
newCustomer.dtultalter = new Date();
|
||||||
newCustomer.latitude = customer.latitude;
|
newCustomer.latitude = customer.latitude;
|
||||||
newCustomer.longitude = customer.longitude;
|
newCustomer.longitude = customer.longitude;
|
||||||
|
newCustomer.tipoendereco = customer.addressType;
|
||||||
|
|
||||||
const oldCustomer = await this.findCustomerByCpf(newCustomer.cgcent);
|
const oldCustomer = await this.findCustomerByCpf(newCustomer.cgcent);
|
||||||
if (oldCustomer) {
|
if (oldCustomer) {
|
||||||
@@ -321,7 +342,8 @@ export class CustomerService {
|
|||||||
allowMessage: customer.allowMessage, cellPhone: customer.cellPhone,
|
allowMessage: customer.allowMessage, cellPhone: customer.cellPhone,
|
||||||
category: customer.category, subCategory: customer.subCategory,
|
category: customer.category, subCategory: customer.subCategory,
|
||||||
place: customer.place, ramo: customer.ramo, meiocomunicacao: customer.communicate,
|
place: customer.place, ramo: customer.ramo, meiocomunicacao: customer.communicate,
|
||||||
latitude: customer.latitude, longitude: customer.longitude, ibgeCode: customer.ibgeCode
|
latitude: customer.latitude, longitude: customer.longitude, ibgeCode: customer.ibgeCode,
|
||||||
|
addressType: customer.addressType,
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
const idCustomer = await this.generateIdCustomer();
|
const idCustomer = await this.generateIdCustomer();
|
||||||
@@ -340,7 +362,8 @@ export class CustomerService {
|
|||||||
allowMessage: customer.allowMessage, cellPhone: customer.cellPhone,
|
allowMessage: customer.allowMessage, cellPhone: customer.cellPhone,
|
||||||
category: customer.category, subCategory: customer.subCategory,
|
category: customer.category, subCategory: customer.subCategory,
|
||||||
place: customer.place, meiocomunicacao: customer.communicate,
|
place: customer.place, meiocomunicacao: customer.communicate,
|
||||||
ramo: customer.ramo, latitude: customer.latitude, longitude: customer.longitude, ibgeCode: customer.ibgeCode
|
ramo: customer.ramo, latitude: customer.latitude, longitude: customer.longitude,
|
||||||
|
ibgeCode: customer.ibgeCode, addressType: customer.addressType,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
@@ -401,6 +424,7 @@ export class CustomerService {
|
|||||||
dtultalter: client.dtultalter,
|
dtultalter: client.dtultalter,
|
||||||
latitude: client.latitude,
|
latitude: client.latitude,
|
||||||
longitude: client.longitude,
|
longitude: client.longitude,
|
||||||
|
tipoendereco: client.tipoendereco
|
||||||
})
|
})
|
||||||
.where({ codcli: client.codcli })
|
.where({ codcli: client.codcli })
|
||||||
.execute();
|
.execute();
|
||||||
|
|||||||
@@ -176,6 +176,20 @@ export class SalesController {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Get('product/simil/:id')
|
||||||
|
@ApiOperation({ summary: 'Get products similar' })
|
||||||
|
@ApiParam({ name: 'id', description: 'Product ID' })
|
||||||
|
async getProductSimil(@Headers() headers, @Param('id') id: number) {
|
||||||
|
try {
|
||||||
|
const { store } = this.extractPaginationParams(headers);
|
||||||
|
return await this.salesService.GetProductsSimil(store, id);
|
||||||
|
} catch (e) {
|
||||||
|
throw new HttpException(e.message, HttpStatus.BAD_REQUEST);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Get('stock/:storeid/:id')
|
@Get('stock/:storeid/:id')
|
||||||
@ApiOperation({ summary: 'Get product stock information' })
|
@ApiOperation({ summary: 'Get product stock information' })
|
||||||
@ApiParam({ name: 'storeid', description: 'Store ID' })
|
@ApiParam({ name: 'storeid', description: 'Store ID' })
|
||||||
|
|||||||
@@ -77,7 +77,9 @@ export class SalesService {
|
|||||||
esvlistaprodutos.LETRABASETINTOMETRICO as "letter",
|
esvlistaprodutos.LETRABASETINTOMETRICO as "letter",
|
||||||
esvlistaprodutos.LINHATINTOMETRICO as "line",
|
esvlistaprodutos.LINHATINTOMETRICO as "line",
|
||||||
esvlistaprodutos.LITRAGEM as "can",
|
esvlistaprodutos.LITRAGEM as "can",
|
||||||
esvlistaprodutos.QUANTIDADE_ESTOQUE_GERAL as "full_stock"
|
esvlistaprodutos.QUANTIDADE_ESTOQUE_GERAL as "full_stock",
|
||||||
|
esvlistaprodutos.TEM_PRODUTO_SIMILAR as "similar",
|
||||||
|
NVL(esvlistaprodutos.TIPO, 'SEM') as "type_campaing"
|
||||||
FROM ESVLISTAPRODUTOS
|
FROM ESVLISTAPRODUTOS
|
||||||
WHERE 1 = 1 `;
|
WHERE 1 = 1 `;
|
||||||
|
|
||||||
@@ -127,6 +129,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
||||||
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("UPPER(\"esvlistaprodutos\".CODFAB) LIKE '%'||REPLACE(:description, '@', '%')||'%'", { description })
|
.where("UPPER(\"esvlistaprodutos\".CODFAB) LIKE '%'||REPLACE(:description, '@', '%')||'%'", { description })
|
||||||
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||||
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
||||||
@@ -184,6 +188,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
||||||
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("UPPER(\"esvlistaprodutos\".descricao) LIKE '%'||REPLACE(:description, '@', '%')||'%'", { description })
|
.where("UPPER(\"esvlistaprodutos\".descricao) LIKE '%'||REPLACE(:description, '@', '%')||'%'", { description })
|
||||||
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||||
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
||||||
@@ -260,6 +266,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
||||||
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("esvlistaprodutos.brand in (" + xbrands + ")")
|
.where("esvlistaprodutos.brand in (" + xbrands + ")")
|
||||||
.andWhere("\"esvlistaprodutos\".URLCATEGORIA LIKE :urlCategoria||'%'", { urlCategoria: filter.urlCategory })
|
.andWhere("\"esvlistaprodutos\".URLCATEGORIA LIKE :urlCategoria||'%'", { urlCategoria: filter.urlCategory })
|
||||||
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||||
@@ -324,6 +332,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
||||||
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
.where("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||||
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
||||||
{ produtoComReducaoPreco: (filter.markdown.toString() == 'true') ? 'S' : 'N' })
|
{ produtoComReducaoPreco: (filter.markdown.toString() == 'true') ? 'S' : 'N' })
|
||||||
@@ -562,6 +572,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||||
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("esvlistaprodutos.idProduct = :id", { id: numbers })
|
.where("esvlistaprodutos.idProduct = :id", { id: numbers })
|
||||||
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
||||||
.limit(pageSize)
|
.limit(pageSize)
|
||||||
@@ -609,6 +621,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||||
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("esvlistaprodutos.CODAUXILIAR = :id", { id: numbers })
|
.where("esvlistaprodutos.CODAUXILIAR = :id", { id: numbers })
|
||||||
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||||
.limit(pageSize)
|
.limit(pageSize)
|
||||||
@@ -658,6 +672,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||||
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("UPPER(esvlistaprodutos.CODFAB) like REPLACE(:description, '@', '%')", { description })
|
.where("UPPER(esvlistaprodutos.CODFAB) like REPLACE(:description, '@', '%')", { description })
|
||||||
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
||||||
.limit(pageSize)
|
.limit(pageSize)
|
||||||
@@ -704,6 +720,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||||
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("UPPER(esvlistaprodutos.DESCRICAO) like REPLACE(:description, '@', '%')", { description })
|
.where("UPPER(esvlistaprodutos.DESCRICAO) like REPLACE(:description, '@', '%')", { description })
|
||||||
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
||||||
.limit(pageSize)
|
.limit(pageSize)
|
||||||
@@ -773,6 +791,8 @@ export class SalesService {
|
|||||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||||
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
||||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||||
|
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||||
.where("esvlistaprodutos.idProduct = :id", { id: id })
|
.where("esvlistaprodutos.idProduct = :id", { id: id })
|
||||||
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial", { codfilial: store })
|
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial", { codfilial: store })
|
||||||
.orderBy("REPLACE(\"esvlistaprodutos\".DESCRICAO,'#', '')", "ASC")
|
.orderBy("REPLACE(\"esvlistaprodutos\".DESCRICAO,'#', '')", "ASC")
|
||||||
@@ -834,6 +854,8 @@ export class SalesService {
|
|||||||
,esvlistaprodutos.PRODUTO_EM_CAMPANHA as "compaing"
|
,esvlistaprodutos.PRODUTO_EM_CAMPANHA as "compaing"
|
||||||
,esvlistaprodutos.BASETINTOMETRICO as "base"
|
,esvlistaprodutos.BASETINTOMETRICO as "base"
|
||||||
,esvlistaprodutos.QUANTIDADE_ESTOQUE_GERAL as "full_stock"
|
,esvlistaprodutos.QUANTIDADE_ESTOQUE_GERAL as "full_stock"
|
||||||
|
,esvlistaprodutos.TEM_PRODUTO_SIMILAR as "similar"
|
||||||
|
,esvlistaprodutos.TIPO_CAMPANHA as "type_campaing"
|
||||||
FROM ESVLISTAPRODUTOS, ESTCOMPREJUNTO
|
FROM ESVLISTAPRODUTOS, ESTCOMPREJUNTO
|
||||||
WHERE ESVLISTAPRODUTOS.CODPROD = ESTCOMPREJUNTO.CODPROD
|
WHERE ESVLISTAPRODUTOS.CODPROD = ESTCOMPREJUNTO.CODPROD
|
||||||
AND ESTCOMPREJUNTO.CODPRODVENDA = ${id}
|
AND ESTCOMPREJUNTO.CODPRODVENDA = ${id}
|
||||||
@@ -851,6 +873,68 @@ export class SalesService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async GetProductsSimil(store: string, id: number) {
|
||||||
|
const connectionDb = new Connection(connectionOptions);
|
||||||
|
await connectionDb.connect();
|
||||||
|
const queryRunner = connectionDb.createQueryRunner();
|
||||||
|
await queryRunner.connect();
|
||||||
|
try {
|
||||||
|
const sql = `SELECT esvlistaprodutos.CODPROD as "idProduct"
|
||||||
|
,esvlistaprodutos.SEQ as "seq"
|
||||||
|
,esvlistaprodutos.DESCRICAO as "smallDescription"
|
||||||
|
,esvlistaprodutos.NOMEECOMMERCE as "title"
|
||||||
|
,esvlistaprodutos.CODFAB as "idProvider"
|
||||||
|
,esvlistaprodutos.CODAUXILIAR as "ean"
|
||||||
|
,esvlistaprodutos.TIPOPRODUTO as "productType"
|
||||||
|
,esvlistaprodutos.DADOSTECNICOS as "technicalData"
|
||||||
|
,esvlistaprodutos.INFORMACOESTECNICAS as "description"
|
||||||
|
,esvlistaprodutos.URLIMAGEM as "urlImage"
|
||||||
|
,esvlistaprodutos.NOMEMARCA as "brand"
|
||||||
|
,esvlistaprodutos.NOMEDEPARTAMENTO as "department"
|
||||||
|
,esvlistaprodutos.NOMESECAO as "section"
|
||||||
|
,esvlistaprodutos.NOMECATEGORIA as "category"
|
||||||
|
,esvlistaprodutos.NOMEFORNECEDOR as "supplier"
|
||||||
|
,esvlistaprodutos.CODIGOFILIAL as "store"
|
||||||
|
,esvlistaprodutos.CLASSEVENDA as "saleAbc"
|
||||||
|
,esvlistaprodutos.CLASSEESTOQUE as "stockAbc"
|
||||||
|
,esvlistaprodutos.FORALINHA as "outLine"
|
||||||
|
,esvlistaprodutos.PRECOVENDA as "listPrice"
|
||||||
|
,esvlistaprodutos.PRECOPROMOCIONAL as "salePrice"
|
||||||
|
,esvlistaprodutos.PRECOPROMOCIONAL as "salePromotion"
|
||||||
|
,esvlistaprodutos.PERCENTUALDESCONTO as"offPercent"
|
||||||
|
,esvlistaprodutos.QTESTOQUE_DISPONIVEL as "stock"
|
||||||
|
,esvlistaprodutos.QTCAIXAS as "boxStock"
|
||||||
|
,esvlistaprodutos.ESTOQUE_DISP_LOJA as "store_stock"
|
||||||
|
,esvlistaprodutos.ESTOQUE_DISP_CAIXA_LOJA as "store_boxStock"
|
||||||
|
,esvlistaprodutos.ESTOQUE_DISP_LOJA as "store_stock"
|
||||||
|
,esvlistaprodutos.ESTOQUE_DISP_CAIXA_LOJA as "store_boxStock"
|
||||||
|
,esvlistaprodutos.MULTIPLO as "mutiple"
|
||||||
|
,esvlistaprodutos.UNIDADE as "unity"
|
||||||
|
,esvlistaprodutos.URLDEPARTAMENTO as "urlDepartment"
|
||||||
|
,esvlistaprodutos.URLSECAO as "urlSection"
|
||||||
|
,esvlistaprodutos.PRODUTO_COM_REDUCAO_PRECO as "downPrice"
|
||||||
|
,esvlistaprodutos.PRODUTO_EM_CAMPANHA as "compaing"
|
||||||
|
,esvlistaprodutos.BASETINTOMETRICO as "base"
|
||||||
|
,esvlistaprodutos.QUANTIDADE_ESTOQUE_GERAL as "full_stock"
|
||||||
|
,esvlistaprodutos.TEM_PRODUTO_SIMILAR as "similar"
|
||||||
|
,esvlistaprodutos.TIPO_CAMPANHA as "type_campaing"
|
||||||
|
FROM ESVLISTAPRODUTOS, PCPRODSIMIL
|
||||||
|
WHERE ESVLISTAPRODUTOS.CODPROD = PCPRODSIMIL.CODSIMIL
|
||||||
|
AND PCPRODSIMIL.CODPROD = ${id}
|
||||||
|
AND ESVLISTAPRODUTOS.CODFILIAL = '${store}'
|
||||||
|
ORDER BY REPLACE(esvlistaprodutos.DESCRICAO,'#', '')`;
|
||||||
|
let products: SalesProduct[] = await queryRunner.query(sql);
|
||||||
|
|
||||||
|
products = this.createListImages(products);
|
||||||
|
return products;
|
||||||
|
} catch (error) {
|
||||||
|
throw error;
|
||||||
|
} finally {
|
||||||
|
await queryRunner.release();
|
||||||
|
await connectionDb.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
async GetStocks(storeId: string, id: number) {
|
async GetStocks(storeId: string, id: number) {
|
||||||
const connectionDb = new Connection(connectionOptions);
|
const connectionDb = new Connection(connectionOptions);
|
||||||
await connectionDb.connect();
|
await connectionDb.connect();
|
||||||
@@ -1265,6 +1349,8 @@ export class SalesService {
|
|||||||
' ,esvlistaprodutos.LINHATINTOMETRICO "line" ' +
|
' ,esvlistaprodutos.LINHATINTOMETRICO "line" ' +
|
||||||
' ,esvlistaprodutos.LITRAGEM "can" ' +
|
' ,esvlistaprodutos.LITRAGEM "can" ' +
|
||||||
' ,esvlistaprodutos.QUANTIDADE_ESTOQUE_GERAL "full_stock" ' +
|
' ,esvlistaprodutos.QUANTIDADE_ESTOQUE_GERAL "full_stock" ' +
|
||||||
|
' ,esvlistaprodutos.TEM_PRODUTO_SIMILAR "similar" ' +
|
||||||
|
' ,esvlistaprodutos.TIPO_CAMPANHA "type_campaing" ' +
|
||||||
' FROM esvlistaprodutos ' +
|
' FROM esvlistaprodutos ' +
|
||||||
' WHERE 1 = 1 ';
|
' WHERE 1 = 1 ';
|
||||||
|
|
||||||
|
|||||||
1
src/version.ts
Normal file
1
src/version.ts
Normal file
@@ -0,0 +1 @@
|
|||||||
|
export const APP_VERSION = 'v1.1.0';
|
||||||
Reference in New Issue
Block a user