예제 #1
0
    protected void btnCancel_Click(object sender, EventArgs e)
    {
        Users            u      = UsersDB.getUserbyEmail(Session["email"].ToString());
        List <LiveDonor> ldlist = LiveDonorDB.getLiveDonorbyuserID(u.userId);

        foreach (LiveDonor l in ldlist)
        {
            if (l.status == "not allotted")
            {
                id = l.ldonorID;
                break;
            }
        }
        if (id != null)
        {
            LiveDonor nowld = LiveDonorDB.getLiveDonorbyID(id);

            nowld.status = "cancelled";
            int num = LiveDonorDB.updateLiveDonor(nowld);
            if (num != 1)
            {
                lblDOutput.Text = "Sorry cancel Failed!";
            }
            else
            {
                lblDOutput.Text = "Your organ donation is now cancelled!";
                string DonateOrganUrl = "DonateOrgan.aspx";
                Page.Header.Controls.Add(new LiteralControl(string.Format(@" <META http-equiv='REFRESH' content=2;url={0}> ", DonateOrganUrl)));
            }
        }
        else
        {
            lblDOutput.Text = "Sorry cancel Failed!";
        }
    }
예제 #2
0
    //get LiveDonor by ID
    public static LiveDonor getLiveDonorbyID(string ID)
    {
        LiveDonor u = new LiveDonor();

        try
        {
            SqlCommand command = new SqlCommand("Select * from LiveDonor where ldonorID = @ldonorID");
            command.Parameters.AddWithValue("@ldonorID", ID);
            command.Connection = connection;
            connection.Open();
            SqlDataReader reader = command.ExecuteReader();
            while (reader.Read())
            {
                u.ldonorID = reader["ldonorID"].ToString();
                Users us = UsersDB.getUserbyID(reader["userID"].ToString());
                u.userid        = us;
                u.comments      = reader["comments"].ToString();
                u.organType     = reader["organType"].ToString();
                u.status        = reader["status"].ToString();
                u.doctorName    = reader["doctorName"].ToString();
                u.doctorNumber  = Convert.ToInt32(reader["doctorNumber"]);
                u.DoctorAddress = reader["doctorAddress"].ToString();
                u.DoctorEmail   = reader["doctorEmail"].ToString();
            }
            reader.Close();
        }
        finally
        {
            connection.Close();
        }
        return(u);
    }
예제 #3
0
    //insert LiveDonor to database
    public static int insertLiveDonor(LiveDonor i)
    {
        int num = -1;

        try
        {
            SqlCommand command = new SqlCommand("insert into LiveDonor values( @userid, @organType, @comments, @status, @doctorName, @doctorNumber,@doctorAddress,@doctorEmail)");
            command.Parameters.AddWithValue("@userid", i.userid.userId);
            command.Parameters.AddWithValue("@organType", i.organType);
            command.Parameters.AddWithValue("@comments", i.comments);
            command.Parameters.AddWithValue("@status", i.status);
            command.Parameters.AddWithValue("@doctorName", i.doctorName);
            command.Parameters.AddWithValue("@doctorNumber", i.doctorNumber);
            command.Parameters.AddWithValue("@doctorAddress", i.doctorAddress);
            command.Parameters.AddWithValue("@doctorEmail", i.doctorEmail);
            command.Connection = connection;
            connection.Open();
            if (command.ExecuteNonQuery() > 0)
            {
                num = 1;
            }
        }
        finally
        {
            connection.Close();
        }
        return(num);
    }
예제 #4
0
 public LiveOrganMatching(LiveDonor liveDonor, OrganRecipient recipient, int matchScore, string comments, string status, int distance)
 {
     LiveDonor  = liveDonor;
     Recipient  = recipient;
     MatchScore = matchScore;
     Comments   = comments;
     Status     = status;
     Distance   = distance;
 }
예제 #5
0
    //Update liveDonation in the database
    public static int updateLiveDonor(LiveDonor u)
    {
        int result;

        try
        {
            SqlCommand command = new SqlCommand("Update LiveDonor set status=@status where lDonorID=@lDonorID");
            command.Parameters.AddWithValue("@lDonorID", u.ldonorID);
            command.Parameters.AddWithValue("@status", u.status);
            command.Connection = connection;
            connection.Open();
            result = command.ExecuteNonQuery();
        }
        finally
        {
            connection.Close();
        }
        return(result);
    }
