--msg-num = -1       
--msg-num = -2     
--msg-num = -5  
--msg-num = Left(NuSanad,3) = -99     
-------------------------------------------------------------------------
--   
--@Msg_Num=-10        
------------------------------------------------------------
CREATE PROCEDURE [dbo].[Sp_SodorFactor_Retail] @msg_num Numeric(18,0) OUTPUT,@TmpId  Numeric(18,0) AS

 -----------------------------------Create Virtual TmpHeadh-------------------------------------------------------------------------
 DECLARE @TmpHeadh as Table ( Id_Havaleh  numeric(18, 0) , Kind_Flag CHAR(1) , Nu_Forosh VARCHAR(8) ,
	                          Nu_Kharid VARCHAR(8) , Nu_Bargasht_Forosh VARCHAR(8) ,Items SMALLINT,
	                          Number_bar VARCHAR(15) , Recive_Name NVARCHAR(35) , Trans_Name NVARCHAR(35) ,
	                          Tot_Price_KHarid MONEY ,Tot_Price_forosh MONEY , Tarikh_faktor SMALLDATETIME,Sanad INT, 
	                          Note NTEXT, kind_Save CHAR(1) , User_id SMALLINT, Kind_Cooperative SMALLINT,Tot_Price_Cooperative MONEY, ClubId INT
                              ) 
                              
 INSERT INTO @TmpHeadh ( Id_Havaleh   , Kind_Flag  , Nu_Forosh  ,
	                     Nu_Kharid  , Nu_Bargasht_Forosh  ,Items ,
	                     Number_bar  , Recive_Name  , Trans_Name  ,
	                     Tot_Price_KHarid  ,Tot_Price_forosh  , Tarikh_faktor ,Sanad,
	                     Note , kind_Save , User_id, ClubId 
	                    )
 SELECT Id_Havaleh , Kind_Flag  , Nu_Forosh  , Nu_Kharid  , Nu_Bargasht_Forosh  ,Items , Number_bar , 
        Recive_Name  , Trans_Name  , Tot_Price_KHarid  ,Tot_Price_forosh  , Tarikh_faktor ,Sanad,
        Note , kind_Save , User_id, ClubId FROM dbo.TmpHeadH
 WHERE Id_Havaleh = @Tmpid
 
 -----------------------------------Create Virtual TmpHavaleh-------------------------------------------------------------------------
 
 DECLARE @TmpHavaleh as Table ( Id_Havaleh  numeric(18, 0) , AutoId bigint , Sender Varchar(5) , 
								Reciver  VARCHAR(8) , Radif  SMALLINT , K_Code  VARCHAR(15),
								K_Qty1 MONEY, K_Qty2 MONEY, R_Unit1_2 MONEY, Price_Kharid MONEY,
								Price_Forosh MONEY, Price_Omdeh MONEY, Status SMALLINT, 
								Takhfif_Flag CHAR(1), Cooperative_Flag CHAR(1), Point_Flag BIT,
								Hamrah_Flag BIT, EditQty_Flag BIT, CtrMojodi CHAR(1),
								Link_Record BIGINT, Make_Flag BIT,Note NVARCHAR(60),DayOfKala SMALLINT, 
								Price_Consumer MONEY,   Price_Finish MONEY, Tot_Kharid MONEY, Tot_Forosh MONEY, Tot_Omdeh MONEY, jetId INT  
                              ) 
 INSERT INTO @TmpHavaleh ( Id_Havaleh , AutoId , Sender ,
						   Reciver , Radif ,  K_Code ,
						   K_Qty1 ,  K_Qty2 ,  R_Unit1_2 , Price_Kharid ,
						   Price_Forosh ,  Price_Omdeh ,  Status ,
						   Takhfif_Flag ,  Cooperative_Flag ,  Point_Flag ,
						   Hamrah_Flag ,  EditQty_Flag , CtrMojodi ,
						   Link_Record , Make_Flag ,  Note ,  DayOfKala ,
						   Price_Consumer,  Price_Finish,Tot_Kharid, Tot_Forosh,  Tot_Omdeh, jetId )
							
                          SELECT Id_Havaleh  , AutoId , Sender , Reciver  , Radif  , K_Code  , K_Qty1 , K_Qty2 , R_Unit1_2 , Price_Kharid ,
                          Price_Forosh , Price_Omdeh , Status , Takhfif_Flag , Cooperative_Flag , Point_Flag ,
                          Hamrah_Flag , EditQty_Flag , CtrMojodi , Link_Record , Make_Flag ,Note ,DayOfKala , 
                          Price_Consumer, Price_Finish, Tot_Kharid, Tot_Forosh, Tot_Omdeh, JetId FROM dbo.TmpHavaleh
                          WHERE Id_Havaleh = @Tmpid
                          
						  -----------------------------Update Tot Price From Header-------------------------------------
						  UPDATE TmpHeadH Set 
						  Tot_Price_KHarid = T.TotPriceKharid ,
						  Tot_Price_forosh = T.TotPriceForosh ,
						  Tot_Price_Cooperative =
						  CASE
							  When Kind_Flag = 8 then PriceKharidCooperative
							  When Kind_Flag = 7 then PriceForoshCooperative
						  END ,
						  Kind_Cooperative = 
						  CASE
						    When T.KindCooperative > 0 Then Cast(Kind_Flag As TinyInt) + 900
						    ELSE 0
					      END
						  FROM @TmpHeadH TmpHeadh
						  Inner Join (
										 Select Id_Havaleh, 
										 Sum(Tot_Kharid) TotPriceKharid,      
										 Sum(Tot_Forosh) TotPriceForosh,
										 Sum(Case When IsNull(Cooperative_Flag,0) = '1' Then Round(K_Qty1 * Price_KHarid,0) Else 0 End) PriceKharidCooperative,
										 Sum(Case When IsNull(Cooperative_Flag,0) = '1' Then Round(K_Qty1 * Price_Forosh,0) Else 0 End) PriceForoshCooperative,
										 Sum(Cast(IsNull(Cooperative_Flag,0) as int)) KindCooperative
										 From @TmpHavaleh  
										 Where Id_Havaleh = @TmpId
										 Group By Id_Havaleh
									  ) As T on Tmpheadh.Id_Havaleh = T.Id_Havaleh      
						WHERE TmpHeadh.Id_Havaleh = @TmpId
		                -----------------------------Update Tot Price From Header-------------------------------------

 -----------------------------------------------------------------------------------------------------------------------------------------                         
 IF (SELECT TOP 1 Id_Havaleh From @TmpHavaleh Where Id_Havaleh = @TmpId) > 0     
 BEGIN
   DECLARE @Nu_sanad BIGINT
   SET @msg_num=0
 
   --    
   SELECT @Nu_Sanad=Nu_Manual FROM dbo.heads Where (DateDiff(day,Tarikh_User,getdate())=0) And (Auto=1)  and (Fiexd=1 )
   IF ( @Nu_Sanad ) > 0 
   Begin
     Set  @msg_num= cast ('-99'+Ltrim(str(@Nu_Sanad)) as int)
     RETURN @msg_num  
   End
   ------------------------------------------------------------------------------------------------
   --   
   IF EXISTS(
             SELECT  TOP 1 TmpHavaleh.K_Code
	  	     FROM dbo.Anbar INNER JOIN
             @TmpHavaleh AS TmpHavaleh ON dbo.Anbar.A_Code = TmpHavaleh.Sender AND dbo.Anbar.K_Code = TmpHavaleh.K_Code 
		     GROUP BY TmpHavaleh.Sender, TmpHavaleh.K_Code, dbo.Anbar.Mojodi, TmpHavaleh.CtrMojodi, TmpHavaleh.Id_Havaleh
		     HAVING  (TmpHavaleh.CtrMojodi = '1') AND (TmpHavaleh.Id_Havaleh = @tmpid) 
		     AND (dbo.Anbar.Mojodi - SUM(TmpHavaleh.K_Qty1) < 0) And ( Len(TmpHavaleh.Sender) =3)
            ) 
   BEGIN
     Set  @msg_num=-1  --msg-num = -1       
     RETURN @msg_num
   END
   ------------------------------------------------------------------------------------------------
   Else 
   BEGIN   
     Begin Tran 
     Exec dbo.checkMandeh10000 @TmpId
     Declare @Last_Id Numeric(18,0)
	 DECLARE @FactorId UNIQUEIDENTIFIER = NEWID()     
     
     Insert Into Dbo.HeadH(Kind_Flag,Nu_Forosh,Nu_Kharid,Nu_Bargasht_Forosh,Items,Recive_Name,Trans_Name,Tot_Price_kharid,Tot_Price_Forosh,Tot_Price_Cooperative, Note,User_Id,Tarikh_Faktor, Number_Bar, Sanad,Kind_Cooperative,Id)
                    Select Kind_Flag,Nu_Forosh,Nu_Kharid,Nu_Bargasht_Forosh,Items,Recive_Name,Trans_Name,Tot_Price_kharid,Tot_Price_Forosh,Tot_Price_Cooperative, Note,User_Id,CONVERT(VARCHAR(10),GETDATE(),111), Number_Bar, Sanad, Kind_Cooperative,@FactorId  From @TmpHeadH
                    Where Id_Havaleh=@TmpId	
     IF @@Error > 0  
     Begin
       Set @msg_num=-5  
       ROLLBACK TRANSACTION
       RETURN @msg_num 
     End    
   
     Select @Last_Id=Scope_Identity() 
   
     Insert Into Dbo.Havaleh(Id_Havaleh,AutoId,Sender,Reciver,Radif,K_Code,K_Qty1,K_Qty2,R_Unit1_2,Price_Kharid,Price_Forosh,Price_Omdeh,Status,Takhfif_Flag,Cooperative_Flag, Point_Flag,Hamrah_Flag,EditQty_Flag,CtrMojodi,Link_Record,Make_Flag,Note,DayOfKala, Price_Consumer,Price_Finish,JetId)
                     Select @Last_Id ,AutoId,Sender,Reciver,Radif,K_Code,K_Qty1,K_Qty2,R_Unit1_2,Price_Kharid,Price_Forosh,Price_Omdeh,Status,Takhfif_Flag,Cooperative_Flag, Point_Flag,Hamrah_Flag,EditQty_Flag,CtrMojodi,Link_Record,Make_Flag,Note,DayOfKala,Price_Consumer,Price_Finish,jetId
                     From @TmpHavaleh Where Id_Havaleh=@TmpId  
   
     IF @@Error > 0  
     Begin
       Set  @msg_num=-5  
       ROLLBACK TRANSACTION
       RETURN @msg_num 
     End    
     ------------------------------------------------------------------------------------------------
     Delete From dbo.Tmp_Over_Under_Factor Where (Id_Havaleh=@TmpId) And (Price <=0 Or Price is null )
     IF (SELECT TOP 1 Id_Havaleh FROM dbo.Tmp_Over_Under_Factor WHERE (Id_Havaleh = @TmpId)) > 0 
     BEGIN
       INSERT Into dbo.Over_Under_Factor(Id_Havaleh, Code_Over_Under ,Type ,Price ,[Percent] , Act_Code , Auto_Id_Havaleh , Price_Row, Guy_Code)
                            SELECT @Last_Id, Code_Over_Under ,Type ,Price , [Percent] , Act_Code , Auto_Id_Havaleh , Price_Row, Guy_Code
                            FROM Tmp_Over_Under_factor  Where (Id_Havaleh=@TmpId)      
       IF @@Error > 0 
       BEGIN
         Set  @msg_num=-5  
         ROLLBACK TRANSACTION
         RETURN @msg_num 
       END    
     END
     ------------------------------------------------------------------------------------------------
     INSERT INTO Dbo.Over_Under_Row (AutoId,name,Code_Act,Type,Price,[Percent],Code_Over_Under)
     SELECT  Tmp_Over_Under_Row.AutoId, Tmp_Over_Under_Row.name, Tmp_Over_Under_Row.Code_Act, 
                    Tmp_Over_Under_Row.Type, Tmp_Over_Under_Row.Price, Tmp_Over_Under_Row.[Percent], 
                    Tmp_Over_Under_Row.Code_Over_Under FROM  @TmpHavaleh TmpHavaleh INNER JOIN
                    Tmp_Over_Under_Row ON TmpHavaleh.AutoId = Tmp_Over_Under_Row.AutoId
                    WHERE  TmpHavaleh.Id_Havaleh = @TmpId And Price > 0 
     IF @@Error > 0  
     Begin
       Set  @Msg_Num= -5  
       ROLLBACK TRANSACTION
       RETURN @Msg_Num 
     End
     ---------------------------------------------------------------------------------------------------------------------------------------
     Declare @Id_Cheqe BigInt 
     SELECT  @Id_cheqe= dbo.TmpHeadC.Id_Cheqe FROM dbo.TmpHeadC INNER JOIN dbo.TmpCheqe ON dbo.TmpHeadC.Id_Cheqe = dbo.TmpCheqe.Id_Cheqe
     WHERE (dbo.TmpHeadc.Id_Havaleh = @TmpId)And (dbo.TmpCheqe.CH_Price > 0)
  
     IF  (@Id_Cheqe <> Null) Or (@Id_Cheqe <> 0) 
       Exec  @Msg_Num=Sodor_Vajeh  @Msg_num,@Id_Cheqe,@TmpId,@last_id,0
     IF @Msg_Num < 0  
     Begin
       Set  @msg_num=-5  
       ROLLBACK TRANSACTION
       RETURN @msg_num 
     End    
	 ----------------------------------------(Club Save info)---------------------------------------------------------
     EXEC @Msg_Num = dbo.Club_SaveInfo @TmpId, @Last_Id,@FactorId 
     IF @Msg_Num < 0  
     BEGIN
       SET @msg_num=-5  
       ROLLBACK TRANSACTION
       RETURN @msg_num 
     END    
     ------------------------------------------------------------------------------------------------
     Delete From dbo.Tmpheadh Where Id_Havaleh=@TmpId 
     ------------------------------------------------------------------------------------------------
     Commit Tran
     SELECT @msg_num=@Last_Id
     RETURN @msg_num
     print 'ǘ  ' 
   END 
 End 
 Else 
 Begin
   SET  @msg_num=-2 
   RETURN @msg_num
   PRINT '    '
 END
