-- Compute average value to two decimal
values and avoid divide by zero error
Create FUNCTION [dbo].[getPercent]
(
       -- Add the parameters for the function here
       @valueToCompute
decimal,
       @TotalValue  decimal
)
RETURNS  numeric(10,2)
AS
BEGIN
Declare @result numeric(10,2);
if (@valueToCompute =0 or @TotalValue = 0)
begin
set @result = 0.00
end
else
begin
set @result =CAST(@valueToCompute
*100 /@TotalValue
AS numeric(10,2)) 
end
 return @result
       END
-----------------------------------------------------------------------------------------------------------------------------------------------------------
--Function to convert comma separated
list to integer table values to select from it
-- call example SELECT * FROM
fnNTextToIntTable ('150,220,560,950')
Create FUNCTION [dbo].[fnNTextToIntTable] (@Data NTEXT)
RETURNS 
    @IntTable
TABLE ([Value] INT NULL)
AS
BEGIN
    DECLARE @Ptr int, @Length int, @v nchar, @vv nvarchar(10)
    SELECT @Length = (DATALENGTH(@Data) / 2) + 1, @Ptr = 1
    WHILE (@Ptr < @Length)
    BEGIN
        SET @v = SUBSTRING(@Data, @Ptr, 1)
        IF @v = ','
        BEGIN
            INSERT INTO @IntTable (Value) VALUES (CAST(@vv AS int))
            SET @vv = NULL
        END
        ELSE
        BEGIN
            SET @vv = ISNULL(@vv, '') + @v
        END
        SET @Ptr = @Ptr + 1
    END
    -- If the last number was not followed by a comma, add it
to the result set
    IF @vv IS NOT NULL
        INSERT INTO @IntTable (Value) VALUES (CAST(@vv AS int))
    RETURN
END
---------------------------------------------------------------------------------------------------------------------------------------
--
=============================================
-- the function get weed end days count
for period between start date and end date ( friday and saturday are days of
weekend in my case )
/*Call Example
SELECT [dbo].[weekEndDaysCount] (
  
'2016-01-01'
 
,'2016-01-30')
GO
*/
-- =============================================
CREATE FUNCTION [dbo].[weekEndDaysCount]
(
       -- Add the parameters for the function here
       @StartDate
date,
       @EndDate
date
)
RETURNS int
AS
BEGIN
DECLARE @WDCount int       
;WITH cteSequence (SeqNo) as
(
      SELECT 1  UNION ALL SELECT SeqNo + 1
      FROM cteSequence
      WHERE SeqNo < DATEDIFF(DD, @StartDate,
@EndDate)+1
)
SELECT @WDCount = count(* )
FROM  
(SELECT TOP ( datediff(DAY,@StartDate,@EndDate) + 1 )
                        [Date] = dateadd(DAY,ROW_NUMBER()
                 
OVER(ORDER BY c1.SeqNo),
                 
DATEADD(DD,-1,@StartDate))
        FROM  
cteSequence c1 ) x
WHERE  datepart(dw,[Date]) in(5,6)
OPTION ( MAXRECURSION 0);
       RETURN @WDCount
END
GO
----------------------------------------------------------------------------------------------------------------------------------------------------------------------
--
=============================================
-- the function used to get working days
count in period passed to the function start and end dates ( weekend days in my
case is Friday and saturday)
/*
calling example : 
SELECT [dbo].[WorkingDaysGetCount] (
  
'2016-01-01'
 
,'2016-01-30')
GO
*/
--
=============================================
CREATE FUNCTION [dbo].[WorkingDaysGetCount]
(
       -- Add the parameters for the function here
       @StartDate
date,
       @EndDate
date
)
RETURNS int
AS
BEGIN
DECLARE @WDCount int       
SELECT @WDCount=
  
(DATEDIFF(dd,
@StartDate, @EndDate)
+ 1)
  -(DATEDIFF(wk, @StartDate, @EndDate) * 2)
  -(CASE WHEN DATENAME(dw, @StartDate) = 'Saturday' THEN 1 ELSE 0 END)
  -(CASE WHEN DATENAME(dw, @EndDate) = 'Friday' THEN 1 ELSE 0 END)
       
       
       RETURN @WDCount
END
---------------------------------------------------------------------------------------------------------------------------------------------------
--
=============================================
-- Author:           احتساب وقت ارسال التنبيهات بالدقائق والساعات والأيام لإظهارها للمستخدم
-- Create date: 
-- Description:      
--
=============================================
Create FUNCTION [dbo].[ElapsedTimeCalculate]
(
       -- Add the parameters for the function here
       @ToConvetDateTime
DateTime
)
RETURNS nvarchar(50)
AS
BEGIN
Declare 
@ReturnElapsedTime nvarchar(50),
  @CurrDate datetime = getdate() ,
@tempHours int,
@tempMinutes int,
@tempDays int
       select
        @tempDays= DATEDIFF(DD, @ToConvetDateTime,
@CurrDate) ,
        @tempHours= DATEDIFF(hh, @ToConvetDateTime,
@CurrDate) ,
  
@tempMinutes= DATEDIFF(mi,DATEADD(hh,DATEDIFF(hh,
@ToConvetDateTime, @CurrDate),@ToConvetDateTime),@CurrDate) 
    
       if(@tempDays>0)
 set @ReturnElapsedTime=
N'منذ '+ convert(nvarchar,@tempDays)+N' يوم سابق '    
 else 
 if(@tempHours>1)
 set @ReturnElapsedTime=
N'منذ '+ convert(nvarchar,@tempHours)+N' ساعة سابقة '  
 else
 if(@tempMinutes >2)
 set @ReturnElapsedTime=
N'منذ '+ convert(nvarchar,@tempMinutes)+N' دقيقة سابقة ' 
 else
 begin
 set @ReturnElapsedTime=
N'مرسل الآن  '    
 end
 return 
@ReturnElapsedTime  
       END
 -------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------