예제 #6
0
    protected void btnDSubmit_Click(object sender, EventArgs e)
    {
        if (Convert.ToInt32(tbxDPhone.Text) <= 0)
        {
            lblDOutput.Text = "Phone number is in incorrect format";
            return;
        }
        else
        {
            string ogtype;
            string Dname    = tbxDoctor.Text;
            int    Dphone   = Convert.ToInt32(tbxDPhone.Text);
            string Demail   = TbxDEmail.Text;
            string Daddress = tbxDAddress.Text;
            if (ddlOrgan.SelectedIndex == 0)
            {
                lblOrgan.Visible = true;
                return;
            }
            else
            {
                ogtype = ddlOrgan.SelectedValue;
            }
            if (tbxComment.Text == "")
            {
                comment = "-";
            }
            else
            {
                comment = tbxComment.Text;
            }
            Users u = UsersDB.getUserbyEmail(Session["email"].ToString());
            //add code for finding match here
            LiveDonor ld  = new LiveDonor(u, ogtype, comment, "not allotted", Dname, Dphone, Daddress, Demail);
            int       num = LiveDonorDB.insertLiveDonor(ld);
            if (num != -1)
            {
                LiveDonor        tLiveDonor;
                List <LiveDonor> tDonorList = LiveDonorDB.getLiveDonorbyuserID(u.userId);
                tLiveDonor = tDonorList[0];
                foreach (LiveDonor tld in tDonorList)
                {
                    if (tld.status == "not allotted")
                    {
                        tLiveDonor = tld;
                    }
                }

                List <OrganRecipient> allRecievers = OrganRecipientDB.getAllRecipients();
                bool f = false;
                foreach (OrganRecipient r in allRecievers)
                {
                    int    y   = 0;
                    String bt1 = u.bloodtype;
                    String bt2 = r.Bloodgroup;
                    if ((bt1 == "A+" || bt1 == "A-") && (bt2 == "A+" || bt2 == "A-" || bt2 == "AB+" || bt2 == "AB-"))
                    {
                        y = 1;
                    }
                    else if ((bt1 == "B+" || bt1 == "B-") && (bt2 == "B+" || bt2 == "B-" || bt2 == "AB+" || bt2 == "AB-"))
                    {
                        y = 1;
                    }
                    else if ((bt1 == "AB+" || bt1 == "AB-") && (bt2 == "AB+" || bt2 == "AB-"))
                    {
                        y = 1;
                    }
                    else if ((bt1 == "O+" || bt1 == "O-") && (bt2 == "A+" || bt2 == "A-" || bt2 == "AB+" || bt2 == "AB-" || bt2 == "B+" || bt2 == "B-" || bt2 == "O+" || bt2 == "O-"))
                    {
                        y = 1;
                    }

                    if (y == 1 && tLiveDonor.OrganType == r.Organrequired && r.Status == "waiting")
                    {
                        float d     = getDistance(u.address, r.Establishment.Address);
                        int   score = 0;
                        int   d1    = Convert.ToInt32(d);
                        d = d / 3600;
                        int wTimeScore = 0, distanceScore = 0;
                        if (d < 5)
                        {
                            distanceScore = 5;
                        }
                        else if (d < 15)
                        {
                            distanceScore = 4;
                        }
                        else if (d < 25)
                        {
                            distanceScore = 3;
                        }
                        else if (d < 35)
                        {
                            distanceScore = 2;
                        }
                        else if (d < 45)
                        {
                            distanceScore = 1;
                        }
                        else
                        {
                            distanceScore = 0;
                        }

                        double days = (DateTime.Today - r.Addedon).TotalDays;

                        if (days < 180)
                        {
                            wTimeScore = 1;
                        }
                        else if (days < 365)
                        {
                            wTimeScore = 2;
                        }
                        else if (days < 1095)
                        {
                            wTimeScore = 3;
                        }
                        else if (days < 1825)
                        {
                            wTimeScore = 4;
                        }
                        else
                        {
                            wTimeScore = 5;
                        }

                        score = r.Urgency * 3 + distanceScore + wTimeScore;

                        LiveOrganMatching match = new LiveOrganMatching();
                        match.LiveDonor  = tLiveDonor;
                        match.MatchScore = score;
                        match.Recipient  = r;
                        match.Status     = "pending";
                        match.Comments   = "NIL";
                        match.Distance   = d1;
                        LiveOrganMatchingDB.insertMatch(match);
                        f = true;
                    }
                }
                if (f == true)
                {
                    List <LiveOrganMatching> liveMatches     = LiveOrganMatchingDB.getAllMatches();
                    List <LiveOrganMatching> liveMatchesCurr = new List <LiveOrganMatching>();
                    foreach (LiveOrganMatching LOM1 in liveMatches)
                    {
                        if (LOM1.LiveDonor.LdonorID == tLiveDonor.LdonorID)
                        {
                            liveMatchesCurr.Add(LOM1);
                        }
                    }
                    LiveOrganMatching tempLOM = liveMatchesCurr[0];
                    foreach (LiveOrganMatching LOM in liveMatchesCurr)
                    {
                        if (LOM.MatchScore > tempLOM.MatchScore)
                        {
                            tempLOM = LOM;
                        }
                    }
                    tempLOM.Status = "current match";
                    LiveOrganMatchingDB.updateMatch(tempLOM);
                    tLiveDonor.status = "allotted";
                    LiveDonorDB.updateLiveDonor(tLiveDonor);
                    tempLOM.Recipient.Status = "allotted";
                    OrganRecipientDB.updateOrganRecipient(tempLOM.Recipient);
                }
                PanelRegisterDonor.Visible = false;
                Server.Transfer("HistoryOrgan.aspx");
            }
            else
            {
                PanelRegisterDonor.Visible = true;
                lblDOutput.Text            = "Registration Fail! Please Try Again.";
                return;
            }
        }
    }
