Compare commits
12 Commits
97d9a95208
...
757d547755
| Author | SHA1 | Date |
|---|---|---|
|
|
757d547755 | |
|
|
79fb04fdb5 | |
|
|
94fcbe9b39 | |
|
|
6a2e16e503 | |
|
|
615c4353b8 | |
|
|
19e1317e3a | |
|
|
f32a3fd40f | |
|
|
b1aae3304b | |
|
|
6dba6fb1a9 | |
|
|
f5f4d58321 | |
|
|
eb572913eb | |
|
|
85012058e5 |
|
|
@ -33,3 +33,5 @@ lerna-debug.log*
|
|||
!.vscode/launch.json
|
||||
!.vscode/extensions.json
|
||||
|
||||
postgres-data/
|
||||
.env
|
||||
|
|
|
|||
47
Dockerfile
47
Dockerfile
|
|
@ -1,32 +1,37 @@
|
|||
FROM node:16
|
||||
# Estágio 1: Build
|
||||
FROM node:16-bullseye-slim AS builder
|
||||
|
||||
WORKDIR /app
|
||||
COPY package*.json ./
|
||||
RUN npm install --legacy-peer-deps
|
||||
COPY . .
|
||||
RUN npm run build
|
||||
|
||||
FROM node:16-bullseye-slim
|
||||
# Instalar dependências do Oracle
|
||||
RUN apt-get update && apt-get install -y \
|
||||
apt-transport-https \
|
||||
ca-certificates \
|
||||
libaio1 \
|
||||
unzip \
|
||||
wget \
|
||||
libc6 \
|
||||
libncurses5 && \
|
||||
mkdir -p /opt/oracle && \
|
||||
wget https://download.oracle.com/otn_software/linux/instantclient/instantclient-basic-linuxx64.zip -O /opt/oracle/instantclient-basic-linuxx64.zip && \
|
||||
unzip /opt/oracle/instantclient-basic-linuxx64.zip -d /opt/oracle && \
|
||||
rm /opt/oracle/instantclient-basic-linuxx64.zip && \
|
||||
ln -s /opt/oracle/instantclient_* /opt/oracle/instantclient && \
|
||||
echo "/opt/oracle/instantclient" > /etc/ld.so.conf.d/oracle-instantclient.conf && \
|
||||
ldconfig
|
||||
&& mkdir -p /opt/oracle
|
||||
|
||||
# Instalar Oracle Instant Client
|
||||
RUN wget https://download.oracle.com/otn_software/linux/instantclient/instantclient-basic-linuxx64.zip -O /opt/oracle/client.zip && \
|
||||
unzip /opt/oracle/client.zip -d /opt/oracle && \
|
||||
rm /opt/oracle/client.zip && \
|
||||
ln -s /opt/oracle/instantclient_* /opt/oracle/instantclient
|
||||
|
||||
# Configurar o sistema para encontrar as bibliotecas do Oracle
|
||||
ENV LD_LIBRARY_PATH=/opt/oracle/instantclient
|
||||
RUN echo "/opt/oracle/instantclient" > /etc/ld.so.conf.d/oracle-instantclient.conf && ldconfig
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Copiar apenas o necessário do estágio anterior
|
||||
COPY --from=builder /app/dist ./dist
|
||||
COPY --from=builder /app/package*.json ./
|
||||
COPY --from=builder /app/node_modules ./node_modules
|
||||
|
||||
COPY package*.json ./
|
||||
|
||||
|
||||
RUN npm install --legacy-peer-deps
|
||||
|
||||
COPY . .
|
||||
|
||||
|
||||
CMD ["npm", "run", "start:prod"]
|
||||
# Variáveis de ambiente padrão para o driver oracledb
|
||||
ENV OCI_LIB_DIR=/opt/oracle/instantclient
|
||||
ENV OCI_INC_DIR=/opt/oracle/instantclient/sdk/include
|
||||
|
|
@ -1,14 +1,18 @@
|
|||
version: '3.8'
|
||||
|
||||
services:
|
||||
vendaweb:
|
||||
image: link70/vendaweb
|
||||
deploy:
|
||||
replicas: 20
|
||||
resources:
|
||||
limits:
|
||||
cpus: '0.5'
|
||||
memory: 512M
|
||||
vendaweb-api:
|
||||
image: http://10.1.1.124:8082/library/vendaweb-api:latest
|
||||
ports:
|
||||
- "8065:8065"
|
||||
restart: always
|
||||
networks:
|
||||
- juru-network
|
||||
deploy:
|
||||
replicas: 4
|
||||
update_config:
|
||||
order: start-first
|
||||
parallelism: 1
|
||||
|
||||
networks:
|
||||
juru-network:
|
||||
external: true
|
||||
|
|
@ -1,14 +1,20 @@
|
|||
import { Controller, Get } from '@nestjs/common';
|
||||
import { AppService } from './app.service';
|
||||
import { ApiExcludeEndpoint } from '@nestjs/swagger';
|
||||
import { ApiTags, ApiOperation } from '@nestjs/swagger';
|
||||
import { APP_VERSION } from './version';
|
||||
|
||||
@Controller()
|
||||
@ApiTags('Main')
|
||||
@Controller('v1')
|
||||
export class AppController {
|
||||
constructor(private readonly appService: AppService) {}
|
||||
|
||||
@Get()
|
||||
@ApiExcludeEndpoint()
|
||||
getHello(): string {
|
||||
return this.appService.getHello();
|
||||
@Get('version')
|
||||
@ApiOperation({ summary: 'Get App Version' })
|
||||
getVersion() {
|
||||
return { version: APP_VERSION };
|
||||
}
|
||||
|
||||
@Get('health')
|
||||
@ApiOperation({ summary: 'Health check' })
|
||||
healthCheck() {
|
||||
return { status: 'ok' };
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1637,6 +1637,9 @@ export class Pcclient {
|
|||
@Column({ name: 'CODSUBCATEGORIA' })
|
||||
codsubcategoria: number;
|
||||
|
||||
@Column({ name: 'TIPOENDERECO' })
|
||||
tipoendereco: string;
|
||||
|
||||
@OneToMany(() => Pcnfsaid, notas => notas.pcclient)
|
||||
notas: Pcnfsaid[];
|
||||
|
||||
|
|
|
|||
|
|
@ -76,6 +76,9 @@ export class Pcclientendent {
|
|||
@Column({name: 'CODPAISRECEBEDOR'})
|
||||
codpaisrecebedor: number;
|
||||
|
||||
@Column({name: 'TIPOENDERECO'})
|
||||
tipoendereco: string;
|
||||
|
||||
@OneToMany(() => Pcpedc, pedidos => pedidos.pcclientendent)
|
||||
pedidos: Pcpedc[];
|
||||
|
||||
|
|
|
|||
|
|
@ -23,5 +23,6 @@ export class Address {
|
|||
emailRecebedor: string;
|
||||
latitude: number;
|
||||
longitude: number;
|
||||
addressType?: string;
|
||||
|
||||
}
|
||||
|
|
@ -19,14 +19,16 @@ export class Customer {
|
|||
public category: Category,
|
||||
public subCategory: SubCategory,
|
||||
public place: Place,
|
||||
public placeId: number,
|
||||
public sellerId: number,
|
||||
public ibgeCode: string,
|
||||
public birthdate: Date,
|
||||
public ramo: Ramo,
|
||||
public birthdate?: Date,
|
||||
public ramo?: Ramo,
|
||||
public communicate?: string,
|
||||
public idUser?: number,
|
||||
public latitude?: number,
|
||||
public longitude?: number,
|
||||
public addressType?: string,
|
||||
){}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -234,6 +234,7 @@ export class PartnerService {
|
|||
null,
|
||||
null,
|
||||
data.place,
|
||||
data.place.id,
|
||||
data.sellerId,
|
||||
data.ibgeCode,
|
||||
null,
|
||||
|
|
|
|||
|
|
@ -37,6 +37,7 @@ export class AddressCustomerService {
|
|||
.addSelect('\"pcclientendent\".codpracaent', 'placeId')
|
||||
.addSelect('\"pcclientendent\".latitude', 'latitude')
|
||||
.addSelect('\"pcclientendent\".longitude', 'longitude')
|
||||
.addSelect('\"pcclientendent\".tipoendereco', 'addressType')
|
||||
.where("\"pcclientendent\".codcli = :idCustomer", { idCustomer })
|
||||
.getRawMany();
|
||||
return new ResultModel(true, null, addresses, null);
|
||||
|
|
@ -79,6 +80,7 @@ export class AddressCustomerService {
|
|||
' ,pcclientendent.codpracaent as "placeId" ' +
|
||||
' ,pcclientendent.latitude as "latitude" ' +
|
||||
' ,pcclientendent.longitude as "longitude" ' +
|
||||
' ,pcclientendent.tipoendereco as "addressType" ' +
|
||||
' FROM pcclientendent ' +
|
||||
' WHERE pcclientendent.codcli = :idCustomer ' +
|
||||
' AND pcclientendent.codendentcli = :idAddress ';
|
||||
|
|
@ -122,6 +124,7 @@ export class AddressCustomerService {
|
|||
' ,pcclientendent.codpracaent as "placeId" ' +
|
||||
' ,pcclientendent.latitude as "latitude" ' +
|
||||
' ,pcclientendent.longitude as "longitude" ' +
|
||||
' ,pcclientendent.tipoendereco as "addressType" ' +
|
||||
' FROM pcclientendent ' +
|
||||
' WHERE pcclientendent.codcli = :idCustomer ' +
|
||||
" AND REGEXP_REPLACE(pcclientendent.cepent, '[^0-9]', '') = REGEXP_REPLACE(:cepent, '[^0-9]', '')";
|
||||
|
|
@ -183,6 +186,7 @@ export class AddressCustomerService {
|
|||
emailRecebedor: customer[0].email,
|
||||
latitude: ( data.latitude ) ? data.latitude.toString() : '0',
|
||||
longitude:( data.longitude ) ? data.longitude.toString() : '0',
|
||||
tipoendereco: data.addressType
|
||||
})
|
||||
.where("\"PCCLIENTENDENT\".codcli = :codcli and \"PCCLIENTENDENT\".codendentcli = :codendentcli",
|
||||
{ codcli: data.idCustomer, codendentcli: data.idAddress })
|
||||
|
|
@ -250,6 +254,7 @@ export class AddressCustomerService {
|
|||
newPcclientendent.emailRecebedor = customer.email;
|
||||
newPcclientendent.latitude = ( data.latitude ) ? data.latitude.toString() : '0';
|
||||
newPcclientendent.longitude = ( data.longitude ) ? data.longitude.toString() : '0';
|
||||
newPcclientendent.tipoendereco = data.addressType;
|
||||
|
||||
await queryRunner.manager
|
||||
.createQueryBuilder()
|
||||
|
|
@ -257,6 +262,7 @@ export class AddressCustomerService {
|
|||
.into(Pcclientendent)
|
||||
.values(newPcclientendent)
|
||||
.execute();
|
||||
|
||||
const newAddress: Address = {
|
||||
idCustomer: data.idCustomer,
|
||||
idAddress: id,
|
||||
|
|
@ -282,6 +288,7 @@ export class AddressCustomerService {
|
|||
emailRecebedor: customer.email,
|
||||
latitude: data.latitude,
|
||||
longitude: data.longitude,
|
||||
addressType: data.addressType,
|
||||
}
|
||||
|
||||
return newAddress;
|
||||
|
|
|
|||
|
|
@ -49,6 +49,7 @@ export class CustomerService {
|
|||
' ,pcclient.longitude as "longitude" ' +
|
||||
' ,pcclient.codmunicipio as "ibgeCode" ' +
|
||||
' ,pcclient.codcidade as "cityId" ' +
|
||||
' ,pcclient.tipoendereco as "addressType" ' +
|
||||
' FROM pcclient, pccidade ' +
|
||||
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
||||
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 customers = await queryRunner.manager
|
||||
.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) {
|
||||
console.log(error);
|
||||
throw error;
|
||||
|
|
@ -102,6 +114,7 @@ export class CustomerService {
|
|||
' ,pcclient.longitude as "longitude" ' +
|
||||
' ,pcclient.codmunicipio as "ibgeCode" ' +
|
||||
' ,pcclient.codcidade as "cityId" ' +
|
||||
' ,pcclient.tipoendereco as "addressType" ' +
|
||||
' FROM pcclient, pccidade ' +
|
||||
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
||||
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.codmunicipio as "ibgeCode" ' +
|
||||
' ,pcclient.codcidade as "cityId" ' +
|
||||
' ,pcclient.tipoendereco as "addressType" ' +
|
||||
' FROM pcclient, pccidade ' +
|
||||
' WHERE pcclient.codcidade = pccidade.codcidade (+)';
|
||||
const where = ` AND pcclient.codcli = ${idCustomer}`;
|
||||
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) {
|
||||
console.log(error);
|
||||
throw error;
|
||||
|
|
@ -216,6 +235,7 @@ export class CustomerService {
|
|||
.addSelect("\"pcclient\".longitude as \"longitude\"")
|
||||
.addSelect("\"pcclient\".codmunicipio as \"ibgeCode\"")
|
||||
.addSelect("\"pcclient\".codcidade as \"cityId\"")
|
||||
.addSelect("\"pcclient\".esc_tipoeclieente as \"addressType\"")
|
||||
.where(where)
|
||||
.andWhere("\"pcclient\".CODCLI NOT IN (2) AND \"pcclient\".DTEXCLUSAO IS NULL")
|
||||
.getRawMany();
|
||||
|
|
@ -304,6 +324,7 @@ export class CustomerService {
|
|||
newCustomer.dtultalter = new Date();
|
||||
newCustomer.latitude = customer.latitude;
|
||||
newCustomer.longitude = customer.longitude;
|
||||
newCustomer.tipoendereco = customer.addressType;
|
||||
|
||||
const oldCustomer = await this.findCustomerByCpf(newCustomer.cgcent);
|
||||
if (oldCustomer) {
|
||||
|
|
@ -321,7 +342,8 @@ export class CustomerService {
|
|||
allowMessage: customer.allowMessage, cellPhone: customer.cellPhone,
|
||||
category: customer.category, subCategory: customer.subCategory,
|
||||
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 {
|
||||
const idCustomer = await this.generateIdCustomer();
|
||||
|
|
@ -340,7 +362,8 @@ export class CustomerService {
|
|||
allowMessage: customer.allowMessage, cellPhone: customer.cellPhone,
|
||||
category: customer.category, subCategory: customer.subCategory,
|
||||
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) {
|
||||
|
|
@ -400,7 +423,8 @@ export class CustomerService {
|
|||
codfuncultalter: client.codfuncultalter,
|
||||
dtultalter: client.dtultalter,
|
||||
latitude: client.latitude,
|
||||
longitude: client.longitude,
|
||||
longitude: client.longitude,
|
||||
tipoendereco: client.tipoendereco
|
||||
})
|
||||
.where({ codcli: client.codcli })
|
||||
.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')
|
||||
@ApiOperation({ summary: 'Get product stock information' })
|
||||
@ApiParam({ name: 'storeid', description: 'Store ID' })
|
||||
|
|
|
|||
|
|
@ -77,9 +77,11 @@ export class SalesService {
|
|||
esvlistaprodutos.LETRABASETINTOMETRICO as "letter",
|
||||
esvlistaprodutos.LINHATINTOMETRICO as "line",
|
||||
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
|
||||
WHERE 1 = 1`;
|
||||
WHERE 1 = 1 `;
|
||||
|
||||
if (filter && filter.text.length > 0) {
|
||||
const description = filter.text.toUpperCase();
|
||||
|
|
@ -127,6 +129,8 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
||||
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
||||
.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 })
|
||||
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
||||
|
|
@ -184,6 +188,8 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
||||
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
||||
.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 })
|
||||
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
||||
|
|
@ -260,6 +266,8 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
||||
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
||||
.addSelect("\"esvlistaprodutos\".QUANTIDADE_ESTOQUE_GERAL", "full_stock")
|
||||
.addSelect("\"esvlistaprodutos\".TEM_PRODUTO_SIMILAR", "similar")
|
||||
.addSelect("\"esvlistaprodutos\".TIPO_CAMPANHA", "type_campaing")
|
||||
.where("esvlistaprodutos.brand in (" + xbrands + ")")
|
||||
.andWhere("\"esvlistaprodutos\".URLCATEGORIA LIKE :urlCategoria||'%'", { urlCategoria: filter.urlCategory })
|
||||
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||
|
|
@ -324,6 +332,8 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".LINHATINTOMETRICO", "line")
|
||||
.addSelect("\"esvlistaprodutos\".LITRAGEM", "can")
|
||||
.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 })
|
||||
.andWhere("(\"esvlistaprodutos\".produto_com_reducao_preco = :produtoComReducaoPreco OR :produtoComReducaoPreco = 'N')",
|
||||
{ produtoComReducaoPreco: (filter.markdown.toString() == 'true') ? 'S' : 'N' })
|
||||
|
|
@ -562,6 +572,8 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||
.addSelect("\"esvlistaprodutos\".BASETINTOMETRICO", "base")
|
||||
.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 })
|
||||
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
||||
.limit(pageSize)
|
||||
|
|
@ -608,7 +620,9 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".PRODUTO_COM_REDUCAO_PRECO", "downPrice")
|
||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||
.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 })
|
||||
.andWhere("(\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99')", { codfilial: store })
|
||||
.limit(pageSize)
|
||||
|
|
@ -657,7 +671,9 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".PRODUTO_COM_REDUCAO_PRECO", "downPrice")
|
||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||
.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 })
|
||||
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
||||
.limit(pageSize)
|
||||
|
|
@ -703,7 +719,9 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".PRODUTO_COM_REDUCAO_PRECO", "downPrice")
|
||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||
.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 })
|
||||
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial OR :codfilial = '99'", { codfilial: store })
|
||||
.limit(pageSize)
|
||||
|
|
@ -772,7 +790,9 @@ export class SalesService {
|
|||
.addSelect("\"esvlistaprodutos\".PRODUTO_COM_REDUCAO_PRECO", "downPrice")
|
||||
.addSelect("\"esvlistaprodutos\".PRODUTO_EM_CAMPANHA", "compaing")
|
||||
.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 })
|
||||
.andWhere("\"esvlistaprodutos\".codfilial = :codfilial", { codfilial: store })
|
||||
.orderBy("REPLACE(\"esvlistaprodutos\".DESCRICAO,'#', '')", "ASC")
|
||||
|
|
@ -834,6 +854,8 @@ export class SalesService {
|
|||
,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, ESTCOMPREJUNTO
|
||||
WHERE ESVLISTAPRODUTOS.CODPROD = ESTCOMPREJUNTO.CODPROD
|
||||
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) {
|
||||
const connectionDb = new Connection(connectionOptions);
|
||||
await connectionDb.connect();
|
||||
|
|
@ -1265,8 +1349,10 @@ export class SalesService {
|
|||
' ,esvlistaprodutos.LINHATINTOMETRICO "line" ' +
|
||||
' ,esvlistaprodutos.LITRAGEM "can" ' +
|
||||
' ,esvlistaprodutos.QUANTIDADE_ESTOQUE_GERAL "full_stock" ' +
|
||||
' ,esvlistaprodutos.TEM_PRODUTO_SIMILAR "similar" ' +
|
||||
' ,esvlistaprodutos.TIPO_CAMPANHA "type_campaing" ' +
|
||||
' FROM esvlistaprodutos ' +
|
||||
' WHERE 1 = 1';
|
||||
' WHERE 1 = 1 ';
|
||||
|
||||
let where = "";
|
||||
if (filter.text != null) {
|
||||
|
|
|
|||
|
|
@ -0,0 +1 @@
|
|||
export const APP_VERSION = 'v1.1.0';
|
||||
Loading…
Reference in New Issue