DELIMITER $$
CREATE OR REPLACE DEFINER=`vn`@`localhost` FUNCTION `vn`.`invoiceSerial`(
	vClientFk INT,
	vCompanyFk INT,
	vType CHAR(15)
)
	RETURNS char(2) CHARSET utf8mb3 COLLATE utf8mb3_general_ci
	DETERMINISTIC
BEGIN
/**
* Obtiene la serie de una factura
* dependiendo del area del cliente.
*
* @param vClientFk Id del cliente
* @param vCompanyFk Id de la empresa
* @param vType Tipo de factura (vn.invoiceOutSerial.type[ENUM])
* @return vSerie de la factura
*/
	DECLARE vTaxArea VARCHAR(25) COLLATE utf8mb3_general_ci;
	DECLARE vTransactionCode INT(2);
	DECLARE vSerie CHAR(2);

	IF (SELECT hasInvoiceSimplified FROM client WHERE id = vClientFk) THEN
		RETURN 'S';
	END IF;

	SELECT addressTaxArea(defaultAddressFk, vCompanyFk) INTO vTaxArea
		FROM client
		WHERE id = vClientFk;

	SELECT CodigoTransaccion INTO vTransactionCode
		FROM taxArea
		WHERE code = vTaxArea;

	SELECT ios.code INTO vSerie
		FROM invoiceOutSerial ios
			JOIN taxArea ta ON ta.code = ios.taxAreaFk
		WHERE ios.`type` = vType
			AND ta.CodigoTransaccion = vTransactionCode;

	RETURN vSerie;
END$$
DELIMITER ;