예제 #7
0
    protected void btnDecline_Click(object sender, EventArgs e)
    {
        List <OrganRecipient> ourRecipients = new List <OrganRecipient>();
        List <OrganRecipient> allRecipients = OrganRecipientDB.getAllRecipients();
        Establishment         currentEstab  = (Establishment)Session["establishment"];

        foreach (OrganRecipient r in allRecipients)
        {
            if (r.Establishment.ID == currentEstab.ID && (r.Status == "waiting" || r.Status == "allotted"))
            {
                ourRecipients.Add(r);
            }
        }
        OrganRecipient        currentRecipient = ourRecipients[gvRecipients.PageSize * gvRecipients.PageIndex + gvRecipients.SelectedIndex];
        DeceasedOrganMatching deadOrgan        = new DeceasedOrganMatching();
        LiveOrganMatching     liveOrgan        = new LiveOrganMatching();
        int matchFound = 0;
        List <DeceasedOrganMatching> allDeadMatches     = DeceasedOrganMatchingDB.getAllMatches();
        List <LiveOrganMatching>     allLiveMatches     = LiveOrganMatchingDB.getAllMatches();
        List <DeceasedOrganMatching> allDeadMatchesCurr = new List <DeceasedOrganMatching>();
        List <LiveOrganMatching>     allLiveMatchesCurr = new List <LiveOrganMatching>();
        bool checkMatchD = false;
        bool checkMatchL = false;

        foreach (DeceasedOrganMatching d in allDeadMatches)
        {
            if (d.Recipient.ID == currentRecipient.ID && d.Status == "current match")
            {
                matchFound = 1;
                deadOrgan  = d;
            }
            else if (d.Recipient.ID == currentRecipient.ID && d.Status == "pending" && d.DeceasedDonor.Status == "not allotted")
            {
                allDeadMatchesCurr.Add(d);
                checkMatchD = true;
            }
        }
        foreach (LiveOrganMatching l in allLiveMatches)
        {
            if (l.Recipient.ID == currentRecipient.ID && l.Status == "current match")
            {
                matchFound = 2;
                liveOrgan  = l;
            }
            else if (l.Recipient.ID == currentRecipient.ID && l.Status == "pending" && l.LiveDonor.status == "not allotted")
            {
                allLiveMatchesCurr.Add(l);
                checkMatchL = true;
            }
        }
        if (matchFound == 0)
        {
            lblOutput.Text = "Sorry no matches yet!";
        }
        else if (matchFound == 2)
        {
            // tempCurrentMatch = deadOrgan.ID;
            liveOrgan.Status = "not possible";
            LiveOrganMatchingDB.updateMatch(liveOrgan);
        }
        else if (matchFound == 1)
        {
            // tempCurrentMatch = liveOrgan.ID;
            deadOrgan.Status = "not possible";
            DeceasedOrganMatchingDB.updateMatch(deadOrgan);
        }
        LiveOrganMatching tempLDM = new LiveOrganMatching();

        if (checkMatchL == true)
        {
            tempLDM = allLiveMatchesCurr[0];
            foreach (LiveOrganMatching ldm in allLiveMatchesCurr)
            {
                if (ldm.MatchScore > tempLDM.MatchScore)
                {
                    tempLDM = ldm;
                }
            }
        }
        DeceasedOrganMatching tempDOM = new DeceasedOrganMatching();

        if (checkMatchD == true)
        {
            tempDOM = allDeadMatchesCurr[0];
            foreach (DeceasedOrganMatching dom in allDeadMatchesCurr)
            {
                if (dom.MatchScore > tempDOM.MatchScore)
                {
                    tempDOM = dom;
                }
            }
        }
        if (checkMatchD == true && checkMatchL == true)
        {
            if (tempDOM.MatchScore < tempLDM.MatchScore)
            {
                tempLDM.Status = "current match";
                LiveOrganMatchingDB.updateMatch(tempLDM);
                LiveDonor tempItem = LiveDonorDB.getLiveDonorbyID(tempLDM.LiveDonor.LdonorID);
                tempItem.status = "allotted";
                LiveDonorDB.updateLiveDonor(tempItem);
            }
            else
            {
                tempDOM.Status = "current match";
                DeceasedOrganMatchingDB.updateMatch(tempDOM);
                DeceasedDonor tempItem = DeceasedDonorDB.getDonorByID(tempDOM.DeceasedDonor.ID);
                tempItem.Status = "allotted";
                DeceasedDonorDB.updateDeceasedDonor(tempItem);
            }
        }
        else if (checkMatchD == true && checkMatchL == false)
        {
            tempDOM.Status = "current match";
            DeceasedOrganMatchingDB.updateMatch(tempDOM);
            DeceasedDonor tempItem = DeceasedDonorDB.getDonorByID(tempDOM.DeceasedDonor.ID);
            tempItem.Status = "allotted";
            DeceasedDonorDB.updateDeceasedDonor(tempItem);
        }
        else if (checkMatchL == true && checkMatchD == false)
        {
            tempLDM.Status = "current match";
            LiveOrganMatchingDB.updateMatch(tempLDM);
            LiveDonor tempItem = LiveDonorDB.getLiveDonorbyID(tempLDM.LiveDonor.LdonorID);
            tempItem.status = "allotted";
            LiveDonorDB.updateLiveDonor(tempItem);
        }
        else
        {
            currentRecipient.Status = "waiting";
            OrganRecipientDB.updateOrganRecipient(currentRecipient);
        }
        Label1.Text = "Successfully completed";
        string MyAccountUrl = "RecipientWaitingList.aspx";

        Page.Header.Controls.Add(new LiteralControl(string.Format(@" <META http-equiv='REFRESH' content=2;url={0}> ", MyAccountUrl)));
    }
