Обновление источника привязки после добавления, обновления или удаления - PullRequest
0 голосов
/ 21 июня 2011

Мне нужно было знать, есть ли способ обновить источник привязки после добавления, обновления или удаления записей, так что в случае удаления записи я смогу показать правильное количество записей в панели инструментов моего навигатора привязок.

В настоящее время я делаю модуль приложения для расчета заработной платы для добавления банков.Я не могу добавить две последовательные записи (могу добавить только одну за раз прямо сейчас, закройте мое приложение и добавьте еще одну).Мое приложение интегрировано в SAP Business 1.

На моем BankMasterForm.cs у меня есть

private void BankMaintenanceForm_Load(object sender, EventArgs e)
{
    bankMasterBindingSource.DataSource = Program.Kernel.Get<IBankMasterService>().GetAllBankMasters();
}

Я также использую дополнение Ninject для этого приложения

Мой код включенформа IBankMasterService.cs (интерфейс):

namespace Payroll.BLL
{
    public interface IBankMasterService
    {
        IEnumerable<BankMaster> GetAllBankMasters();

        BankMaster GetBankMaster(string code);

        void AddBankMaster(BankMaster bankMaster);

        void UpdateBankMaster(BankMaster bankMaster);

        void DeleteBankMaster(BankMaster bankMaster);

        string GenerateSAPCode();
    }
}

У меня также есть класс BankMasterService.cs:

namespace Payroll.BLL
{
    public class BankMasterService : IBankMasterService
    {
        private readonly IBankMasterRepository _bankMasterRepository;

        public BankMasterService(
            IBankMasterRepository bankMasterRepository)
        {
            Guard.AgainstNullParameter(bankMasterRepository, "bankMasterRepository");

            _bankMasterRepository = bankMasterRepository;
        }

        public IEnumerable<BankMaster> GetAllBankMasters()
        {
            return _bankMasterRepository.SelectAll();
        }

        public BankMaster GetBankMaster(string code)
        {
            var rulesException = new RulesException<BankMaster>();

            // Business rule: Answer Id cannot be less than 1
            if (!code.HasValue())
                rulesException.ErrorFor(x => x.Code, "Code cannot be null");

            if (rulesException.Errors.Any()) throw rulesException;

            return _bankMasterRepository.GetEntity(code);
        }

        public void AddBankMaster(BankMaster bankMaster)
        {
            // Business rule: 0
            var errors = DataAnnotationsValidationRunner.GetErrors(bankMaster);

            var rulesException = new RulesException();

            rulesException.ErrorsForModel(errors);

            // Other validation rules

            if (rulesException.Errors.Any()) throw rulesException;

            // Save to database
            _bankMasterRepository.Insert(bankMaster);
        }

        public void UpdateBankMaster(BankMaster bankMaster)
        {
            // Business rule: 0
            var errors = DataAnnotationsValidationRunner.GetErrors(bankMaster);

            var rulesException = new RulesException();

            rulesException.ErrorsForModel(errors);

            // Other validation rules

            if (rulesException.Errors.Any()) throw rulesException;

            // Save to database
            _bankMasterRepository.Update(bankMaster);
        }

        public void DeleteBankMaster(BankMaster bankMaster)
        {
            var bm = GetBankMaster(bankMaster.Code);

            if (bm != null)
            {
                // Delete from database
                _bankMasterRepository.Delete(bm);
            }
        }

        public string GenerateSAPCode()
        {
            var result = default(long);

            var codesList = from b in GetAllBankMasters()
                            select new { Code = long.Parse(b.Code) };

            codesList = codesList.OrderBy(x => x.Code);

            var lastRecord = codesList.LastOrDefault();

            if (lastRecord != null)
                result = lastRecord.Code + 1;

            return result.ToString();
        }
    }
}

Пример функции удаления в моей форме BankMasterForm.cs:

private void bindingNavigatorDeleteItem_Click(object sender, EventArgs e)
{
    DialogResult result = MessageBox.Show("Are You Sure You Want To Delete This Record?", "Confirm", MessageBoxButtons.YesNo, MessageBoxIcon.Question);

    if (result == DialogResult.Yes)
    {
        // Get service instance
        var bankMasterService = Program.Kernel.Get<IBankMasterService>();

        var bankMasterDelete =
                new BankMaster
                {
                    Code = txt_code.Text
                };

        // Delete record
        bankMasterService.DeleteBankMaster(bankMasterDelete);

        //clear textfields after input
        txt_code.Text = string.Empty;
        txt_bank_code.Text = string.Empty;
        txt_bank_name.Text = string.Empty;
        cb_bank_type.Text = null;
        txt_address1.Text = string.Empty;
        txt_address2.Text = string.Empty;
        txt_comments.Text = string.Empty;

        MessageBox.Show("Bank Details Deleted Successfully");
    }
}

У меня вопрос, как мне получить источник привязки, например:

bankMasterBindingSource.DataSource = Program.Kernel.Get<IBankMasterService>().GetAllBankMasters();

для обновления после удаления, например?

Любая помощь будет в значительной степениоценили.

Ответы [ 2 ]

0 голосов
/ 30 июня 2011

Я нашел ответ. Просто добавьте эту строку кода после каждого редактирования или добавления записи. Обновляет источник привязки.

// Refresh the datasource
bankMasterBindingSource.DataSource = Program.Kernel.Get<IBankMasterService>().GetAllBankMasters().ToList();

Таким образом, вновь добавленные или обновленные записи могут быть "просмотрены" системой

0 голосов
/ 21 июня 2011

Я почти уверен, что вызов .ResetBindings () заставляет его обновить список.

Но, если вы выполняете операцию с графическим интерфейсом, лучше использовать источник привязки для выполнения удаления.Таким образом, вы можете использовать свойства проверки формы и т. Д., А затем внедрить инфраструктуру для выполнения той работы, которая вам нужна.Представьте себе мультиклиентскую систему, в которой одновременно происходит много изменений, список будет постоянно обновляться.Таким образом, источник привязки позволяет вам абстрагироваться, когда и как часто меняется ваше представление, но направлен на поддержание локального состояния, в котором есть определенный уровень здравомыслия.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...