Change "Download Status" column to "Liberate" button column. Displays text status. No functionality added yet
This commit is contained in:
parent
9534969c2d
commit
498aeaac3a
@ -6,5 +6,5 @@
|
|||||||
cause the file to be unrecognizable by the program.
|
cause the file to be unrecognizable by the program.
|
||||||
-->
|
-->
|
||||||
<GenericObjectDataSource DisplayName="GridEntry" Version="1.0" xmlns="urn:schemas-microsoft-com:xml-msdatasource">
|
<GenericObjectDataSource DisplayName="GridEntry" Version="1.0" xmlns="urn:schemas-microsoft-com:xml-msdatasource">
|
||||||
<TypeInfo>WinFormsDesigner.GridEntry, LibationWinForm, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null</TypeInfo>
|
<TypeInfo>LibationWinForm.GridEntry, LibationWinForm, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null</TypeInfo>
|
||||||
</GenericObjectDataSource>
|
</GenericObjectDataSource>
|
||||||
@ -26,6 +26,45 @@ namespace LibationWinForm
|
|||||||
[Browsable(false)]
|
[Browsable(false)]
|
||||||
public IEnumerable<string> TagsEnumerated => book.UserDefinedItem.TagsEnumerated;
|
public IEnumerable<string> TagsEnumerated => book.UserDefinedItem.TagsEnumerated;
|
||||||
|
|
||||||
|
[Browsable(false)]
|
||||||
|
public string Download_Status
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
var print
|
||||||
|
= FileManager.AudibleFileStorage.Audio.Exists(book.AudibleProductId) ? "Liberated"
|
||||||
|
: FileManager.AudibleFileStorage.AAX.Exists(book.AudibleProductId) ? "DRM"
|
||||||
|
: "NOT d/l'ed";
|
||||||
|
|
||||||
|
if (!book.Supplements.Any())
|
||||||
|
return print;
|
||||||
|
|
||||||
|
print += "\r\n";
|
||||||
|
|
||||||
|
var downloadStatuses = book.Supplements
|
||||||
|
.Select(d => FileManager.AudibleFileStorage.PDF.Exists(book.AudibleProductId))
|
||||||
|
// break delayed execution right now!
|
||||||
|
.ToList();
|
||||||
|
var count = downloadStatuses.Count;
|
||||||
|
if (count == 1)
|
||||||
|
{
|
||||||
|
print += downloadStatuses[0]
|
||||||
|
? "PDF d/l'ed"
|
||||||
|
: "PDF NOT d/l'ed";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var downloadedCount = downloadStatuses.Count(s => s);
|
||||||
|
print
|
||||||
|
+= downloadedCount == count ? $"{count} PDFs d/l'ed"
|
||||||
|
: downloadedCount == 0 ? $"{count} PDFs NOT d/l'ed"
|
||||||
|
: $"{downloadedCount} of {count} PDFs d/l'ed";
|
||||||
|
}
|
||||||
|
|
||||||
|
return print;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// displayValues is what gets displayed
|
// displayValues is what gets displayed
|
||||||
// the value that gets returned from the property is the cell's value
|
// the value that gets returned from the property is the cell's value
|
||||||
// this allows for the value to be sorted one way and displayed another
|
// this allows for the value to be sorted one way and displayed another
|
||||||
@ -176,43 +215,5 @@ namespace LibationWinForm
|
|||||||
return string.Join("\r\n", details);
|
return string.Join("\r\n", details);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Download_Status
|
|
||||||
{
|
|
||||||
get
|
|
||||||
{
|
|
||||||
var print
|
|
||||||
= FileManager.AudibleFileStorage.Audio.Exists(book.AudibleProductId) ? "Liberated"
|
|
||||||
: FileManager.AudibleFileStorage.AAX.Exists(book.AudibleProductId) ? "DRM"
|
|
||||||
: "NOT d/l'ed";
|
|
||||||
|
|
||||||
if (!book.Supplements.Any())
|
|
||||||
return print;
|
|
||||||
|
|
||||||
print += "\r\n";
|
|
||||||
|
|
||||||
var downloadStatuses = book.Supplements
|
|
||||||
.Select(d => FileManager.AudibleFileStorage.PDF.Exists(book.AudibleProductId))
|
|
||||||
// break delayed execution right now!
|
|
||||||
.ToList();
|
|
||||||
var count = downloadStatuses.Count;
|
|
||||||
if (count == 1)
|
|
||||||
{
|
|
||||||
print += downloadStatuses[0]
|
|
||||||
? "PDF d/l'ed"
|
|
||||||
: "PDF NOT d/l'ed";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var downloadedCount = downloadStatuses.Count(s => s);
|
|
||||||
print
|
|
||||||
+= downloadedCount == count ? $"{count} PDFs d/l'ed"
|
|
||||||
: downloadedCount == 0 ? $"{count} PDFs NOT d/l'ed"
|
|
||||||
: $"{downloadedCount} of {count} PDFs d/l'ed";
|
|
||||||
}
|
|
||||||
|
|
||||||
return print;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
12
LibationWinForm/UNTESTED/ProductsGrid.Designer.cs
generated
12
LibationWinForm/UNTESTED/ProductsGrid.Designer.cs
generated
@ -43,7 +43,6 @@
|
|||||||
this.dataGridViewTextBoxColumn9 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
this.dataGridViewTextBoxColumn9 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||||
this.dataGridViewTextBoxColumn10 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
this.dataGridViewTextBoxColumn10 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||||
this.dataGridViewTextBoxColumn11 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
this.dataGridViewTextBoxColumn11 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||||
this.dataGridViewTextBoxColumn12 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
|
||||||
((System.ComponentModel.ISupportInitialize)(this.gridEntryBindingSource)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.gridEntryBindingSource)).BeginInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.gridEntryDataGridView)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.gridEntryDataGridView)).BeginInit();
|
||||||
this.SuspendLayout();
|
this.SuspendLayout();
|
||||||
@ -68,8 +67,7 @@
|
|||||||
this.dataGridViewTextBoxColumn8,
|
this.dataGridViewTextBoxColumn8,
|
||||||
this.dataGridViewTextBoxColumn9,
|
this.dataGridViewTextBoxColumn9,
|
||||||
this.dataGridViewTextBoxColumn10,
|
this.dataGridViewTextBoxColumn10,
|
||||||
this.dataGridViewTextBoxColumn11,
|
this.dataGridViewTextBoxColumn11});
|
||||||
this.dataGridViewTextBoxColumn12});
|
|
||||||
this.gridEntryDataGridView.DataSource = this.gridEntryBindingSource;
|
this.gridEntryDataGridView.DataSource = this.gridEntryBindingSource;
|
||||||
this.gridEntryDataGridView.Location = new System.Drawing.Point(54, 58);
|
this.gridEntryDataGridView.Location = new System.Drawing.Point(54, 58);
|
||||||
this.gridEntryDataGridView.Name = "gridEntryDataGridView";
|
this.gridEntryDataGridView.Name = "gridEntryDataGridView";
|
||||||
@ -160,13 +158,6 @@
|
|||||||
this.dataGridViewTextBoxColumn11.Name = "dataGridViewTextBoxColumn11";
|
this.dataGridViewTextBoxColumn11.Name = "dataGridViewTextBoxColumn11";
|
||||||
this.dataGridViewTextBoxColumn11.ReadOnly = true;
|
this.dataGridViewTextBoxColumn11.ReadOnly = true;
|
||||||
//
|
//
|
||||||
// dataGridViewTextBoxColumn12
|
|
||||||
//
|
|
||||||
this.dataGridViewTextBoxColumn12.DataPropertyName = "Download_Status";
|
|
||||||
this.dataGridViewTextBoxColumn12.HeaderText = "Download_Status";
|
|
||||||
this.dataGridViewTextBoxColumn12.Name = "dataGridViewTextBoxColumn12";
|
|
||||||
this.dataGridViewTextBoxColumn12.ReadOnly = true;
|
|
||||||
//
|
|
||||||
// ProductsGrid
|
// ProductsGrid
|
||||||
//
|
//
|
||||||
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
||||||
@ -196,6 +187,5 @@
|
|||||||
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn9;
|
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn9;
|
||||||
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn10;
|
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn10;
|
||||||
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn11;
|
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn11;
|
||||||
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn12;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -28,27 +28,28 @@ namespace LibationWinForm
|
|||||||
{
|
{
|
||||||
public event EventHandler<int> VisibleCountChanged;
|
public event EventHandler<int> VisibleCountChanged;
|
||||||
|
|
||||||
private DataGridView dataGridView;
|
private const string EDIT_TAGS = "Edit Tags";
|
||||||
|
private const string LIBERATE = "Liberate";
|
||||||
|
|
||||||
|
// alias
|
||||||
|
private DataGridView dataGridView => gridEntryDataGridView;
|
||||||
|
|
||||||
private LibationContext context;
|
private LibationContext context;
|
||||||
|
|
||||||
public ProductsGrid()
|
public ProductsGrid()
|
||||||
{
|
{
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
formatDataGridView();
|
||||||
|
addLiberateButtons();
|
||||||
|
addEditTagsButtons();
|
||||||
|
formatColumns();
|
||||||
Disposed += (_, __) => context?.Dispose();
|
Disposed += (_, __) => context?.Dispose();
|
||||||
|
|
||||||
manageLiveImageUpdateSubscriptions();
|
manageLiveImageUpdateSubscriptions();
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool hasBeenDisplayed = false;
|
private void formatDataGridView()
|
||||||
public void Display()
|
|
||||||
{
|
{
|
||||||
if (hasBeenDisplayed)
|
|
||||||
return;
|
|
||||||
hasBeenDisplayed = true;
|
|
||||||
|
|
||||||
dataGridView = gridEntryDataGridView;
|
|
||||||
|
|
||||||
dataGridView.Dock = DockStyle.Fill;
|
dataGridView.Dock = DockStyle.Fill;
|
||||||
dataGridView.AllowUserToAddRows = false;
|
dataGridView.AllowUserToAddRows = false;
|
||||||
dataGridView.AllowUserToDeleteRows = false;
|
dataGridView.AllowUserToDeleteRows = false;
|
||||||
@ -57,26 +58,150 @@ namespace LibationWinForm
|
|||||||
dataGridView.DefaultCellStyle.WrapMode = DataGridViewTriState.True;
|
dataGridView.DefaultCellStyle.WrapMode = DataGridViewTriState.True;
|
||||||
dataGridView.ReadOnly = true;
|
dataGridView.ReadOnly = true;
|
||||||
dataGridView.RowHeadersVisible = false;
|
dataGridView.RowHeadersVisible = false;
|
||||||
|
|
||||||
// adjust height for 80x80 pictures.
|
// adjust height for 80x80 pictures.
|
||||||
// this must be done before databinding. or can alter later by iterating through rows
|
// this must be done before databinding. or can alter later by iterating through rows
|
||||||
dataGridView.RowTemplate.Height = 82;
|
dataGridView.RowTemplate.Height = 82;
|
||||||
dataGridView.CellFormatting += replaceFormatted;
|
dataGridView.CellFormatting += replaceFormatted;
|
||||||
dataGridView.CellFormatting += hiddenFormatting;
|
dataGridView.CellFormatting += hiddenFormatting;
|
||||||
|
|
||||||
// sorting breaks filters. must reapply filters after sorting
|
// sorting breaks filters. must reapply filters after sorting
|
||||||
dataGridView.Sorted += (_, __) => filter();
|
dataGridView.Sorted += (_, __) => filter();
|
||||||
|
|
||||||
{ // add tag buttons
|
|
||||||
var editUserTagsButton = new DataGridViewButtonColumn { HeaderText = "Edit Tags" };
|
|
||||||
dataGridView.Columns.Add(editUserTagsButton);
|
|
||||||
|
|
||||||
// add image and handle click
|
|
||||||
dataGridView.CellPainting += paintEditTag_TextAndImage;
|
|
||||||
dataGridView.CellContentClick += dataGridView_GridButtonClick;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#region format text cells. ie: not buttons
|
||||||
|
private void replaceFormatted(object sender, DataGridViewCellFormattingEventArgs e)
|
||||||
|
{
|
||||||
|
var col = ((DataGridView)sender).Columns[e.ColumnIndex];
|
||||||
|
if (col is DataGridViewTextBoxColumn textCol && GetGridEntry(e.RowIndex).TryDisplayValue(textCol.Name, out string value))
|
||||||
|
e.Value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void hiddenFormatting(object _, DataGridViewCellFormattingEventArgs e)
|
||||||
|
{
|
||||||
|
var isHidden = GetGridEntry(e.RowIndex).TagsEnumerated.Contains("hidden");
|
||||||
|
|
||||||
|
dataGridView.Rows[e.RowIndex].Cells[e.ColumnIndex].Style
|
||||||
|
= isHidden
|
||||||
|
? new DataGridViewCellStyle { ForeColor = Color.LightGray }
|
||||||
|
: dataGridView.DefaultCellStyle;
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region liberation buttons
|
||||||
|
private void addLiberateButtons()
|
||||||
|
{
|
||||||
|
dataGridView.Columns.Insert(0, new DataGridViewButtonColumn { HeaderText = LIBERATE });
|
||||||
|
|
||||||
|
dataGridView.CellPainting += liberate_Paint;
|
||||||
|
dataGridView.CellContentClick += liberate_Click;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void liberate_Paint(object sender, DataGridViewCellPaintingEventArgs e)
|
||||||
|
{
|
||||||
|
var dgv = (DataGridView)sender;
|
||||||
|
|
||||||
|
if (!isColumnValid(dgv, e.RowIndex, e.ColumnIndex, LIBERATE))
|
||||||
|
return;
|
||||||
|
|
||||||
|
dgv.Rows[e.RowIndex].Cells[e.ColumnIndex].Value = GetGridEntry(e.RowIndex).Download_Status;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void liberate_Click(object sender, DataGridViewCellEventArgs e)
|
||||||
|
{
|
||||||
|
var dgv = (DataGridView)sender;
|
||||||
|
|
||||||
|
if (!isColumnValid(dgv, e.RowIndex, e.ColumnIndex, LIBERATE))
|
||||||
|
return;
|
||||||
|
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region tag buttons
|
||||||
|
private void addEditTagsButtons()
|
||||||
|
{
|
||||||
|
dataGridView.Columns.Add(new DataGridViewButtonColumn { HeaderText = EDIT_TAGS });
|
||||||
|
|
||||||
|
dataGridView.CellPainting += editTags_Paint;
|
||||||
|
dataGridView.CellContentClick += editTags_Click;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void editTags_Paint(object sender, DataGridViewCellPaintingEventArgs e)
|
||||||
|
{
|
||||||
|
// DataGridView Image for Button Column: https://stackoverflow.com/a/36253883
|
||||||
|
|
||||||
|
var dgv = (DataGridView)sender;
|
||||||
|
|
||||||
|
if (!isColumnValid(dgv, e.RowIndex, e.ColumnIndex, EDIT_TAGS))
|
||||||
|
return;
|
||||||
|
|
||||||
|
var displayTags = GetGridEntry(e.RowIndex).TagsEnumerated.ToList();
|
||||||
|
|
||||||
|
var cell = dgv.Rows[e.RowIndex].Cells[e.ColumnIndex];
|
||||||
|
|
||||||
|
if (displayTags.Any())
|
||||||
|
cell.Value = string.Join("\r\n", displayTags);
|
||||||
|
else // no tags: use image
|
||||||
|
{
|
||||||
|
// clear tag text
|
||||||
|
cell.Value = "";
|
||||||
|
|
||||||
|
var image = Properties.Resources.edit_tags_25x25;
|
||||||
|
|
||||||
|
e.Paint(e.CellBounds, DataGridViewPaintParts.All);
|
||||||
|
|
||||||
|
var w = image.Width;
|
||||||
|
var h = image.Height;
|
||||||
|
var x = e.CellBounds.Left + (e.CellBounds.Width - w) / 2;
|
||||||
|
var y = e.CellBounds.Top + (e.CellBounds.Height - h) / 2;
|
||||||
|
|
||||||
|
e.Graphics.DrawImage(image, new Rectangle(x, y, w, h));
|
||||||
|
e.Handled = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void editTags_Click(object sender, DataGridViewCellEventArgs e)
|
||||||
|
{
|
||||||
|
// handle grid button click: https://stackoverflow.com/a/13687844
|
||||||
|
|
||||||
|
var dgv = (DataGridView)sender;
|
||||||
|
|
||||||
|
if (!isColumnValid(dgv, e.RowIndex, e.ColumnIndex, EDIT_TAGS))
|
||||||
|
return;
|
||||||
|
|
||||||
|
var liveGridEntry = GetGridEntry(e.RowIndex);
|
||||||
|
|
||||||
|
// EditTagsDialog should display better-formatted title
|
||||||
|
liveGridEntry.TryDisplayValue(nameof(liveGridEntry.Title), out string value);
|
||||||
|
|
||||||
|
var editTagsForm = new EditTagsDialog(value, liveGridEntry.Tags);
|
||||||
|
if (editTagsForm.ShowDialog() != DialogResult.OK)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var qtyChanges = context.UpdateTags(liveGridEntry.GetBook(), editTagsForm.NewTags);
|
||||||
|
if (qtyChanges == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// force a re-draw, and re-apply filters
|
||||||
|
|
||||||
|
// needed to update text colors
|
||||||
|
dgv.InvalidateRow(e.RowIndex);
|
||||||
|
|
||||||
|
filter();
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
private static bool isColumnValid(DataGridView dgv, int rowIndex, int colIndex, string colName)
|
||||||
|
{
|
||||||
|
var col = dgv.Columns[colIndex];
|
||||||
|
return rowIndex >= 0 && col.HeaderText == colName && col is DataGridViewButtonColumn;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void formatColumns()
|
||||||
|
{
|
||||||
for (var i = dataGridView.ColumnCount - 1; i >= 0; i--)
|
for (var i = dataGridView.ColumnCount - 1; i >= 0; i--)
|
||||||
{
|
{
|
||||||
DataGridViewColumn col = dataGridView.Columns[i];
|
var col = dataGridView.Columns[i];
|
||||||
|
|
||||||
// initial HeaderText is the lookup name from GridEntry class. any formatting below won't change this
|
// initial HeaderText is the lookup name from GridEntry class. any formatting below won't change this
|
||||||
col.Name = col.HeaderText;
|
col.Name = col.HeaderText;
|
||||||
@ -94,8 +219,32 @@ namespace LibationWinForm
|
|||||||
var n when n.In(nameof(GridEntry.My_Rating), nameof(GridEntry.Product_Rating)) => col.Width + 8,
|
var n when n.In(nameof(GridEntry.My_Rating), nameof(GridEntry.Product_Rating)) => col.Width + 8,
|
||||||
_ => col.Width
|
_ => col.Width
|
||||||
};
|
};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#region live update newly downloaded and cached images
|
||||||
|
private void manageLiveImageUpdateSubscriptions()
|
||||||
|
{
|
||||||
|
FileManager.PictureStorage.PictureCached += crossThreadImageUpdate;
|
||||||
|
Disposed += (_, __) => FileManager.PictureStorage.PictureCached -= crossThreadImageUpdate;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void crossThreadImageUpdate(object _, string pictureId)
|
||||||
|
=> dataGridView.UIThread(() => updateRowImage(pictureId));
|
||||||
|
private void updateRowImage(string pictureId)
|
||||||
|
{
|
||||||
|
var rowId = GetRowId((ge) => ge.GetBook().PictureId == pictureId);
|
||||||
|
if (rowId > -1)
|
||||||
|
dataGridView.InvalidateRow(rowId);
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
private bool hasBeenDisplayed = false;
|
||||||
|
public void Display()
|
||||||
|
{
|
||||||
|
if (hasBeenDisplayed)
|
||||||
|
return;
|
||||||
|
hasBeenDisplayed = true;
|
||||||
|
|
||||||
//
|
//
|
||||||
// transform into sorted GridEntry.s BEFORE binding
|
// transform into sorted GridEntry.s BEFORE binding
|
||||||
@ -132,90 +281,6 @@ namespace LibationWinForm
|
|||||||
filter();
|
filter();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void paintEditTag_TextAndImage(object sender, DataGridViewCellPaintingEventArgs e)
|
|
||||||
{
|
|
||||||
// DataGridView Image for Button Column: https://stackoverflow.com/a/36253883
|
|
||||||
|
|
||||||
if (e.RowIndex < 0 || !(((DataGridView)sender).Columns[e.ColumnIndex] is DataGridViewButtonColumn))
|
|
||||||
return;
|
|
||||||
|
|
||||||
|
|
||||||
var gridEntry = getGridEntry(e.RowIndex);
|
|
||||||
var displayTags = gridEntry.TagsEnumerated.ToList();
|
|
||||||
|
|
||||||
if (displayTags.Any())
|
|
||||||
dataGridView.Rows[e.RowIndex].Cells[e.ColumnIndex].Value = string.Join("\r\n", displayTags);
|
|
||||||
else // no tags: use image
|
|
||||||
{
|
|
||||||
// clear tag text
|
|
||||||
dataGridView.Rows[e.RowIndex].Cells[e.ColumnIndex].Value = "";
|
|
||||||
|
|
||||||
// images from: icons8.com -- search: tags
|
|
||||||
var image = Properties.Resources.edit_tags_25x25;
|
|
||||||
|
|
||||||
e.Paint(e.CellBounds, DataGridViewPaintParts.All);
|
|
||||||
|
|
||||||
var w = image.Width;
|
|
||||||
var h = image.Height;
|
|
||||||
var x = e.CellBounds.Left + (e.CellBounds.Width - w) / 2;
|
|
||||||
var y = e.CellBounds.Top + (e.CellBounds.Height - h) / 2;
|
|
||||||
|
|
||||||
e.Graphics.DrawImage(image, new Rectangle(x, y, w, h));
|
|
||||||
e.Handled = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void dataGridView_GridButtonClick(object sender, DataGridViewCellEventArgs e)
|
|
||||||
{
|
|
||||||
// handle grid button click: https://stackoverflow.com/a/13687844
|
|
||||||
|
|
||||||
if (e.RowIndex < 0)
|
|
||||||
return;
|
|
||||||
if (sender != dataGridView)
|
|
||||||
throw new Exception($"{nameof(dataGridView_GridButtonClick)} has incorrect sender ...somehow");
|
|
||||||
if (!(dataGridView.Columns[e.ColumnIndex] is DataGridViewButtonColumn))
|
|
||||||
return;
|
|
||||||
|
|
||||||
var liveGridEntry = getGridEntry(e.RowIndex);
|
|
||||||
|
|
||||||
// EditTagsDialog should display better-formatted title
|
|
||||||
liveGridEntry.TryDisplayValue(nameof(liveGridEntry.Title), out string value);
|
|
||||||
|
|
||||||
var editTagsForm = new EditTagsDialog(value, liveGridEntry.Tags);
|
|
||||||
if (editTagsForm.ShowDialog() != DialogResult.OK)
|
|
||||||
return;
|
|
||||||
|
|
||||||
var qtyChanges = context.UpdateTags(liveGridEntry.GetBook(), editTagsForm.NewTags);
|
|
||||||
if (qtyChanges == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// force a re-draw, and re-apply filters
|
|
||||||
|
|
||||||
// needed to update text colors
|
|
||||||
dataGridView.InvalidateRow(e.RowIndex);
|
|
||||||
|
|
||||||
filter();
|
|
||||||
}
|
|
||||||
|
|
||||||
#region Cell Formatting
|
|
||||||
private void replaceFormatted(object sender, DataGridViewCellFormattingEventArgs e)
|
|
||||||
{
|
|
||||||
var col = ((DataGridView)sender).Columns[e.ColumnIndex];
|
|
||||||
if (col is DataGridViewTextBoxColumn textCol && getGridEntry(e.RowIndex).TryDisplayValue(textCol.Name, out string value))
|
|
||||||
e.Value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void hiddenFormatting(object _, DataGridViewCellFormattingEventArgs e)
|
|
||||||
{
|
|
||||||
var isHidden = getGridEntry(e.RowIndex).TagsEnumerated.Contains("hidden");
|
|
||||||
|
|
||||||
dataGridView.Rows[e.RowIndex].Cells[e.ColumnIndex].Style
|
|
||||||
= isHidden
|
|
||||||
? new DataGridViewCellStyle { ForeColor = Color.LightGray }
|
|
||||||
: dataGridView.DefaultCellStyle;
|
|
||||||
}
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
#region filter
|
#region filter
|
||||||
string _filterSearchString;
|
string _filterSearchString;
|
||||||
private void filter() => Filter(_filterSearchString);
|
private void filter() => Filter(_filterSearchString);
|
||||||
@ -234,7 +299,7 @@ namespace LibationWinForm
|
|||||||
currencyManager.SuspendBinding();
|
currencyManager.SuspendBinding();
|
||||||
{
|
{
|
||||||
for (var r = dataGridView.RowCount - 1; r >= 0; r--)
|
for (var r = dataGridView.RowCount - 1; r >= 0; r--)
|
||||||
dataGridView.Rows[r].Visible = productIds.Contains(getGridEntry(r).GetBook().AudibleProductId);
|
dataGridView.Rows[r].Visible = productIds.Contains(GetGridEntry(r).GetBook().AudibleProductId);
|
||||||
}
|
}
|
||||||
currencyManager.ResumeBinding();
|
currencyManager.ResumeBinding();
|
||||||
VisibleCountChanged?.Invoke(this, dataGridView.AsEnumerable().Count(r => r.Visible));
|
VisibleCountChanged?.Invoke(this, dataGridView.AsEnumerable().Count(r => r.Visible));
|
||||||
@ -243,32 +308,8 @@ namespace LibationWinForm
|
|||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region live update newly downloaded and cached images
|
private int GetRowId(Func<GridEntry, bool> func) => dataGridView.GetRowIdOfBoundItem(func);
|
||||||
private void manageLiveImageUpdateSubscriptions()
|
|
||||||
{
|
|
||||||
FileManager.PictureStorage.PictureCached += crossThreadImageUpdate;
|
|
||||||
Disposed += (_, __) => FileManager.PictureStorage.PictureCached -= crossThreadImageUpdate;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void crossThreadImageUpdate(object _, string pictureId)
|
private GridEntry GetGridEntry(int rowIndex) => dataGridView.GetBoundItem<GridEntry>(rowIndex);
|
||||||
=> dataGridView.UIThread(() => updateRowImage(pictureId));
|
|
||||||
private void updateRowImage(string pictureId)
|
|
||||||
{
|
|
||||||
var rowId = getRowId((ge) => ge.GetBook().PictureId == pictureId);
|
|
||||||
if (rowId > -1)
|
|
||||||
dataGridView.InvalidateRow(rowId);
|
|
||||||
}
|
|
||||||
#endregion
|
|
||||||
|
|
||||||
private GridEntry getGridEntry(int rowIndex) => (GridEntry)dataGridView.Rows[rowIndex].DataBoundItem;
|
|
||||||
|
|
||||||
private int getRowId(Func<GridEntry, bool> func)
|
|
||||||
{
|
|
||||||
for (var r = 0; r < dataGridView.RowCount; r++)
|
|
||||||
if (func(getGridEntry(r)))
|
|
||||||
return r;
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -40,6 +40,12 @@ publish win64 platform, single-file
|
|||||||
dotnet publish -r win-x64 -c Release /p:PublishSingleFile=true
|
dotnet publish -r win-x64 -c Release /p:PublishSingleFile=true
|
||||||
-- end HOW TO PUBLISH ---------------------------------------------------------------------------------------------------------------------
|
-- end HOW TO PUBLISH ---------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
-- begin IMAGES ---------------------------------------------------------------------------------------------------------------------
|
||||||
|
edit tags icon images from:
|
||||||
|
icons8.com
|
||||||
|
search: tags
|
||||||
|
-- end IMAGES ---------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
-- begin AUDIBLE DETAILS ---------------------------------------------------------------------------------------------------------------------
|
-- begin AUDIBLE DETAILS ---------------------------------------------------------------------------------------------------------------------
|
||||||
alternate book id (eg BK_RAND_006061) is called 'sku' , 'sku_lite' , 'prod_id' , 'product_id' in different parts of the site
|
alternate book id (eg BK_RAND_006061) is called 'sku' , 'sku_lite' , 'prod_id' , 'product_id' in different parts of the site
|
||||||
-- end AUDIBLE DETAILS ---------------------------------------------------------------------------------------------------------------------
|
-- end AUDIBLE DETAILS ---------------------------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
namespace LibationWinForm_Framework.Dialogs
|
namespace WinFormsDesigner.Dialogs
|
||||||
{
|
{
|
||||||
partial class IndexLibraryDialog
|
partial class IndexLibraryDialog
|
||||||
{
|
{
|
||||||
|
|||||||
@ -8,7 +8,7 @@ using System.Text;
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
|
|
||||||
namespace LibationWinForm_Framework.Dialogs
|
namespace WinFormsDesigner.Dialogs
|
||||||
{
|
{
|
||||||
public partial class IndexLibraryDialog : Form
|
public partial class IndexLibraryDialog : Form
|
||||||
{
|
{
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
namespace LibationWinForm_Framework.Dialogs.Login
|
namespace WinFormsDesigner.Dialogs.Login
|
||||||
{
|
{
|
||||||
partial class AudibleLoginDialog
|
partial class AudibleLoginDialog
|
||||||
{
|
{
|
||||||
|
|||||||
@ -8,7 +8,7 @@ using System.Text;
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
|
|
||||||
namespace LibationWinForm_Framework.Dialogs.Login
|
namespace WinFormsDesigner.Dialogs.Login
|
||||||
{
|
{
|
||||||
public partial class AudibleLoginDialog : Form
|
public partial class AudibleLoginDialog : Form
|
||||||
{
|
{
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
namespace LibationWinForm_Framework.Dialogs.Login
|
namespace WinFormsDesigner.Dialogs.Login
|
||||||
{
|
{
|
||||||
partial class CaptchaDialog
|
partial class CaptchaDialog
|
||||||
{
|
{
|
||||||
|
|||||||
@ -8,7 +8,7 @@ using System.Text;
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
|
|
||||||
namespace LibationWinForm_Framework.Dialogs.Login
|
namespace WinFormsDesigner.Dialogs.Login
|
||||||
{
|
{
|
||||||
public partial class CaptchaDialog : Form
|
public partial class CaptchaDialog : Form
|
||||||
{
|
{
|
||||||
|
|||||||
@ -12,6 +12,9 @@ namespace WinFormsDesigner
|
|||||||
[Browsable(false)]
|
[Browsable(false)]
|
||||||
public IEnumerable<string> TagsEnumerated { get; set; }
|
public IEnumerable<string> TagsEnumerated { get; set; }
|
||||||
|
|
||||||
|
[Browsable(false)]
|
||||||
|
public string Download_Status { get; set; }
|
||||||
|
|
||||||
public Image Cover { get; set; }
|
public Image Cover { get; set; }
|
||||||
public string Title { get; set; }
|
public string Title { get; set; }
|
||||||
public string Authors { get; set; }
|
public string Authors { get; set; }
|
||||||
@ -24,6 +27,5 @@ namespace WinFormsDesigner
|
|||||||
public DateTime? Purchase_Date { get; set; }
|
public DateTime? Purchase_Date { get; set; }
|
||||||
public string My_Rating { get; set; }
|
public string My_Rating { get; set; }
|
||||||
public string Misc { get; set; }
|
public string Misc { get; set; }
|
||||||
public string Download_Status { get; set; }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
12
WinFormsDesigner/ProductsGrid.Designer.cs
generated
12
WinFormsDesigner/ProductsGrid.Designer.cs
generated
@ -43,7 +43,6 @@
|
|||||||
this.dataGridViewTextBoxColumn9 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
this.dataGridViewTextBoxColumn9 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||||
this.dataGridViewTextBoxColumn10 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
this.dataGridViewTextBoxColumn10 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||||
this.dataGridViewTextBoxColumn11 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
this.dataGridViewTextBoxColumn11 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
||||||
this.dataGridViewTextBoxColumn12 = new System.Windows.Forms.DataGridViewTextBoxColumn();
|
|
||||||
((System.ComponentModel.ISupportInitialize)(this.gridEntryBindingSource)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.gridEntryBindingSource)).BeginInit();
|
||||||
((System.ComponentModel.ISupportInitialize)(this.gridEntryDataGridView)).BeginInit();
|
((System.ComponentModel.ISupportInitialize)(this.gridEntryDataGridView)).BeginInit();
|
||||||
this.SuspendLayout();
|
this.SuspendLayout();
|
||||||
@ -68,8 +67,7 @@
|
|||||||
this.dataGridViewTextBoxColumn8,
|
this.dataGridViewTextBoxColumn8,
|
||||||
this.dataGridViewTextBoxColumn9,
|
this.dataGridViewTextBoxColumn9,
|
||||||
this.dataGridViewTextBoxColumn10,
|
this.dataGridViewTextBoxColumn10,
|
||||||
this.dataGridViewTextBoxColumn11,
|
this.dataGridViewTextBoxColumn11});
|
||||||
this.dataGridViewTextBoxColumn12});
|
|
||||||
this.gridEntryDataGridView.DataSource = this.gridEntryBindingSource;
|
this.gridEntryDataGridView.DataSource = this.gridEntryBindingSource;
|
||||||
this.gridEntryDataGridView.Location = new System.Drawing.Point(54, 58);
|
this.gridEntryDataGridView.Location = new System.Drawing.Point(54, 58);
|
||||||
this.gridEntryDataGridView.Name = "gridEntryDataGridView";
|
this.gridEntryDataGridView.Name = "gridEntryDataGridView";
|
||||||
@ -160,13 +158,6 @@
|
|||||||
this.dataGridViewTextBoxColumn11.Name = "dataGridViewTextBoxColumn11";
|
this.dataGridViewTextBoxColumn11.Name = "dataGridViewTextBoxColumn11";
|
||||||
this.dataGridViewTextBoxColumn11.ReadOnly = true;
|
this.dataGridViewTextBoxColumn11.ReadOnly = true;
|
||||||
//
|
//
|
||||||
// dataGridViewTextBoxColumn12
|
|
||||||
//
|
|
||||||
this.dataGridViewTextBoxColumn12.DataPropertyName = "Download_Status";
|
|
||||||
this.dataGridViewTextBoxColumn12.HeaderText = "Download_Status";
|
|
||||||
this.dataGridViewTextBoxColumn12.Name = "dataGridViewTextBoxColumn12";
|
|
||||||
this.dataGridViewTextBoxColumn12.ReadOnly = true;
|
|
||||||
//
|
|
||||||
// ProductsGrid
|
// ProductsGrid
|
||||||
//
|
//
|
||||||
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
|
||||||
@ -196,6 +187,5 @@
|
|||||||
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn9;
|
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn9;
|
||||||
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn10;
|
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn10;
|
||||||
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn11;
|
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn11;
|
||||||
private System.Windows.Forms.DataGridViewTextBoxColumn dataGridViewTextBoxColumn12;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -6,5 +6,5 @@
|
|||||||
cause the file to be unrecognizable by the program.
|
cause the file to be unrecognizable by the program.
|
||||||
-->
|
-->
|
||||||
<GenericObjectDataSource DisplayName="GridEntry" Version="1.0" xmlns="urn:schemas-microsoft-com:xml-msdatasource">
|
<GenericObjectDataSource DisplayName="GridEntry" Version="1.0" xmlns="urn:schemas-microsoft-com:xml-msdatasource">
|
||||||
<TypeInfo>LibationWinForm.ProductGrids.GridEntry, LibationWinForm, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null</TypeInfo>
|
<TypeInfo>WinFormsDesigner.GridEntry, WinFormsDesigner, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null</TypeInfo>
|
||||||
</GenericObjectDataSource>
|
</GenericObjectDataSource>
|
||||||
@ -166,7 +166,7 @@
|
|||||||
<EmbeddedResource Include="ProductsGrid.resx">
|
<EmbeddedResource Include="ProductsGrid.resx">
|
||||||
<DependentUpon>ProductsGrid.cs</DependentUpon>
|
<DependentUpon>ProductsGrid.cs</DependentUpon>
|
||||||
</EmbeddedResource>
|
</EmbeddedResource>
|
||||||
<None Include="Properties\DataSources\LibationWinForm_Framework.ProductGrids.GridEntry.datasource" />
|
<None Include="Properties\DataSources\WinFormsDesigner.GridEntry.datasource" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup />
|
<ItemGroup />
|
||||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user