예제 #8
0
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            if (Session["email"] == null)
            {
                Server.Transfer("CommonLogin.aspx");
            }
            else
            {
                Users            u      = UsersDB.getUserbyEmail(Session["email"].ToString());
                List <LiveDonor> ldlist = LiveDonorDB.getLiveDonorbyuserID(u.userId);
                if (ldlist.Count == 0)
                {
                    Label1.Text = "Sorry! You doesn't have any current organ donation!";
                    PanelFinishRegister.Visible = false;
                }
                else
                {
                    foreach (LiveDonor l in ldlist)
                    {
                        if (l.status == "not allotted" || l.status == "allotted")
                        {
                            tempid = l.ldonorID;
                            PanelFinishRegister.Visible = true;
                            break;
                        }
                        else
                        {
                            tempid = "0";
                        }
                    }
                    if (tempid == "0")
                    {
                        Label1.Text = "Sorry! You doesn't have any current organ donation!";
                        PanelFinishRegister.Visible = false;
                    }
                    else
                    {
                        LiveDonor ld = LiveDonorDB.getLiveDonorbyID(tempid);

                        PanelFinishRegister.Visible = true;
                        lblComment.Text             = ld.comments;
                        lblDAddress.Text            = ld.doctorAddress;
                        lblDEmail.Text = ld.doctorEmail;
                        lblDoctor.Text = ld.doctorName;
                        lblDPhone.Text = Convert.ToString(ld.doctorNumber);
                        lblOrgan.Text  = ld.organType;
                        lblstatus.Text = ld.status;
                    }
                }

                List <LiveOrganMatching> lom     = LiveOrganMatchingDB.getAllMatches();
                List <LiveOrganMatching> lomshow = new List <LiveOrganMatching>();
                if (lom.Count == 0)
                {
                    lblmatchingF.Text = "Sorry! We haven't found any matching for you right now.";
                    gvMatch.Visible   = false;
                }
                else
                {
                    foreach (LiveOrganMatching l in lom)
                    {
                        if (l.LiveDonor.userid.UserId == u.UserId && l.Status == "current match")
                        {
                            l.Distance = l.Distance / 60;
                            lomshow.Add(l);
                        }
                    }

                    if (lomshow.Count == 0)
                    {
                        lblmatchingF.Text     = "Sorry! We haven't found any matching for you right now.";
                        panelmatching.Visible = false;
                    }
                    else
                    {
                        panelmatching.Visible = true;
                        gvMatch.DataSource    = lomshow;
                        gvMatch.DataBind();
                    }
                }
            }
        }
    }