diff --git a/airtime_mvc/application/models/StoredFile.php b/airtime_mvc/application/models/StoredFile.php
index 8b6fe4a99..3e98b0d7e 100644
--- a/airtime_mvc/application/models/StoredFile.php
+++ b/airtime_mvc/application/models/StoredFile.php
@@ -488,6 +488,7 @@ class Application_Model_StoredFile {
{
$file = new CcFiles();
$file->setDbGunid(md5(uniqid("", true)));
+ $file->setDbMtime(new DateTime("now"), new DateTimeZone("UTC"));
$storedFile = new Application_Model_StoredFile();
$storedFile->_file = $file;
@@ -628,49 +629,52 @@ class Application_Model_StoredFile {
return $res;
}
- public static function searchFilesForPlaylistBuilder($datatables) {
- global $CC_CONFIG;
+ public static function searchFilesForPlaylistBuilder($datatables)
+ {
+ global $CC_CONFIG;
- $displayData = array("track_title", "artist_name", "album_title", "genre", "length", "ftype");
+ $displayData = array("track_title", "artist_name", "album_title", "genre", "length", "year", "upload_time", "ftype");
- $plSelect = "SELECT ";
+ $plSelect = "SELECT ";
$fileSelect = "SELECT ";
- foreach ($displayData as $key){
+ foreach ($displayData as $key) {
- if($key === "track_title"){
+ if ($key === "track_title") {
$plSelect .= "name AS ".$key.", ";
$fileSelect .= $key.", ";
- }
- else if ($key === "ftype"){
+ } else if ($key === "ftype") {
$plSelect .= "'playlist' AS ".$key.", ";
$fileSelect .= $key.", ";
- }
- else if ($key === "artist_name"){
+ } else if ($key === "artist_name") {
$plSelect .= "creator AS ".$key.", ";
$fileSelect .= $key.", ";
- }
- else if ($key === "length"){
+ } else if ($key === "length") {
$plSelect .= $key.", ";
$fileSelect .= $key.", ";
- }
- else {
+ } else if ($key === "year") {
+ $plSelect .= "CAST(mtime AS varchar) AS ".$key.", ";
+ $fileSelect .= $key.", ";
+ } else if ($key === "upload_time") {
+ $plSelect .= "mtime AS ".$key.", ";
+ $fileSelect .= "mtime AS ".$key.", ";
+ } else {
$plSelect .= "NULL AS ".$key.", ";
$fileSelect .= $key.", ";
}
}
- $fromTable = " ((".$plSelect."PL.id
- FROM ".$CC_CONFIG["playListTable"]." AS PL
- LEFT JOIN ".$CC_CONFIG['playListTimeView']." AS PLT USING(id))
+ $fromTable = " ((".$plSelect."PL.id
+ FROM ".$CC_CONFIG["playListTable"]." AS PL
+ LEFT JOIN ".$CC_CONFIG['playListTimeView']." AS PLT USING(id))
- UNION
+ UNION
- (".$fileSelect."id FROM ".$CC_CONFIG["filesTable"]." AS FILES)) AS RESULTS";
-
- return Application_Model_StoredFile::searchFiles($fromTable, $datatables);
- }
+ (".$fileSelect."id FROM ".$CC_CONFIG["filesTable"]." AS FILES)) AS RESULTS";
+
+ return Application_Model_StoredFile::searchFiles($fromTable, $datatables);
+ }
- public static function searchPlaylistsForSchedule($datatables)
+ public static function searchPlaylistsForSchedule($datatables)
{
$fromTable = "cc_playlist AS pl LEFT JOIN cc_playlisttimes AS plt USING(id) LEFT JOIN cc_subjs AS sub ON pl.editedby = sub.id";
//$datatables["optWhere"][] = "INTERVAL '{$time_remaining}' > INTERVAL '00:00:00'";
@@ -750,9 +754,14 @@ class Application_Model_StoredFile {
}
$results = $CC_DBC->getAll($sql);
- // add checkbox row
foreach($results as &$row){
+ // add checkbox row
$row['checkbox'] = "";
+
+ // a full timestamp is being returned for playlists' year column;
+ // split it and grab only the year info
+ $yearSplit = explode('-', $row['year']);
+ $row['year'] = $yearSplit[0];
}
//$results['checkbox']
//$results = $CC_DBC->getAssoc($sql);
diff --git a/airtime_mvc/public/js/airtime/library/library.js b/airtime_mvc/public/js/airtime/library/library.js
index c70d776e6..57d3aea41 100644
--- a/airtime_mvc/public/js/airtime/library/library.js
+++ b/airtime_mvc/public/js/airtime/library/library.js
@@ -493,12 +493,14 @@ function createDataTable(data) {
"aoColumns": [
/* Checkbox */ { "sTitle": "", "bSortable": false, "bSearchable": false, "mDataProp": "checkbox", "sWidth": "25px", "sClass": "library_checkbox"},
/* Id */ { "sName": "id", "bSearchable": false, "bVisible": false, "mDataProp": "id", "sClass": "library_id"},
- /* Title */ { "sTitle": "Title", "sName": "track_title", "mDataProp": "track_title", "sWidth": "30%", "sClass": "library_title"},
+ /* Title */ { "sTitle": "Title", "sName": "track_title", "mDataProp": "track_title", "sClass": "library_title"},
/* Creator */ { "sTitle": "Creator", "sName": "artist_name", "mDataProp": "artist_name", "sClass": "library_creator"},
/* Album */ { "sTitle": "Album", "sName": "album_title", "mDataProp": "album_title", "sClass": "library_album"},
/* Genre */ { "sTitle": "Genre", "sName": "genre", "mDataProp": "genre", "sWidth": "10%", "sClass": "library_genre"},
+ /* Year */ { "sTitle": "Year", "sName": "year", "mDataProp": "year", "sWidth": "8%", "sClass": "library_year"},
/* Length */ { "sTitle": "Length", "sName": "length", "mDataProp": "length", "sWidth": "16%", "sClass": "library_length"},
- /* Type */ { "sTitle": "Type", "sName": "ftype", "bSearchable": false, "mDataProp": "ftype", "sWidth": "9%", "sClass": "library_type"},
+ /* Type */ { "sTitle": "Type", "sName": "ftype", "bSearchable": false, "mDataProp": "ftype", "sWidth": "9%", "sClass": "library_type"},
+ /* Upload Time */ { "sTitle": "Upload Time", "sName": "upload_time", "mDataProp": "upload_time", "sClass": "library_upload_time"},
],
"aaSorting": [[2,'asc']],
"sPaginationType": "full_numbers",