Knocks/BackEnd/Knoks.Operate/Stored Procedures/BO_GetAliveKnoks.sql

87 lines
3.3 KiB
Transact-SQL

CREATE PROCEDURE [BO_GetAliveKnoks]
@KnokId BIGINT = NULL,
@UserId BIGINT,
@SortOrderAsc BIT = 0,
@SortField INT = 1,
@Published BIT = 0,
@ExchangesIdsString NVARCHAR(1024) = NULL,
@TradingPairsString NVARCHAR(1024) = NULL,
@Gaining BIT = 0,
@Losing BIT = 0,
@RangeSettings [DurationCRTAggrItemsList] readonly
AS
declare @ExchangesIds TABLE(id int NULL);
declare @TradingPairs TABLE(code nvarchar(255) NULL);
insert into @ExchangesIds(id) SELECT cast(value as int)
FROM STRING_SPLIT(@ExchangesIdsString, ';')
insert into @TradingPairs(code) SELECT value
FROM STRING_SPLIT(@TradingPairsString, ';')
--Get active knoks
SELECT Duration, CreateDate, KnokId, Currency1, Currency2, Currency, MarketDisplayName, ExchangeId, UserId,
EntryPriceFrom, EntryPriceTo, ExitPriceFrom, ExitPriceTo, StopLoss, ExchangeName,
PotentialProfitValue, PotentialProfit, Price, DollarPrice, UserFollowers, [Rank],
HasAvatar, UserName, FirstName, LastName, CurrentPrice, Purchases, CurrentProfit, --DistanceFromTarget,
CAST(CASE WHEN EXISTS(SELECT 1 FROM TraderFeedbacks fb where fb.KnokId = k.KnokId AND fb.UserId = @UserId AND fb.FeedbackType = 0) THEN 1 ELSE 0 END AS BIT) AS FeedbackExists,
k.Precision
FROM [dbo].[VW_ActiveKnoks] k with(nolock)
Where ISNULL(@KnokId, k.KnokId) = k.KnokId
AND (EXISTS (SELECT 1 FROM UserKnoks uk WHERE uk.UserId = @UserId AND uk.KnokId = k.KnokId))
AND (EXISTS(SELECT 1 FROM @ExchangesIds HAVING COUNT(1) = 0) OR EXISTS (SELECT 1 FROM @ExchangesIds e WHERE e.id = k.ExchangeId))
AND (EXISTS(SELECT 1 FROM @TradingPairs HAVING COUNT(1) = 0) OR EXISTS (SELECT 1 FROM @TradingPairs e WHERE e.code = k.Currency2))
AND (ISNULL(@Published, 0) = 0 OR (@Published = 1 AND NOT k.PublishedDate IS NULL AND k.KnokStatusId = 3))
AND ((@Gaining = 1 AND @Losing = 1) OR
(ISNULL(@Gaining, 0) = 0 OR (@Gaining = 1 AND CurrentPrice > ((EntryPriceFrom + EntryPriceTo) / 2)))
AND (ISNULL(@Losing, 0) = 0 OR (@Losing = 1 AND CurrentPrice < ((EntryPriceFrom + EntryPriceTo) / 2)))
)
ORDER BY
--CASE @SortOrderAsc WHEN 1 THEN
-- CASE WHEN ISNULL(@SortField, 1) = 1 THEN
-- CASE @SortField
-- WHEN NULL THEN FinishTime -- TimeLeft
-- WHEN 1 THEN FinishTime -- TimeLeft
-- END
-- END
--END ASC,
--CASE @SortOrderAsc WHEN 0 THEN
-- CASE WHEN ISNULL(@SortField, 1) = 1 THEN
-- CASE @SortField
-- WHEN NULL THEN TimeLeft -- TimeLeft
-- WHEN 1 THEN TimeLeft -- TimeLeft
-- END
-- END
--END DESC,
CASE @SortOrderAsc WHEN 1 THEN
--CASE WHEN ISNULL(@SortField, 1) > 1 THEN
CASE @SortField
WHEN 1 THEN TimeLeft -- TimeLeft
WHEN 2 THEN DistanceFromTarget -- Distance from target
WHEN 3 THEN CurrentProfit -- Current profit
WHEN 4 THEN Purchases -- Purchases
--WHEN 5 THEN PricePoolData -- PricePool
--WHEN 6 THEN UserReview -- BuyerReview
END
--END
END ASC,
CASE @SortOrderAsc WHEN 0 THEN
--CASE WHEN ISNULL(@SortField, 1) > 1 THEN
CASE @SortField
WHEN 1 THEN TimeLeft -- TimeLeft
WHEN 2 THEN DistanceFromTarget -- Distance from target
WHEN 3 THEN CurrentProfit -- Current profit
WHEN 4 THEN Purchases -- Purchases
--WHEN 5 THEN PricePoolData -- PricePool
--WHEN 6 THEN UserReview -- BuyerReview
END
--END
END DESC
EXEC [BO_GetKnokChartData] @KnokId, NULL, @RangeSettings
RETURN 0