Sunday, October 3, 2021

Get Data on scroll in dropdown in Ajax JS call

Bootstrap Multiselect dropdown, with scroll populating

==================================================

function CustomerMultiSelect() {

    $("#ddlCustomer").attr("multiple", "multiple");

    $('#ddlCustomer').multiselect({

        includeSelectAllOption: false,

        enableFiltering: true,

        enableCaseInsensitiveFiltering: true,

        maxHeight: 200,

        buttonWidth: '165px',

        onChange: function (option, checked) {

            var customer = $("#ddlCustomer").val();

            console.log(bluebook);

        }

    });

    $("#ddlCustomer").multiselect('clearSelection');

    $('.multiselect-clear-filter').css('display', 'none');

    $('.multiselect-search').css('width', '97%');

    $('.customer ul')[0].addEventListener('scroll', dataLoadOnScroll, true);

}


fetch data on Ajax call and bind 100 records at once

=======================================

 function GetCustomers(bluebook) {

    $('#custLoad').show();

    var blValues = bluebook.toString();

    if (bluebook !== "null")

    {

        $.ajax({

            url: "Default.aspx/GetCustomersOnBluebook",

            type: "POST",

            data: JSON.stringify({"values":blValues}),

            contentType: 'application/json;charset=utf-8',

            dataType: 'JSON',

            success: function (data) {

                $('#ddlCustomer').multiselect('destroy');

                $('#ddlCustomer').empty();

                var option = "";

                if (data != null) {

                    alert(data.d.length);

                    currentRecordNumber = 300; page = 2;

                    datasource = data.d;

                    var newData = data.d.slice(0, 300);

                    for (i = 0; i < newData.length; i++) {

                        option += '<option value="' + newData[i].ID + '">' + newData[i].Name + '</option>';                       

                    }

                    $('#ddlCustomer').append(option);

                }

                CustomerMultiSelect();

                $('#custLoad').hide();

            },

            failure: function (error) {

                console.log(JSON.stringify(error));

            }


        });

    }

}

= scroll function bind
=============================================

var currentRecordNumber; var page;

function dataLoadOnScroll() {
     var currentPage;
    var ul = $('.customer ul')[0];
    if (Math.ceil(ul.scrollTop + ul.offsetHeight) >= ul.scrollHeight) {
        const newDatasource = getPaginatedData();
        if (newDatasource) {
            currentRecordNumber = currentRecordNumber + newDatasource.length;
            currentPage = page;
            var option = "";
            for (i = 0; i < newDatasource.length; i++) {
                option += '<option value="' + newDatasource[i].ID + '">' + newDatasource[i].Name + '</option>';
              }
            $('#ddlCustomer').append(option);
            $('#ddlCustomer').multiselect('rebuild');
        }
        else {
            $('.customer ul')[0].removeEventListener('scroll', dataLoadOnScroll, true);
        }       
    }
    $('.customer .multiselect-clear-filter').css('display', 'none');
}

function getPaginatedData() {
    let numberOfRecordsToDisplay = 300;
    let returnArray = "";
    let startingIndex = numberOfRecordsToDisplay * page - numberOfRecordsToDisplay;
    let endingIndex = numberOfRecordsToDisplay * page - 1;
    if (datasource.length > startingIndex && datasource.length >= endingIndex) {
        if (startingIndex !== -300)
            returnArray = datasource.slice(startingIndex, endingIndex + 1);
        else
            return returnArray;
    }
    else if (datasource.length > startingIndex && datasource.length < endingIndex) {
        returnArray = datasource.slice(startingIndex);
    }
    page = datasource.length > endingIndex ? page + 1 : 0
    return returnArray;
}

Thursday, September 16, 2021

file upload to document library and get file from library

  public void UploadFile()

        {

            if (fileUpload.HasFile)

            {

                string fileName = Path.GetFileName(fileUpload.PostedFile.FileName);

                if (!string.IsNullOrEmpty(fileName))

                {

                    fileName = fileName.Split('.')[0];

                    fileName = fileName + "_" + DateTime.Now.ToString("MMddyyyyHHmm") + ".pdf";

                }

                var spContext = SharePointContextProvider.Current.GetSharePointContext(Context);

                using (var clientContext = spContext.CreateAppOnlyClientContextForSPHost())

                {

                    try

                    {

                        FileCreationInformation newFile = new FileCreationInformation();

                        byte[] FileContent = fileUpload.FileBytes;

                        newFile.ContentStream = new MemoryStream(FileContent);

                        newFile.Url = Path.GetFileName(fileName);

                        List list = clientContext.Web.Lists.GetByTitle(Constant.BIM_Comm_Docs);

                        Folder Clientfolder = list.RootFolder;

                        var uploadFile = Clientfolder.Files.Add(newFile);


                        clientContext.Load(Clientfolder);

                        clientContext.Load(uploadFile);

                        clientContext.ExecuteQuery();

                    }

                    catch (Exception ex)

                    {

                        ErrorLog(clientContext, ex.Message, ex.Source, "UploadFile", "Default.aspx");

                    }


                }

            }

        }

============================================================

 // Get pdf file byte content

        public void GetLatestFileFromLibrary()

        {

            var spContext = SharePointContextProvider.Current.GetSharePointContext(Context);

            using (var clientContext = spContext.CreateUserClientContextForSPHost())

            {

                try

                {

                    List list = clientContext.Web.Lists.GetByTitle(Constant.BIM_Comm_Docs);

                    var q = new CamlQuery() { ViewXml = "<View><Query><OrderBy><FieldRef Name='Created' Ascending='False' /></OrderBy></Query><RowLimit>1</RowLimit> </View>" };

                    var items = list.GetItems(q);

                    clientContext.Load(items);

                    clientContext.ExecuteQuery();


                    if (items != null && items.Count > 0)

                    {

                        Microsoft.SharePoint.Client.ListItem item = items[0];

                        var filePath = Convert.ToString(item["FileRef"]);

                        Microsoft.SharePoint.Client.File file = clientContext.Web.GetFileByServerRelativeUrl(filePath);


                        if (file != null)

                        {

                            var stream = file.OpenBinaryStream();

                            clientContext.Load(file);

                            clientContext.ExecuteQuery();

                            using (System.IO.MemoryStream mStream = new System.IO.MemoryStream())

                            {

                                if (stream != null)

                                {

                                    stream.Value.CopyTo(mStream);                                   

                                    byte[] bytes = mStream.ToArray();

                                    string base64String = Convert.ToBase64String(bytes, 0, bytes.Length);

                                    hdnByteArray.Value = base64String;

                                }

                            }

                        }

                    }

                }

                catch (Exception ex)

                {

                    ErrorLog(clientContext, ex.Message, ex.Source, "GetLatestFileFromLibrary", "Default.aspx");

                }

            }

        }

Thursday, September 9, 2021

Design HTML for AGS PMA template

 Fixed Width Div css:

---------------------------

.release_scroll {
  1. height: 626px;
  2. width: 458px;
  3. position: absolute;
  4. top: 76px;
  5. left: 0px;
  6. overflow-y: scroll;