private void StepCategory_Load(object sender, EventArgs e) { if (!DesignMode) { Localizer.TranslateControl(this); Dictionary<int, SurveyType> surveys = new Dictionary<int, SurveyType>(); foreach (var survey in options.Surveys) if (!surveys.ContainsKey(survey.TypeOfSurvey.Id)) surveys.Add(survey.TypeOfSurvey.Id, survey.TypeOfSurvey); if (surveys.Count == 0 || options.SplitType == SplittingType.Merge) { DoNext(); return; } MessageBox.Show(Translations.SplittingSurveyWarning, Translations.ValidationErrorTitle); foreach (var t in surveys.Values) { var index = tblNewUnits.RowStyles.Add(new RowStyle { SizeType = SizeType.AutoSize }); var lblName = new H3bLabel { AutoSize = true, Text = t.SurveyTypeName, Margin = new Padding(0, 5, 10, 5) }; tblNewUnits.Controls.Add(lblName, 0, index); var lnk = new H3Link { Text = Translations.DownloadImportFile, Margin = new Padding(0, 5, 10, 5) }; tblNewUnits.Controls.Add(lnk, 1, index); lnk.ClickOverride += () => { List<IHaveDynamicIndicatorValues> forms = options.Surveys.Where(s => s.TypeOfSurvey.Id == t.Id).Cast<IHaveDynamicIndicatorValues>().ToList(); SurveyImporter importer = new SurveyImporter(); importer.SetType(t.Id); var payload = new SplitDistro.WorkerPayload { FileName = Util.CleanFilename(t.SurveyTypeName) + "_" + options.SplitType.ToString() + DateTime.Now.ToString("yyyyMMdd") + ".xlsx", Importer = importer, Forms = forms }; SplitDistro.CreateDownload(payload); }; var lnk2 = new H3Link { Text = Translations.UploadImportFile, Margin = new Padding(0, 5, 10, 5) }; tblNewUnits.Controls.Add(lnk2, 2, index); lnk2.ClickOverride += () => { Upload(t); }; } } }
private void Upload(SurveyType stype) { List<IHaveDynamicIndicatorValues> forms = new List<IHaveDynamicIndicatorValues>(); forms = options.Surveys.Where(d => d.TypeOfSurvey.Id == stype.Id).Cast<IHaveDynamicIndicatorValues>().ToList(); SurveyImporter importer = new SurveyImporter(); importer.SetType(stype.Id); var payload = new Nada.UI.View.Wizard.SplitDistro.WorkerPayload { Importer = importer, Forms = forms, }; OpenFileDialog ofd = new OpenFileDialog(); ofd.Filter = Translations.ExcelFiles + " (*.xlsx)|*.xlsx"; ofd.DefaultExt = ".xlsx"; if (ofd.ShowDialog() == DialogResult.OK) { OnSwitchStep(new WorkingStep(Translations.ImportingFile)); payload.FileName = ofd.FileName; BackgroundWorker importerWorker = new BackgroundWorker(); importerWorker.DoWork += importerWorker_DoWork; importerWorker.RunWorkerCompleted += importerWorker_RunWorkerCompleted; importerWorker.RunWorkerAsync(payload); } }