2024-09-14 15:25:13 +00:00
/ *
THIS IS A GENERATED / BUNDLED FILE BY ESBUILD
if you want to view the source , please visit the github repository of this plugin
* /
var _ _defProp = Object . defineProperty ;
var _ _getOwnPropDesc = Object . getOwnPropertyDescriptor ;
var _ _getOwnPropNames = Object . getOwnPropertyNames ;
var _ _hasOwnProp = Object . prototype . hasOwnProperty ;
var _ _export = ( target , all ) => {
for ( var name in all )
_ _defProp ( target , name , { get : all [ name ] , enumerable : true } ) ;
} ;
var _ _copyProps = ( to , from , except , desc ) => {
if ( from && typeof from === "object" || typeof from === "function" ) {
for ( let key of _ _getOwnPropNames ( from ) )
if ( ! _ _hasOwnProp . call ( to , key ) && key !== except )
_ _defProp ( to , key , { get : ( ) => from [ key ] , enumerable : ! ( desc = _ _getOwnPropDesc ( from , key ) ) || desc . enumerable } ) ;
}
return to ;
} ;
var _ _toCommonJS = ( mod ) => _ _copyProps ( _ _defProp ( { } , "__esModule" , { value : true } ) , mod ) ;
// src/main.ts
var main _exports = { } ;
_ _export ( main _exports , {
DEFAULT _SETTINGS : ( ) => DEFAULT _SETTINGS ,
default : ( ) => DNPlugin
} ) ;
module . exports = _ _toCommonJS ( main _exports ) ;
var import _obsidian4 = require ( "obsidian" ) ;
// src/settings.ts
var import _obsidian = require ( "obsidian" ) ;
var DNSettingTab = class extends import _obsidian . PluginSettingTab {
constructor ( app , plugin ) {
super ( app , plugin ) ;
this . plugin = plugin ;
}
display ( ) {
const { containerEl } = this ;
containerEl . empty ( ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Open dashboard navigator" ) . addButton ( ( btn ) => {
btn . setButtonText ( "Open" ) . setTooltip ( "Open dashboard navigator" ) . onClick ( ( evt ) => {
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . open ( ) ;
2024-09-14 15:25:13 +00:00
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Default view" ) . setDesc ( "Select view when opening window" ) . addDropdown ( ( sel ) => {
this . dropdownDefaultView = sel ;
sel . addOption ( "1" , "Dashboard" ) ;
sel . addOption ( "2" , "Navigator" ) ;
sel . onChange ( async ( val ) => {
this . plugin . settings . default _view = parseInt ( val ) ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . default _view = this . plugin . settings . default _view ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) , sel . setValue ( this . plugin . settings . default _view . toString ( ) ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . dropdownDefaultView . setValue ( DEFAULT _SETTINGS . default _view . toString ( ) ) ;
this . plugin . settings . default _view = DEFAULT _SETTINGS . default _view ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . default _view = this . plugin . settings . default _view ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Navigator table layout" ) . setDesc ( "Select table results layout" ) . addDropdown ( ( sel ) => {
this . dropdownTableLayout = sel ;
sel . addOption ( "dn-tbl-default" , "Default" ) ;
sel . addOption ( "dn-tbl-row" , "Row striped" ) ;
sel . addOption ( "dn-tbl-column" , "Column striped" ) ;
sel . addOption ( "dn-tbl-bordered" , "Bordered" ) ;
sel . onChange ( async ( val ) => {
this . plugin . settings . selected _table _layout = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . selected _table _layout = this . plugin . settings . selected _table _layout ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) , sel . setValue ( this . plugin . settings . selected _table _layout . toString ( ) ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . dropdownTableLayout . setValue ( DEFAULT _SETTINGS . selected _table _layout . toString ( ) ) ;
this . plugin . settings . selected _table _layout = DEFAULT _SETTINGS . selected _table _layout ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . selected _table _layout = this . plugin . settings . selected _table _layout ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Date format" ) . setDesc ( "Select date format" ) . addDropdown ( ( sel ) => {
this . dropdownDateFormat = sel ;
sel . addOption ( "YYYY-MM-DD HH:mm:ss" , "YYYY-MM-DD HH:mm:ss" ) ;
sel . addOption ( "YYYY-MM-DD HH:mm" , "YYYY-MM-DD HH:mm" ) ;
sel . addOption ( "YYYY-MM-DD" , "YYYY-MM-DD" ) ;
sel . addOption ( "DD/MM/YYYY HH:mm:ss" , "DD/MM/YYYY HH:mm:ss" ) ;
sel . addOption ( "DD/MM/YYYY HH:mm" , "DD/MM/YYYY HH:mm" ) ;
sel . addOption ( "DD/MM/YYYY" , "DD/MM/YYYY" ) ;
sel . onChange ( async ( val ) => {
this . plugin . settings . date _format = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . date _format = this . plugin . settings . date _format ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) , sel . setValue ( this . plugin . settings . date _format . toString ( ) ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . dropdownDateFormat . setValue ( DEFAULT _SETTINGS . date _format . toString ( ) ) ;
this . plugin . settings . date _format = DEFAULT _SETTINGS . date _format ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . date _format = this . plugin . settings . date _format ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Font size" ) . setDesc ( "Select font size in pixels for results and links" ) . addSlider ( ( sli ) => {
this . sliderFontSize = sli ;
let slider _val ;
if ( this . plugin . settings . font _size ) {
slider _val = this . plugin . settings . font _size ;
} else {
slider _val = DEFAULT _SETTINGS . font _size ;
}
sli . setDynamicTooltip ( ) ;
sli . setLimits ( 12 , 24 , 1 ) ;
sli . setValue ( slider _val ) ;
sli . onChange ( ( val ) => {
this . plugin . settings . font _size = val ;
this . plugin . dnSetFontSize ( val ) ;
this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . sliderFontSize . setValue ( DEFAULT _SETTINGS . font _size ) ;
this . plugin . settings . font _size = DEFAULT _SETTINGS . font _size ;
this . plugin . dnSetFontSize ( this . plugin . settings . font _size ) ;
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Files per page" ) . setDesc ( "Number of results per page" ) . addDropdown ( ( sel ) => {
this . dropdownFilesPerPage = sel ;
sel . addOption ( "10" , "10" ) ;
sel . addOption ( "20" , "20" ) ;
sel . addOption ( "30" , "30" ) ;
sel . addOption ( "50" , "50" ) ;
sel . addOption ( "100" , "100" ) ;
sel . onChange ( async ( val ) => {
this . plugin . settings . files _per _page = parseInt ( val ) ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . files _per _page = this . plugin . settings . files _per _page ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) , sel . setValue ( this . plugin . settings . files _per _page . toString ( ) ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . dropdownFilesPerPage . setValue ( DEFAULT _SETTINGS . files _per _page . toString ( ) ) ;
this . plugin . settings . files _per _page = DEFAULT _SETTINGS . files _per _page ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . files _per _page = this . plugin . settings . files _per _page ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Recent files" ) . setDesc ( "Number of recent files per category" ) . addDropdown ( ( sel ) => {
this . dropdownRecentFiles = sel ;
sel . addOption ( "3" , "3" ) ;
sel . addOption ( "4" , "4" ) ;
sel . addOption ( "5" , "5" ) ;
sel . addOption ( "10" , "10" ) ;
sel . onChange ( async ( val ) => {
this . plugin . settings . num _recent _files = parseInt ( val ) ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . num _recent _files = this . plugin . settings . num _recent _files ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) , sel . setValue ( this . plugin . settings . num _recent _files . toString ( ) ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . dropdownRecentFiles . setValue ( DEFAULT _SETTINGS . num _recent _files . toString ( ) ) ;
this . plugin . settings . num _recent _files = DEFAULT _SETTINGS . num _recent _files ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . num _recent _files = this . plugin . settings . num _recent _files ;
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Hide column: Ext" ) . setDesc ( "Navigator: Hide file extension column" ) . addToggle ( ( toggle ) => {
this . toggleHideExtColumn = toggle ;
toggle . setValue ( this . plugin . settings . hide _ext ) . onChange ( async ( val ) => {
this . plugin . settings . hide _ext = val ;
this . plugin . dnUpdateHideColumn ( "ext" , val ) ;
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . toggleHideExtColumn . setValue ( DEFAULT _SETTINGS . hide _ext ) ;
this . plugin . settings . hide _ext = DEFAULT _SETTINGS . hide _ext ;
this . plugin . dnUpdateHideColumn ( "ext" , DEFAULT _SETTINGS . hide _ext ) ;
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Hide column: Path" ) . setDesc ( "Navigator: Hide path column" ) . addToggle ( ( toggle ) => {
this . toggleHidePathColumn = toggle ;
toggle . setValue ( this . plugin . settings . hide _path ) . onChange ( async ( val ) => {
this . plugin . settings . hide _path = val ;
this . plugin . dnUpdateHideColumn ( "path" , val ) ;
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . toggleHidePathColumn . setValue ( DEFAULT _SETTINGS . hide _path ) ;
this . plugin . settings . hide _path = DEFAULT _SETTINGS . hide _path ;
this . plugin . dnUpdateHideColumn ( "path" , DEFAULT _SETTINGS . hide _path ) ;
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Hide column: Size" ) . setDesc ( "Navigator: Hide size column" ) . addToggle ( ( toggle ) => {
this . toggleHideSizeColumn = toggle ;
toggle . setValue ( this . plugin . settings . hide _size ) . onChange ( async ( val ) => {
this . plugin . settings . hide _size = val ;
this . plugin . dnUpdateHideColumn ( "size" , val ) ;
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . toggleHideSizeColumn . setValue ( DEFAULT _SETTINGS . hide _size ) ;
this . plugin . settings . hide _size = DEFAULT _SETTINGS . hide _size ;
this . plugin . dnUpdateHideColumn ( "size" , DEFAULT _SETTINGS . hide _size ) ;
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Hide column: Date" ) . setDesc ( "Navigator: Hide date column" ) . addToggle ( ( toggle ) => {
this . toggleHideDateColumn = toggle ;
toggle . setValue ( this . plugin . settings . hide _date ) . onChange ( async ( val ) => {
this . plugin . settings . hide _date = val ;
this . plugin . dnUpdateHideColumn ( "date" , val ) ;
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . toggleHideDateColumn . setValue ( DEFAULT _SETTINGS . hide _date ) ;
this . plugin . settings . hide _date = DEFAULT _SETTINGS . hide _date ;
this . plugin . dnUpdateHideColumn ( "date" , DEFAULT _SETTINGS . hide _date ) ;
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Hide column: Tags" ) . setDesc ( "Navigator: Hide tags column" ) . addToggle ( ( toggle ) => {
this . toggleHideTagsColumn = toggle ;
toggle . setValue ( this . plugin . settings . hide _tags ) . onChange ( async ( val ) => {
this . plugin . settings . hide _tags = val ;
this . plugin . dnUpdateHideColumn ( "tags" , val ) ;
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . toggleHideTagsColumn . setValue ( DEFAULT _SETTINGS . hide _tags ) ;
this . plugin . settings . hide _tags = DEFAULT _SETTINGS . hide _tags ;
this . plugin . dnUpdateHideColumn ( "tags" , DEFAULT _SETTINGS . hide _tags ) ;
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Hide column: Frontmatter" ) . setDesc ( "Navigator: Hide frontmatter properties column" ) . addToggle ( ( toggle ) => {
this . toggleHideFrontmatterColumn = toggle ;
toggle . setValue ( this . plugin . settings . hide _frontmatter ) . onChange ( async ( val ) => {
this . plugin . settings . hide _frontmatter = val ;
this . plugin . dnUpdateHideColumn ( "frontmatter" , val ) ;
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . toggleHideFrontmatterColumn . setValue ( DEFAULT _SETTINGS . hide _frontmatter ) ;
this . plugin . settings . hide _frontmatter = DEFAULT _SETTINGS . hide _frontmatter ;
this . plugin . dnUpdateHideColumn ( "frontmatter" , DEFAULT _SETTINGS . hide _frontmatter ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Excluded file extensions" ) . setDesc ( "File extensions to exclude, separated by commas" ) . addText ( ( text ) => {
this . textExcludedExtensions = text ;
text . setPlaceholder ( "File extensions to exclude" ) . setValue ( this . plugin . settings . excluded _ext ) . onChange ( async ( val ) => {
this . plugin . settings . excluded _ext = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . excluded _extensions = this . plugin . dnGetExcludedExtensions ( val ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . textExcludedExtensions . setValue ( "" ) ;
this . plugin . settings . excluded _ext = "" ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . excluded _extensions = [ ] ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Excluded folders" ) . setDesc ( "List of folder paths to exclude, separated by commas" ) . addText ( ( text ) => {
this . textExcludedFolders = text ;
text . setPlaceholder ( "Folder paths to exclude" ) . setValue ( this . plugin . settings . excluded _path ) . onChange ( async ( val ) => {
this . plugin . settings . excluded _path = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . excluded _folders = this . plugin . dnGetExcludedFolders ( val ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . textExcludedFolders . setValue ( "" ) ;
this . plugin . settings . excluded _path = "" ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . excluded _folders = [ ] ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Toggle colored files" ) . setDesc ( "Turn on/off colored files" ) . addToggle ( ( toggle ) => {
this . toggleColoredFiles = toggle ;
toggle . setValue ( this . plugin . settings . colored _files ) . onChange ( async ( val ) => {
this . plugin . settings . colored _files = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . colored _files = val ;
this . plugin . DN _MODAL . dnToggleColoredFiles ( ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . toggleColoredFiles . setValue ( DEFAULT _SETTINGS . colored _files ) ;
this . plugin . settings . colored _files = DEFAULT _SETTINGS . colored _files ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . colored _files = DEFAULT _SETTINGS . colored _files ;
this . plugin . DN _MODAL . dnToggleColoredFiles ( ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Color: Notes" ) . setDesc ( "Color of notes" ) . addColorPicker ( ( color ) => {
this . colorCompNotes = color ;
color . setValue ( this . plugin . settings . color _notes ) . onChange ( async ( val ) => {
this . plugin . settings . color _notes = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _notes = val ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . colorCompNotes . setValue ( DEFAULT _SETTINGS . color _notes ) ;
this . plugin . settings . color _notes = DEFAULT _SETTINGS . color _notes ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _notes = DEFAULT _SETTINGS . color _notes ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Color: Canvas" ) . setDesc ( "Color of canvas" ) . addColorPicker ( ( color ) => {
this . colorCompCanvas = color ;
color . setValue ( this . plugin . settings . color _canvas ) . onChange ( async ( val ) => {
this . plugin . settings . color _canvas = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _canvas = val ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . colorCompCanvas . setValue ( DEFAULT _SETTINGS . color _canvas ) ;
this . plugin . settings . color _canvas = DEFAULT _SETTINGS . color _canvas ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _canvas = DEFAULT _SETTINGS . color _canvas ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Color: Images" ) . setDesc ( "Color of images" ) . addColorPicker ( ( color ) => {
this . colorCompImages = color ;
color . setValue ( this . plugin . settings . color _images ) . onChange ( async ( val ) => {
this . plugin . settings . color _images = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _images = val ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . colorCompImages . setValue ( DEFAULT _SETTINGS . color _images ) ;
this . plugin . settings . color _images = DEFAULT _SETTINGS . color _images ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _images = DEFAULT _SETTINGS . color _images ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Color: Videos" ) . setDesc ( "Color of videos" ) . addColorPicker ( ( color ) => {
this . colorCompVideos = color ;
color . setValue ( this . plugin . settings . color _videos ) . onChange ( async ( val ) => {
this . plugin . settings . color _videos = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _videos = val ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . colorCompVideos . setValue ( DEFAULT _SETTINGS . color _videos ) ;
this . plugin . settings . color _videos = DEFAULT _SETTINGS . color _videos ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _videos = DEFAULT _SETTINGS . color _videos ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Color: Audios" ) . setDesc ( "Color of audios" ) . addColorPicker ( ( color ) => {
this . colorCompAudios = color ;
color . setValue ( this . plugin . settings . color _audios ) . onChange ( async ( val ) => {
this . plugin . settings . color _audios = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _audios = val ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . colorCompAudios . setValue ( DEFAULT _SETTINGS . color _audios ) ;
this . plugin . settings . color _audios = DEFAULT _SETTINGS . color _audios ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _audios = DEFAULT _SETTINGS . color _audios ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Color: PDF" ) . setDesc ( "Color of PDF files" ) . addColorPicker ( ( color ) => {
this . colorCompPdf = color ;
color . setValue ( this . plugin . settings . color _pdf ) . onChange ( async ( val ) => {
this . plugin . settings . color _pdf = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _pdf = val ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . colorCompPdf . setValue ( DEFAULT _SETTINGS . color _pdf ) ;
this . plugin . settings . color _pdf = DEFAULT _SETTINGS . color _pdf ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _pdf = DEFAULT _SETTINGS . color _pdf ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
new import _obsidian . Setting ( containerEl ) . setName ( "Color: Other files" ) . setDesc ( "Color of other files" ) . addColorPicker ( ( color ) => {
this . colorCompOther = color ;
color . setValue ( this . plugin . settings . color _other ) . onChange ( async ( val ) => {
this . plugin . settings . color _other = val ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _other = val ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
await this . plugin . saveSettings ( ) ;
} ) ;
} ) . addExtraButton ( ( btn ) => {
btn . setIcon ( "rotate-ccw" ) ;
btn . setTooltip ( "Restore default" ) ;
btn . onClick ( ( ) => {
this . colorCompOther . setValue ( DEFAULT _SETTINGS . color _other ) ;
this . plugin . settings . color _other = DEFAULT _SETTINGS . color _other ;
2024-11-22 15:53:13 +00:00
this . plugin . DN _MODAL . color _other = DEFAULT _SETTINGS . color _other ;
this . plugin . DN _MODAL . dnSetCustomColors ( ) ;
2024-09-14 15:25:13 +00:00
this . plugin . saveSettings ( ) ;
} ) ;
} ) ;
}
} ;
// src/dn.ts
var import _obsidian2 = require ( "obsidian" ) ;
// src/utils/format.ts
function formatFileSize ( fileSize ) {
if ( fileSize === 0 ) {
return "0" ;
}
const formattedSize = fileSize . toFixed ( 0 ) . replace ( /\B(?=(\d{3})+(?!\d))/g , "," ) ;
return formattedSize ;
}
function getFolderStructure ( folder ) {
const folders = folder . split ( "/" ) . slice ( 0 , - 1 ) ;
if ( folders . length === 0 ) {
2024-11-29 13:32:34 +00:00
return "/" ;
2024-09-14 15:25:13 +00:00
}
return "/" + folders . join ( "/" ) ;
}
2024-11-22 15:53:13 +00:00
function formatFileSizeKBMB ( total _bytes ) {
if ( total _bytes < 1024 ) {
return "" ;
} else if ( total _bytes < 1048576 ) {
return ` ( ${ ( total _bytes / 1024 ) . toFixed ( 2 ) } KB) ` ;
} else {
return ` ( ${ ( total _bytes / ( 1024 * 1024 ) ) . toFixed ( 2 ) } MB) ` ;
}
}
// src/utils/tags.ts
function getTagsPerFile ( file ) {
var _a , _b ;
const cur _file = this . app . vault . getAbstractFileByPath ( file . path ) ;
if ( cur _file !== null ) {
const tags = ( _a = this . app . metadataCache . getFileCache ( file ) ) == null ? void 0 : _a . tags ;
const frontmatter _tags = ( _b = this . app . metadataCache . getFileCache ( file ) ) == null ? void 0 : _b . frontmatter ;
const arrTags = [ ] ;
if ( tags ) {
for ( let i = 0 , len = tags . length ; i < len ; i ++ ) {
if ( arrTags . indexOf ( tags [ i ] . tag ) < 0 ) {
arrTags . push ( tags [ i ] . tag ) ;
}
}
}
if ( frontmatter _tags !== void 0 && frontmatter _tags . tags ) {
for ( let i = 0 , len = frontmatter _tags . tags . length ; i < len ; i ++ ) {
2024-11-29 13:32:34 +00:00
const fmTag = "#" + frontmatter _tags . tags [ i ] ;
if ( arrTags . indexOf ( fmTag ) < 0 ) {
arrTags . push ( fmTag ) ;
2024-11-22 15:53:13 +00:00
}
}
}
return arrTags . join ( " " ) ;
} else {
return "" ;
}
}
function getPropsPerFile ( file ) {
const fileProperties = [ ] ;
const cache = this . app . metadataCache . getFileCache ( file ) ;
if ( cache == null ? void 0 : cache . frontmatter ) {
for ( const [ key , value ] of Object . entries ( cache . frontmatter ) ) {
fileProperties . push ( ` ' ${ key } : ${ value } ' ` ) ;
}
}
return fileProperties . join ( " \n" ) ;
}
2024-09-14 15:25:13 +00:00
2024-11-22 15:53:13 +00:00
// src/utils/dnpiechart.ts
2024-09-14 15:25:13 +00:00
var DNPieChart = class {
constructor ( canvas , margin = 10 , fontSize = 12 , legendWidth = 50 , labelColor = "#828282" ) {
this . _canvas = canvas ;
2024-11-22 15:53:13 +00:00
const ctx = canvas . getContext ( "2d" ) ;
if ( ctx ) {
this . _ctx = ctx ;
}
2024-09-14 15:25:13 +00:00
this . _data = [ ] ;
this . _margin = margin ;
this . _fontSize = fontSize ;
this . _legendWidth = legendWidth ;
this . _labelColor = labelColor ;
}
addData ( value , color , label ) {
this . _data . push ( { value , color , label } ) ;
}
draw ( ) {
const { width , height } = this . _canvas ;
const availWidth = width - 2 * this . _margin ;
const availHeight = height - 2 * this . _margin ;
const scale = Math . min ( availWidth / width , availHeight / height ) ;
const radius = Math . min ( availWidth , availHeight ) / 2 * scale ;
this . _cX = width / 2 ;
this . _cY = height / 2 ;
this . _ctx . clearRect ( 0 , 0 , width , height ) ;
const totalValue = this . _data . reduce ( ( acc , curr ) => acc + curr . value , 0 ) ;
let currentAngle = - Math . PI / 2 ;
this . _data . forEach ( ( slice ) => {
const sliceAngle = slice . value / totalValue * 2 * Math . PI ;
this . drawSlice ( radius , sliceAngle , slice . color , currentAngle ) ;
currentAngle += sliceAngle ;
} ) ;
this . drawLegend ( 2 , 20 ) ;
}
drawSlice ( radius , sliceAngle , color , startAngle ) {
this . _ctx . beginPath ( ) ;
this . _ctx . arc ( this . _cX , this . _cY , radius , startAngle , startAngle + sliceAngle ) ;
this . _ctx . lineTo ( this . _cX , this . _cY ) ;
this . _ctx . fillStyle = color ;
this . _ctx . closePath ( ) ;
this . _ctx . fill ( ) ;
}
drawLegend ( x , y ) {
const lineHeight = this . _fontSize + 5 ;
this . _data . forEach ( ( slice , index ) => {
const textX = x + this . _legendWidth / 5 ;
const textY = y + index * lineHeight - 10 ;
this . _ctx . fillStyle = slice . color ;
this . _ctx . fillRect ( textX - 10 , textY , 5 , 5 ) ;
this . _ctx . fillStyle = this . _labelColor ;
this . _ctx . font = ` ${ this . _fontSize } px sans-serif ` ;
this . _ctx . fillText ( ` ${ slice . label } ( ${ slice . value } ) ` , textX , textY + 8 ) ;
} ) ;
}
} ;
2024-11-22 15:53:13 +00:00
// src/utils/dntablemanager.ts
var DNTableManager = class {
constructor ( tbl ) {
this . table = document . querySelector ( tbl ) ;
}
getCells ( ) {
return this . table . querySelectorAll ( "td, th" ) ;
}
hideColumns ( columnNames ) {
const cells = this . getCells ( ) ;
if ( columnNames . length === 0 ) {
for ( let i = 0 ; i < cells . length ; i ++ ) {
cells [ i ] . classList . remove ( "dn-hidden" ) ;
}
} else {
for ( let i = 0 ; i < cells . length ; i ++ ) {
const colIndex = i % 7 ;
const columnName = this . getColumnNames ( ) [ colIndex ] ;
if ( columnNames . includes ( columnName ) ) {
cells [ i ] . classList . add ( "dn-hidden" ) ;
} else {
cells [ i ] . classList . remove ( "dn-hidden" ) ;
}
}
}
}
getColumnNames ( ) {
return [ "name" , "ext" , "path" , "size" , "date" , "tags" , "frontmatter" ] ;
}
} ;
2024-09-14 15:25:13 +00:00
// src/dn.ts
var import _obsidian3 = require ( "obsidian" ) ;
var DNModal = class extends import _obsidian2 . Modal {
constructor ( app ) {
super ( app ) ;
this . _sort _order = "desc" ;
this . _sort _column = "modified" ;
this . _selected _category = "" ;
this . _TABLE _LAYOUTS = [ "dn-tbl-default" , "dn-tbl-row" , "dn-tbl-column" , "dn-tbl-bordered" ] ;
this . selected _table _layout = "dn-tbl-default" ;
this . selected _sort _value = "modified-desc" ;
this . num _recent _files = 5 ;
this . files _per _page = 20 ;
this . date _format = "YYYY-MM-DD HH:mm" ;
this . default _view = 1 ;
this . excluded _extensions = [ ] ;
this . excluded _folders = [ ] ;
// File colors
this . color _notes = "#bf48ff" ;
this . color _images = "#007fff" ;
this . color _canvas = "#ff7f28" ;
this . color _videos = "#d34848" ;
this . color _audios = "#bfbf00" ;
this . color _pdf = "#00a300" ;
this . color _other = "#828282" ;
this . colored _files = false ;
2024-11-22 15:53:13 +00:00
// Hide columns
this . hide _columns = [ ] ;
2024-11-29 13:32:34 +00:00
this . _previewComponent = new import _obsidian2 . Component ( ) ;
2024-09-14 15:25:13 +00:00
this . dnHandleIntersection = ( entries ) => {
entries . forEach ( ( entry ) => {
if ( ! entry . isIntersecting ) {
entry . target . removeEventListener ( "contextmenu" , this . dnHandleClick ) ;
entry . target . removeEventListener ( "click" , this . dnHandleClick ) ;
entry . target . removeEventListener ( "dblclick" , this . dnHandleDblClick ) ;
}
} ) ;
} ;
this . intersectionObserver = new IntersectionObserver ( this . dnHandleIntersection ) ;
}
async onOpen ( ) {
var _a ;
const { contentEl } = this ;
2024-11-29 13:32:34 +00:00
this . _previewComponent . load ( ) ;
2024-11-22 15:53:13 +00:00
this . _hoverDiv = this . contentEl . createEl ( "div" , { cls : "dn-preview" } ) ;
await this . updateModalData ( ) ;
const leaf = ( _a = this . app . workspace ) == null ? void 0 : _a . getMostRecentLeaf ( ) ;
if ( leaf !== null ) {
this . _leaf = leaf ;
}
this . dnCreateMainUI ( contentEl ) ;
this . dnSetView ( this . default _view ) ;
this . dnSetSelectLayoutValue ( this . selected _table _layout ) ;
this . dnSetSelectSortValue ( this . selected _sort _value ) ;
this . dnToggleColoredFiles ( ) ;
this . _isDraggingPreview = false ;
this . _hoverDivLeft = "" ;
this . _hoverDivTop = "" ;
}
async updateModalData ( ) {
2024-09-14 15:25:13 +00:00
this . _files = [ ] ;
this . _folders = [ ] ;
this . _recent = [ ] ;
2024-11-22 15:53:13 +00:00
this . _last _opened = [ ] ;
this . _notes = [ ] ;
2024-09-14 15:25:13 +00:00
this . _images = [ ] ;
this . _canvas = [ ] ;
this . _audios = [ ] ;
this . _videos = [ ] ;
this . _pdf = [ ] ;
this . _other = [ ] ;
const dnFilesAndFolders = this . app . vault . getAllLoadedFiles ( ) ;
for ( const absF of dnFilesAndFolders ) {
if ( absF instanceof import _obsidian2 . TFile ) {
this . _files . push ( absF ) ;
} else if ( absF instanceof import _obsidian2 . TFolder && ! absF . isRoot ( ) ) {
this . _folders . push ( absF ) ;
}
}
2024-11-22 15:53:13 +00:00
this . _files _excluded _filters = this . _files . filter (
2024-09-14 15:25:13 +00:00
( file ) => {
return ! this . excluded _extensions . includes ( file . extension . toLowerCase ( ) ) && ! this . excluded _folders . some ( ( folder ) => file . path . startsWith ( folder ) ) ;
}
) ;
2024-11-22 15:53:13 +00:00
this . _files _results = this . _files _excluded _filters ;
await this . dnOrganizeFiles ( { arr : this . _files _excluded _filters } ) ;
this . _recent = await this . dnGetRecentFiles ( this . _files _excluded _filters ) ;
const arrStrLastOpened = this . app . workspace . getLastOpenFiles ( ) ;
arrStrLastOpened . forEach ( async ( file ) => {
const f _temp = await this . app . vault . getAbstractFileByPath ( file ) ;
if ( f _temp instanceof import _obsidian2 . TFile ) {
this . _last _opened . push ( f _temp ) ;
}
} ) ;
2024-09-14 15:25:13 +00:00
}
async dnCreateMainUI ( el ) {
const mainContainer = el . createEl ( "div" , { cls : "dn-container" } ) ;
mainContainer . setAttribute ( "id" , "dn-container" ) ;
this . dnCreateInputSearch ( mainContainer ) ;
const topNav = mainContainer . createEl ( "div" , { cls : "dn-top-nav" } ) ;
const leftTopNav = topNav . createEl ( "div" ) ;
const rightTopNav = topNav . createEl ( "div" ) ;
this . _BTN _DASHBOARD = leftTopNav . createEl ( "button" , { text : "Dashboard" , cls : "mod-cta" } ) ;
this . _BTN _DASHBOARD . onClickEvent ( ( evt ) => {
this . dnSetView ( 1 ) ;
} ) ;
this . _BTN _NAVIGATOR = leftTopNav . createEl ( "button" , { text : "Navigator" } ) ;
this . _BTN _NAVIGATOR . onClickEvent ( ( evt ) => {
2024-11-22 15:53:13 +00:00
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
2024-09-14 15:25:13 +00:00
this . dnSetView ( 2 ) ;
} ) ;
this . labelLayout = rightTopNav . createEl ( "span" , {
text : "Layout:" ,
cls : "dn-tbl-label"
} ) ;
this . labelLayout . setAttribute ( "id" , "dn-label-layout" ) ;
this . _SELECT _TABLE _LAYOUT = rightTopNav . createEl ( "select" , {
cls : "dropdown tbl-select"
} ) ;
this . _SELECT _TABLE _LAYOUT . createEl ( "option" , { text : "Default" , value : "dn-tbl-default" } ) ;
this . _SELECT _TABLE _LAYOUT . createEl ( "option" , { text : "Row striped" , value : "dn-tbl-row" } ) ;
this . _SELECT _TABLE _LAYOUT . createEl ( "option" , { text : "Column striped" , value : "dn-tbl-column" } ) ;
this . _SELECT _TABLE _LAYOUT . createEl ( "option" , { text : "Bordered" , value : "dn-tbl-bordered" } ) ;
this . _SELECT _TABLE _LAYOUT . addEventListener ( "change" , ( ) => {
this . dnSelectTableLayout ( ) ;
} ) ;
this . labelSort = rightTopNav . createEl ( "span" , {
text : "Sort by:" ,
cls : "dn-tbl-label"
} ) ;
this . labelSort . setAttribute ( "id" , "dn-label-sort" ) ;
this . _SELECT _SORT = rightTopNav . createEl ( "select" , {
cls : "dropdown"
} ) ;
this . _SELECT _SORT . setAttribute ( "id" , "dn-select-sort" ) ;
this . _SELECT _SORT . addEventListener ( "change" , ( ) => {
this . dnSortColumnWithSelect ( ) ;
} ) ;
2024-11-22 15:53:13 +00:00
this . _SELECT _SORT . createEl ( "option" , { text : "Name (A to Z)" , value : "name-asc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Name (Z to A)" , value : "name-desc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Extension (A to Z)" , value : "ext-asc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Extension (Z to A)" , value : "ext-desc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Path (A to Z)" , value : "path-asc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Path (Z to A)" , value : "path-desc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Size (smallest to largest)" , value : "size-asc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Size (largest to smallest)" , value : "size-desc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Date/time (oldest to newest)" , value : "modified-asc" } ) ;
this . _SELECT _SORT . createEl ( "option" , { text : "Date/time (newest to oldest)" , value : "modified-desc" } ) ;
2024-09-14 15:25:13 +00:00
this . _VIEW _DASHBOARD = mainContainer . createEl ( "div" , { cls : "dn-flex" } ) ;
this . _VIEW _NAVIGATOR = mainContainer . createEl ( "div" , { cls : "dn-display-none" } ) ;
this . _divSearchResults = this . _VIEW _NAVIGATOR . createEl ( "div" , { cls : "dn-div-table" } ) ;
2024-11-22 15:53:13 +00:00
this . dnShowModalSearchResults ( { f : this . _files _results , el : this . _divSearchResults , leaf : this . _leaf } ) ;
2024-09-14 15:25:13 +00:00
const divVaultStats = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divVaultStats . setAttribute ( "id" , "dn-vault-stats" ) ;
const divVaultGraph = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divVaultGraph . setAttribute ( "id" , "dn-vault-graph" ) ;
2024-11-22 15:53:13 +00:00
const divLastOpenedFiles = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divLastOpenedFiles . setAttribute ( "id" , "dn-last-opened-files" ) ;
2024-09-14 15:25:13 +00:00
const divRecentFiles = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divRecentFiles . setAttribute ( "id" , "dn-recent-files" ) ;
const divRecentNotes = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divRecentNotes . setAttribute ( "id" , "dn-recent-notes" ) ;
const divCanvas = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divCanvas . setAttribute ( "id" , "dn-canvas" ) ;
const divImages = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divImages . setAttribute ( "id" , "dn-images" ) ;
const divAudios = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divAudios . setAttribute ( "id" , "dn-audios" ) ;
const divVideos = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divVideos . setAttribute ( "id" , "dn-videos" ) ;
const divPDFs = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divPDFs . setAttribute ( "id" , "dn-pdfs" ) ;
const divOther = this . _VIEW _DASHBOARD . createEl ( "div" ) ;
divOther . setAttribute ( "id" , "dn-other" ) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateBtn (
2024-09-14 15:25:13 +00:00
divVaultStats ,
"dn-btn-notes" ,
"Notes" ,
this . _notes ,
this . _divSearchResults ,
this . _leaf
) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateBtn (
2024-09-14 15:25:13 +00:00
divVaultStats ,
"dn-btn-canvas" ,
2024-11-22 15:53:13 +00:00
"Canvases" ,
2024-09-14 15:25:13 +00:00
this . _canvas ,
this . _divSearchResults ,
this . _leaf
) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateBtn (
2024-09-14 15:25:13 +00:00
divVaultStats ,
"dn-btn-images" ,
"Images" ,
this . _images ,
this . _divSearchResults ,
this . _leaf
) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateBtn (
2024-09-14 15:25:13 +00:00
divVaultStats ,
"dn-btn-audios" ,
"Audios" ,
this . _audios ,
this . _divSearchResults ,
this . _leaf
) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateBtn (
2024-09-14 15:25:13 +00:00
divVaultStats ,
"dn-btn-videos" ,
"Videos" ,
this . _videos ,
this . _divSearchResults ,
this . _leaf
) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateBtn (
2024-09-14 15:25:13 +00:00
divVaultStats ,
"dn-btn-pdf" ,
2024-11-22 15:53:13 +00:00
"PDFs" ,
2024-09-14 15:25:13 +00:00
this . _pdf ,
this . _divSearchResults ,
this . _leaf
) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateBtn (
2024-09-14 15:25:13 +00:00
divVaultStats ,
"dn-btn-other" ,
"Other" ,
this . _other ,
this . _divSearchResults ,
this . _leaf
) ;
const canvasPieChart1 = divVaultGraph . createEl ( "canvas" ) ;
canvasPieChart1 . setAttribute ( "id" , "dashboard-canvas" ) ;
const styles = getComputedStyle ( document . body ) ;
const labelColor = styles . getPropertyValue ( "--text-muted" ) ;
const pieChart1 = new DNPieChart ( canvasPieChart1 , 10 , 12 , 50 , labelColor ) ;
pieChart1 . addData ( this . _notes . length , this . color _notes , "Notes" ) ;
pieChart1 . addData ( this . _images . length , this . color _images , "Images" ) ;
pieChart1 . addData ( this . _canvas . length , this . color _canvas , "Canvas" ) ;
pieChart1 . addData ( this . _videos . length , this . color _videos , "Videos" ) ;
pieChart1 . addData ( this . _audios . length , this . color _audios , "Audios" ) ;
pieChart1 . addData ( this . _pdf . length , this . color _pdf , "PDF" ) ;
pieChart1 . addData ( this . _other . length , this . color _other , "Other" ) ;
pieChart1 . draw ( ) ;
const divStatsFrame = divVaultGraph . createEl ( "div" , { cls : "dn-stats-files-folders" } ) ;
2024-11-22 15:53:13 +00:00
divStatsFrame . createEl ( "div" , { cls : "dn-stats-files" , text : "Files: " + this . _files _excluded _filters . length } ) ;
2024-09-14 15:25:13 +00:00
divStatsFrame . createEl ( "div" , { cls : "dn-stats-folders" , text : "Folders: " + this . _folders . length } ) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateRecentFiles ( "Recently opened" , divLastOpenedFiles , this . _last _opened , this . num _recent _files ) ;
2024-09-14 15:25:13 +00:00
await this . dnCreateRecentFiles ( "Recent files" , divRecentFiles , this . _recent , this . num _recent _files ) ;
await this . dnCreateRecentFiles ( "Recent notes" , divRecentNotes , this . _notes , this . num _recent _files ) ;
2024-11-22 15:53:13 +00:00
await this . dnCreateRecentFiles ( "Recent canvases" , divCanvas , this . _canvas , this . num _recent _files ) ;
2024-09-14 15:25:13 +00:00
await this . dnCreateRecentFiles ( "Recent images" , divImages , this . _images , this . num _recent _files ) ;
await this . dnCreateRecentFiles ( "Recent audios" , divAudios , this . _audios , this . num _recent _files ) ;
await this . dnCreateRecentFiles ( "Recent videos" , divVideos , this . _videos , this . num _recent _files ) ;
await this . dnCreateRecentFiles ( "Recent PDFs" , divPDFs , this . _pdf , this . num _recent _files ) ;
await this . dnCreateRecentFiles ( "Recent other files" , divOther , this . _other , this . num _recent _files ) ;
}
async dnCreateBtn ( elDiv , btnId , btnTitle , btnCategoryFiles , displayEl , leaf ) {
2024-11-22 15:53:13 +00:00
const btn = elDiv . createEl ( "div" , { cls : "dn-btn-stats" } ) ;
2024-09-14 15:25:13 +00:00
btn . setAttribute ( "id" , btnId ) ;
btn . createEl ( "span" , { cls : "dn-btn-stats-label" , text : btnTitle } ) ;
btn . createEl ( "span" , { cls : "dn-btn-stats-icon" } ) ;
btn . createEl ( "span" , { cls : "dn-btn-stats-number" , text : btnCategoryFiles . length . toString ( ) } ) ;
btn . onClickEvent ( ( evt ) => {
2024-11-22 15:53:13 +00:00
this . _files _results = btnCategoryFiles ;
this . _INPUT _SEARCH . value = "@" + btnTitle . toLocaleLowerCase ( ) + " " ;
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
this . _INPUT _SEARCH . focus ( ) ;
2024-09-14 15:25:13 +00:00
} ) ;
return btn ;
}
dnCreateInputSearch ( el ) {
const searchContainer = el . createEl ( "div" , { cls : "dn-search-input-container" } ) ;
this . _INPUT _SEARCH = searchContainer . createEl ( "input" , { type : "search" , placeholder : "Search..." } ) ;
this . _INPUT _SEARCH . setAttribute ( "id" , "dn-input-filter" ) ;
this . _INPUT _SEARCH . spellcheck = false ;
this . _INPUT _SEARCH . focus ( ) ;
2024-11-22 15:53:13 +00:00
searchContainer . createEl ( "div" , { cls : "search-input-clear-button" } ) . onClickEvent ( ( evt ) => {
2024-09-14 15:25:13 +00:00
this . _INPUT _SEARCH . value = "" ;
this . _INPUT _SEARCH . focus ( ) ;
2024-11-22 15:53:13 +00:00
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
} ) ;
this . _INPUT _SEARCH . addEventListener ( "input" , ( 0 , import _obsidian2 . debounce ) ( ( ) => this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) , 300 , true ) ) ;
}
async dnModalSearchVault ( val ) {
this . dnSetView ( 2 ) ;
const search _raw _vals = /!(?:"(?:\\"|[^"])*"|'(?:\\'|[^'])*')|"(?:\\"|[^"])*"|'(?:\\'|[^'])*'|\S+/g ;
let searchParams = val . toLowerCase ( ) . trim ( ) . match ( search _raw _vals ) ;
if ( ! searchParams ) {
return this . searchAction ( "" , this . _files _excluded _filters ) ;
}
searchParams = searchParams . map ( ( param ) => {
if ( param . startsWith ( '"' ) && param . endsWith ( '"' ) ) {
return param . slice ( 1 , - 1 ) ;
} else if ( param . startsWith ( "'" ) && param . endsWith ( "'" ) ) {
return param . slice ( 1 , - 1 ) ;
} else if ( param . startsWith ( "." ) ) {
return "\\" + param + "$" ;
2024-11-29 13:32:34 +00:00
} else if ( param . startsWith ( "/" ) && param . length === 1 ) {
return "^/$" ;
2024-11-22 15:53:13 +00:00
} else {
return param ;
}
} ) ;
const firstParam = searchParams [ 0 ] ;
await this . searchAction ( firstParam , this . _files _excluded _filters ) ;
const remainingParams = searchParams . slice ( 1 ) ;
remainingParams . every ( async ( p ) => {
await this . searchAction ( p , this . _files _results ) ;
2024-09-14 15:25:13 +00:00
} ) ;
}
2024-11-22 15:53:13 +00:00
// Search
async searchAction ( val , files ) {
2024-09-14 15:25:13 +00:00
let rExp ;
2024-11-29 13:32:34 +00:00
const isExcludeSearch = val . startsWith ( "!" ) && val . length >= 1 ;
2024-11-22 15:53:13 +00:00
let excludeParam = isExcludeSearch ? val . slice ( 1 ) : val ;
if ( excludeParam . startsWith ( '"' ) && excludeParam . endsWith ( '"' ) ) {
excludeParam = excludeParam . slice ( 1 , - 1 ) ;
} else if ( excludeParam . startsWith ( "'" ) && excludeParam . endsWith ( "'" ) ) {
excludeParam = excludeParam . slice ( 1 , - 1 ) ;
}
2024-09-14 15:25:13 +00:00
try {
2024-11-22 15:53:13 +00:00
if ( isExcludeSearch ) {
rExp = new RegExp ( "" , "iu" ) ;
} else {
if ( val === "!" ) {
rExp = new RegExp ( "" , "iu" ) ;
} else {
rExp = new RegExp ( val . toLowerCase ( ) , "iu" ) ;
}
}
2024-09-14 15:25:13 +00:00
} catch ( error ) {
return ;
}
const isDateSearch = val . startsWith ( "@" ) ;
2024-11-22 15:53:13 +00:00
if ( this . _INPUT _SEARCH . value . includes ( "@" ) ) {
2024-09-14 15:25:13 +00:00
this . _INPUT _SEARCH . classList . add ( "dn-input-datesearch" ) ;
} else {
this . _INPUT _SEARCH . classList . remove ( "dn-input-datesearch" ) ;
}
2024-11-22 15:53:13 +00:00
if ( isExcludeSearch ) {
2024-11-29 13:32:34 +00:00
let isMatch ;
if ( excludeParam === "/" ) {
this . _files _results = files . filter ( ( file ) => {
isMatch = getFolderStructure ( file . path ) . toLowerCase ( ) === "/" ;
return isExcludeSearch ? ! isMatch : isMatch ;
} ) ;
} else {
this . _files _results = files . filter ( ( file ) => {
isMatch = file . name . toLowerCase ( ) . includes ( excludeParam ) || getFolderStructure ( file . path ) . toLowerCase ( ) . includes ( excludeParam ) || ( 0 , import _obsidian3 . moment ) ( file . stat . mtime ) . format ( this . date _format ) . toLowerCase ( ) . includes ( excludeParam ) || getTagsPerFile ( file ) . toLowerCase ( ) . includes ( excludeParam ) || getPropsPerFile ( file ) . toLowerCase ( ) . includes ( excludeParam ) ;
return isExcludeSearch ? ! isMatch : isMatch ;
} ) ;
}
2024-11-22 15:53:13 +00:00
} else {
this . _files _results = files . filter (
( file ) => {
if ( isDateSearch ) {
const dateSearch = val . slice ( 1 ) . toLowerCase ( ) . split ( " " ) ;
return this . dnHandleSpecialSearch ( dateSearch [ 0 ] , file ) ;
} else {
return this . dnHandleNormalSearch ( rExp , file ) ;
2024-09-14 15:25:13 +00:00
}
}
2024-11-22 15:53:13 +00:00
) ;
}
2024-09-14 15:25:13 +00:00
this . dnSortFilteredFiles ( false ) ;
2024-11-22 15:53:13 +00:00
await this . dnShowModalSearchResults ( { f : this . _files _results , el : this . _divSearchResults , leaf : this . _leaf } ) ;
2024-09-14 15:25:13 +00:00
const tbody = document . getElementById ( "dn-table-results" ) ;
if ( tbody !== null ) {
const tr = tbody . getElementsByTagName ( "tr" ) ;
for ( let i = 0 , len = tr . length ; i < len ; i ++ ) {
const allTds = tr [ i ] . querySelectorAll ( "td" ) ;
let isResult = false ;
for ( let j = 0 ; j < allTds . length ; j ++ ) {
const td = allTds [ j ] ;
const tdVal = td . innerText . toLowerCase ( ) ;
if ( rExp . test ( tdVal ) || isDateSearch ) {
isResult = true ;
break ;
}
}
if ( isResult ) {
tr [ i ] . classList . remove ( "dn-display-none" ) ;
} else {
tr [ i ] . classList . add ( "dn-display-none" ) ;
}
}
}
}
2024-11-22 15:53:13 +00:00
async dnShowModalSearchResults ( { f , el , leaf , currentPage = 1 } ) {
2024-09-14 15:25:13 +00:00
el . empty ( ) ;
const paginationContainer = this . _divSearchResults . createEl ( "div" , { cls : "dn-pagination" } ) ;
const table = el . createEl ( "table" , { cls : this . selected _table _layout } ) ;
table . setAttribute ( "id" , "dn-table" ) ;
const thead = table . createEl ( "thead" ) ;
const tr = thead . createEl ( "tr" ) ;
this . _th1 = tr . createEl ( "th" , { text : "Name" } ) ;
2024-11-22 15:53:13 +00:00
this . _th2 = tr . createEl ( "th" , { text : "Ext" } ) ;
this . _th3 = tr . createEl ( "th" , { text : "Path" } ) ;
this . _th4 = tr . createEl ( "th" , { text : "Size" } ) ;
this . _th5 = tr . createEl ( "th" , { text : "Date" } ) ;
this . _th6 = tr . createEl ( "th" , { text : "Tags" } ) ;
this . _th7 = tr . createEl ( "th" , { text : "Frontmatter" } ) ;
2024-09-14 15:25:13 +00:00
this . _th1 . addEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "name" ) ) ;
2024-11-22 15:53:13 +00:00
this . _th2 . addEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "ext" ) ) ;
this . _th3 . addEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "path" ) ) ;
this . _th4 . addEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "size" ) ) ;
this . _th5 . addEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "modified" ) ) ;
2024-09-14 15:25:13 +00:00
const tbody = table . createEl ( "tbody" ) ;
tbody . setAttribute ( "id" , "dn-table-results" ) ;
if ( f . length > 0 ) {
if ( this . intersectionObserver ) {
this . intersectionObserver . disconnect ( ) ;
}
this . _total _pages = Math . ceil ( f . length / this . files _per _page ) ;
const paginatedData = f . slice ( ( currentPage - 1 ) * this . files _per _page , currentPage * this . files _per _page ) ;
paginatedData . forEach ( async ( file ) => {
2024-11-22 15:53:13 +00:00
const tr2 = tbody . createEl ( "tr" ) ;
2024-09-14 15:25:13 +00:00
tr2 . addEventListener ( "contextmenu" , ( evt ) => {
this . dnHandleClick ( evt , file ) ;
} ) ;
tr2 . addEventListener ( "click" , ( evt ) => {
this . dnHandleClick ( evt , file ) ;
} ) ;
tr2 . addEventListener ( "dblclick" , ( evt ) => {
this . dnHandleDblClick ( evt , file ) ;
} ) ;
2024-11-22 15:53:13 +00:00
tr2 . addEventListener ( "mouseover" , async ( evt ) => {
this . dnHandleHoverPreview ( evt , file ) ;
} ) ;
2024-09-14 15:25:13 +00:00
this . intersectionObserver . observe ( tr2 ) ;
2024-11-22 15:53:13 +00:00
tr2 . removeEventListener ( "mouseover" , async ( evt ) => {
this . dnHandleHoverPreview ( evt , file ) ;
} ) ;
const td1 = tr2 . createEl ( "td" ) ;
td1 . createEl ( "a" , { cls : this . dnSetFileIconClass ( file . extension ) , text : file . name } ) . onClickEvent ( ( evt ) => {
2024-09-14 15:25:13 +00:00
if ( leaf !== null && file !== null ) {
this . dnOpenFileAlt ( file , evt ) ;
}
} ) ;
2024-11-22 15:53:13 +00:00
const fExt = file . extension ;
const fSize = formatFileSize ( file . stat . size ) ;
const fMTime = ( 0 , import _obsidian3 . moment ) ( file . stat . mtime ) . format ( this . date _format ) ;
const fCTime = ( 0 , import _obsidian3 . moment ) ( file . stat . ctime ) . format ( this . date _format ) ;
const td2 = tr2 . createEl ( "td" ) ;
td2 . createEl ( "a" , { cls : "dn-ext" , text : fExt , title : fExt } ) . onClickEvent ( ( evt ) => {
if ( evt . button === 2 ) {
evt . preventDefault ( ) ;
} else {
this . _INPUT _SEARCH . value = "." + fExt ;
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
}
} ) ;
const td3 = tr2 . createEl ( "td" ) ;
const folder _path = getFolderStructure ( file . path ) ;
td3 . createEl ( "a" , { cls : "dn-folder-path" , text : folder _path , title : file . path } ) . onClickEvent ( ( evt ) => {
if ( evt . button === 2 ) {
evt . preventDefault ( ) ;
} else {
this . _INPUT _SEARCH . value = folder _path ;
this . dnModalSearchVault ( this . _INPUT _SEARCH . value + "$" ) ;
}
2024-09-14 15:25:13 +00:00
} ) ;
2024-11-22 15:53:13 +00:00
tr2 . createEl ( "td" , { text : fSize , title : fSize + " bytes" } ) ;
tr2 . createEl ( "td" , { text : fMTime , title : fCTime + " - Created\n" + fMTime + " - Modified" } ) ;
const tags _per _file = getTagsPerFile ( file ) ;
const props _per _file = getPropsPerFile ( file ) ;
const td6 = tr2 . createEl ( "td" , { title : tags _per _file } ) ;
2024-11-29 13:32:34 +00:00
if ( tags _per _file !== "" ) {
const fTags = tags _per _file . split ( " " ) ;
fTags . forEach ( ( tag ) => {
td6 . createEl ( "a" , { cls : "tag" , text : tag , href : tag } ) . onClickEvent ( ( evt ) => {
if ( evt . button === 2 ) {
evt . preventDefault ( ) ;
} else {
this . _INPUT _SEARCH . value = tag ;
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
}
} ) ;
2024-11-22 15:53:13 +00:00
} ) ;
2024-11-29 13:32:34 +00:00
}
const td7 = tr2 . createEl ( "td" ) ;
if ( props _per _file !== "" ) {
const fProps = props _per _file . split ( "\n" ) ;
fProps . forEach ( ( prop ) => {
td7 . createEl ( "a" , { cls : "dn-tag" , text : prop , title : props _per _file } ) . onClickEvent ( ( evt ) => {
if ( evt . button === 2 ) {
evt . preventDefault ( ) ;
} else {
this . _INPUT _SEARCH . value = prop ;
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
}
} ) ;
2024-09-14 15:25:13 +00:00
} ) ;
2024-11-29 13:32:34 +00:00
}
2024-09-14 15:25:13 +00:00
} ) ;
paginationContainer . empty ( ) ;
2024-11-22 15:53:13 +00:00
paginationContainer . createEl ( "div" , { cls : "dn-pagination-total-results" , text : ` File(s): ${ f . length } ` } ) ;
const rightPagDiv = paginationContainer . createEl ( "div" , { cls : "dn-pagination-current-page" , text : ` Page ${ currentPage } of ${ this . _total _pages } ` } ) ;
const btnPrev = rightPagDiv . createEl ( "button" , { cls : "dn-btn-prev" , text : "\u25C0" , title : "Previous" } ) ;
2024-09-14 15:25:13 +00:00
if ( currentPage === 1 ) {
btnPrev . disabled = true ;
} else {
btnPrev . disabled = false ;
}
btnPrev . addEventListener ( "click" , ( ) => {
if ( currentPage > 1 ) {
2024-11-22 15:53:13 +00:00
this . dnShowModalSearchResults ( { f , el , leaf , currentPage : currentPage - 1 } ) ;
2024-09-14 15:25:13 +00:00
}
} ) ;
2024-11-22 15:53:13 +00:00
const btnNext = rightPagDiv . createEl ( "button" , { cls : "dn-btn-next" , text : "\u25B6" , title : "Next" } ) ;
2024-09-14 15:25:13 +00:00
if ( currentPage === this . _total _pages ) {
btnNext . disabled = true ;
} else {
btnNext . disabled = false ;
}
btnNext . addEventListener ( "click" , ( ) => {
if ( currentPage < this . _total _pages ) {
2024-11-22 15:53:13 +00:00
this . dnShowModalSearchResults ( { f , el , leaf , currentPage : currentPage + 1 } ) ;
2024-09-14 15:25:13 +00:00
}
} ) ;
this . dnUpdateSortIndicators (
this . _sort _column ,
this . _sort _order ,
this . _th1 ,
this . _th2 ,
this . _th3 ,
2024-11-22 15:53:13 +00:00
this . _th4 ,
this . _th5
2024-09-14 15:25:13 +00:00
) ;
2024-11-22 15:53:13 +00:00
const dnTableManager = new DNTableManager ( "#dn-table" ) ;
dnTableManager . hideColumns ( this . hide _columns ) ;
2024-09-14 15:25:13 +00:00
} else {
tr . empty ( ) ;
2024-11-22 15:53:13 +00:00
paginationContainer . createEl ( "div" , { cls : "dn-pagination-total-results" , text : ` File(s): 0 ` } ) ;
2024-09-14 15:25:13 +00:00
this . _divSearchResults . createEl ( "p" , { cls : "dn-no-results-found" , text : "No files found." } ) ;
}
}
2024-11-22 15:53:13 +00:00
async dnSortFilteredFiles ( toggle ) {
switch ( this . _sort _column ) {
2024-09-14 15:25:13 +00:00
case "name" :
case "path" :
2024-11-22 15:53:13 +00:00
case "ext" :
this . dnSortColumnString ( this . _sort _column , this . _sort _order , toggle ) ;
2024-09-14 15:25:13 +00:00
break ;
case "size" :
case "modified" :
2024-11-22 15:53:13 +00:00
this . dnSortColumnNumber ( this . _sort _column , this . _sort _order , toggle ) ;
2024-09-14 15:25:13 +00:00
break ;
}
}
2024-11-22 15:53:13 +00:00
dnSortColumnWithSelect ( ) {
const val = this . _SELECT _SORT . value ;
if ( this . dnIsValidSort ( val ) ) {
const selSort = val . split ( "-" ) ;
this . _sort _column = selSort [ 0 ] ;
this . _sort _order = selSort [ 1 ] ;
switch ( this . _sort _column ) {
case "name" :
case "path" :
case "ext" :
this . dnSortColumnString ( this . _sort _column , this . _sort _order , false ) ;
break ;
case "size" :
case "modified" :
this . dnSortColumnNumber ( this . _sort _column , this . _sort _order , false ) ;
break ;
}
this . dnShowModalSearchResults ( { f : this . _files _results , el : this . _divSearchResults , leaf : this . _leaf } ) ;
}
}
dnIsValidSort ( val ) {
if ( [
"name-asc" ,
"name-desc" ,
"path-asc" ,
"path-desc" ,
"ext-asc" ,
"ext-desc" ,
"size-asc" ,
"size-desc" ,
"modified-asc" ,
"modified-desc"
] . includes ( val ) ) {
return true ;
} else {
return false ;
}
}
dnIsValidLayout ( val ) {
if ( this . _TABLE _LAYOUTS . includes ( val ) ) {
return true ;
} else {
return false ;
}
}
dnAlternateSortColumn ( colName ) {
switch ( colName ) {
case "name" :
this . dnSortColumnString ( "name" , this . _sort _order , true ) ;
break ;
case "path" :
this . dnSortColumnString ( "path" , this . _sort _order , true ) ;
break ;
case "ext" :
this . dnSortColumnString ( "ext" , this . _sort _order , true ) ;
break ;
2024-09-14 15:25:13 +00:00
case "size" :
2024-11-22 15:53:13 +00:00
this . dnSortColumnNumber ( "size" , this . _sort _order , true ) ;
2024-09-14 15:25:13 +00:00
break ;
case "modified" :
2024-11-22 15:53:13 +00:00
this . dnSortColumnNumber ( "modified" , this . _sort _order , true ) ;
break ;
}
this . dnShowModalSearchResults ( { f : this . _files _results , el : this . _divSearchResults , leaf : this . _leaf } ) ;
}
dnUpdateSortIndicators ( activeColumn , sortOrder , col1 , col2 , col3 , col4 , col5 ) {
col1 . classList . remove ( "sort-active" , "sort-asc" , "sort-desc" ) ;
col2 . classList . remove ( "sort-active" , "sort-asc" , "sort-desc" ) ;
col3 . classList . remove ( "sort-active" , "sort-asc" , "sort-desc" ) ;
col4 . classList . remove ( "sort-active" , "sort-asc" , "sort-desc" ) ;
col5 . classList . remove ( "sort-active" , "sort-asc" , "sort-desc" ) ;
let activeThCell = col5 ;
switch ( activeColumn ) {
case "name" :
activeThCell = col1 ;
break ;
case "ext" :
activeThCell = col2 ;
break ;
case "path" :
activeThCell = col3 ;
break ;
case "size" :
2024-09-14 15:25:13 +00:00
activeThCell = col4 ;
break ;
2024-11-22 15:53:13 +00:00
case "modified" :
activeThCell = col5 ;
break ;
2024-09-14 15:25:13 +00:00
}
activeThCell . classList . add ( "sort-active" ) ;
activeThCell . classList . add ( sortOrder === "asc" ? "sort-asc" : "sort-desc" ) ;
}
dnSortColumnString ( sortColumn , sortOrder , toggleSortOrder ) {
2024-11-22 15:53:13 +00:00
const supportedColumns = [ "name" , "path" , "ext" ] ;
2024-09-14 15:25:13 +00:00
if ( ! supportedColumns . includes ( sortColumn ) ) {
return ;
}
if ( toggleSortOrder ) {
if ( this . _sort _column === sortColumn ) {
sortOrder = sortOrder === "asc" ? "desc" : "asc" ;
} else {
this . _sort _column = sortColumn ;
sortOrder = "desc" ;
}
this . _sort _order = sortOrder ;
}
const sortValue = sortColumn + "-" + this . _sort _order ;
this . dnSetSelectSortValue ( sortValue ) ;
2024-11-22 15:53:13 +00:00
this . _files _results . sort ( ( fileA , fileB ) => {
2024-09-14 15:25:13 +00:00
let sortA ;
let sortB ;
2024-11-22 15:53:13 +00:00
let folderStructureA ;
let folderStructureB ;
2024-09-14 15:25:13 +00:00
switch ( sortColumn ) {
case "name" :
sortA = fileA . name . toLowerCase ( ) ;
sortB = fileB . name . toLowerCase ( ) ;
break ;
2024-11-22 15:53:13 +00:00
case "ext" :
sortA = fileA . extension . toLowerCase ( ) ;
sortB = fileB . extension . toLowerCase ( ) ;
break ;
2024-09-14 15:25:13 +00:00
case "path" :
2024-11-22 15:53:13 +00:00
folderStructureA = getFolderStructure ( fileA . path ) ;
folderStructureB = getFolderStructure ( fileB . path ) ;
2024-09-14 15:25:13 +00:00
sortA = folderStructureA . toLowerCase ( ) ;
sortB = folderStructureB . toLowerCase ( ) ;
break ;
default :
sortA = fileA . name . toLowerCase ( ) ;
sortB = fileB . name . toLowerCase ( ) ;
}
if ( sortOrder === "asc" ) {
return sortA . localeCompare ( sortB ) ;
} else if ( sortOrder === "desc" ) {
return sortB . localeCompare ( sortA ) ;
} else {
return sortA . localeCompare ( sortB ) ;
}
} ) ;
}
dnSortColumnNumber ( sortColumn , sortOrder , toggleSortOrder ) {
const supportedColumns = [ "size" , "modified" ] ;
if ( ! supportedColumns . includes ( sortColumn ) ) {
return ;
}
if ( toggleSortOrder ) {
if ( this . _sort _column === sortColumn ) {
sortOrder = sortOrder === "asc" ? "desc" : "asc" ;
} else {
this . _sort _column = sortColumn ;
sortOrder = "desc" ;
}
this . _sort _order = sortOrder ;
}
const sortValue = sortColumn + "-" + this . _sort _order ;
this . dnSetSelectSortValue ( sortValue ) ;
2024-11-22 15:53:13 +00:00
this . _files _results . sort ( ( fileA , fileB ) => {
2024-09-14 15:25:13 +00:00
let sortA = 0 ;
let sortB = 0 ;
switch ( sortColumn ) {
case "size" :
sortA = fileA . stat . size ;
sortB = fileB . stat . size ;
break ;
case "modified" :
sortA = fileA . stat . mtime ;
sortB = fileB . stat . mtime ;
break ;
}
if ( sortOrder === "asc" ) {
return sortA - sortB ;
} else if ( sortOrder === "desc" ) {
return sortB - sortA ;
} else {
return sortA - sortB ;
}
} ) ;
}
async dnGetRecentFiles ( files ) {
const arrRecentFiles = files ;
return arrRecentFiles . sort ( ( a , b ) => b . stat . mtime - a . stat . mtime ) . slice ( 0 , this . num _recent _files ) ;
}
2024-11-22 15:53:13 +00:00
async dnCreateRecentFiles ( title , divF , files , num _files ) {
if ( files . length === 0 ) {
divF . createEl ( "h3" , { cls : "dn-subtitles" , text : title } ) ;
divF . createEl ( "p" , { cls : "dn-no-results-found" , text : "No files found." } ) ;
divF . classList . add ( "dn-display-none" ) ;
} else {
divF . createEl ( "h3" , { cls : "dn-subtitles" , text : title } ) ;
let sortedFiles = [ ] ;
if ( title === "Recently opened" ) {
sortedFiles = files . slice ( 0 , this . num _recent _files ) ;
} else {
sortedFiles = await this . dnGetRecentFiles ( files ) ;
}
sortedFiles . forEach ( ( sfile ) => {
const aLink = divF . createEl ( "a" , {
cls : this . dnSetFileIconClass ( sfile . extension ) ,
text : sfile . basename ,
title : sfile . path
} ) ;
aLink . onClickEvent ( ( evt ) => {
if ( sfile !== null ) {
this . dnOpenFileAlt ( sfile , evt ) ;
}
} ) ;
if ( sfile . extension !== "md" ) {
divF . createEl ( "span" , { cls : "nav-file-tag" , text : sfile . extension } ) ;
}
divF . createEl ( "br" ) ;
aLink . addEventListener ( "mouseover" , ( evt ) => this . dnHandleHoverPreview ( evt , sfile ) ) ;
} ) ;
}
}
2024-09-14 15:25:13 +00:00
async dnOrganizeFiles ( { arr } ) {
const arrNotes = [ ] ;
const arrImages = [ ] ;
const arrAudios = [ ] ;
const arrCanvas = [ ] ;
const arrVideos = [ ] ;
const arrPDFs = [ ] ;
const arrOther = [ ] ;
const extensions = {
"md" : arrNotes ,
2024-11-22 15:53:13 +00:00
// Images
"avif" : arrImages ,
2024-09-14 15:25:13 +00:00
"bmp" : arrImages ,
"gif" : arrImages ,
2024-11-22 15:53:13 +00:00
"ico" : arrImages ,
"jpeg" : arrImages ,
"jpg" : arrImages ,
"png" : arrImages ,
"raw" : arrImages ,
"svg" : arrImages ,
2024-09-14 15:25:13 +00:00
"tif" : arrImages ,
"tiff" : arrImages ,
2024-11-22 15:53:13 +00:00
"webp" : arrImages ,
// Audios
"aac" : arrAudios ,
"aif" : arrAudios ,
"aifc" : arrAudios ,
"aiff" : arrAudios ,
"flac" : arrAudios ,
"m4a" : arrAudios ,
2024-09-14 15:25:13 +00:00
"mp3" : arrAudios ,
"ogg" : arrAudios ,
2024-11-22 15:53:13 +00:00
"wav" : arrAudios ,
2024-09-14 15:25:13 +00:00
"webm" : arrAudios ,
2024-11-22 15:53:13 +00:00
// Videos
2024-09-14 15:25:13 +00:00
"avi" : arrVideos ,
2024-11-22 15:53:13 +00:00
"mov" : arrVideos ,
"mkv" : arrVideos ,
"mp4" : arrVideos ,
// PDF and other formats
2024-09-14 15:25:13 +00:00
"pdf" : arrPDFs ,
"canvas" : arrCanvas
} ;
for ( let i = 0 , len = arr . length ; i < len ; i ++ ) {
const f = arr [ i ] . extension . toLowerCase ( ) ;
const targetArr = extensions [ f ] ;
if ( targetArr ) {
targetArr . push ( arr [ i ] ) ;
} else {
arrOther . push ( arr [ i ] ) ;
}
}
this . _notes = arrNotes ;
this . _images = arrImages ;
this . _audios = arrAudios ;
this . _videos = arrVideos ;
this . _pdf = arrPDFs ;
this . _canvas = arrCanvas ;
this . _other = arrOther ;
}
dnSetFileIconClass ( ext ) {
const file _extension = ext . toLowerCase ( ) ;
const extensions = {
"md" : "note" ,
2024-11-22 15:53:13 +00:00
// Images
"avif" : "image" ,
2024-09-14 15:25:13 +00:00
"bmp" : "image" ,
"gif" : "image" ,
2024-11-22 15:53:13 +00:00
"ico" : "image" ,
"jpeg" : "image" ,
"jpg" : "image" ,
"png" : "image" ,
"raw" : "image" ,
"svg" : "image" ,
2024-09-14 15:25:13 +00:00
"tif" : "image" ,
"tiff" : "image" ,
2024-11-22 15:53:13 +00:00
"webp" : "image" ,
// Audios
"aac" : "audio" ,
"aif" : "audio" ,
"aifc" : "audio" ,
"aiff" : "audio" ,
"flac" : "audio" ,
"m4a" : "audio" ,
2024-09-14 15:25:13 +00:00
"mp3" : "audio" ,
"ogg" : "audio" ,
2024-11-22 15:53:13 +00:00
"wav" : "audio" ,
2024-09-14 15:25:13 +00:00
"webm" : "audio" ,
2024-11-22 15:53:13 +00:00
// Videos
2024-09-14 15:25:13 +00:00
"avi" : "video" ,
2024-11-22 15:53:13 +00:00
"mov" : "video" ,
"mkv" : "video" ,
"mp4" : "video" ,
// PDF and other formats
2024-09-14 15:25:13 +00:00
"pdf" : "pdf" ,
"canvas" : "canvas"
} ;
if ( file _extension in extensions ) {
return "dn-f-" + extensions [ file _extension ] ;
} else {
return "dn-f-other" ;
}
}
2024-11-22 15:53:13 +00:00
// Custom Colors
dnSetCustomColors ( ) {
document . body . style . setProperty ( "--dn-notes-color" , this . color _notes ) ;
document . body . style . setProperty ( "--dn-images-color" , this . color _images ) ;
document . body . style . setProperty ( "--dn-canvas-color" , this . color _canvas ) ;
document . body . style . setProperty ( "--dn-videos-color" , this . color _videos ) ;
document . body . style . setProperty ( "--dn-audios-color" , this . color _audios ) ;
document . body . style . setProperty ( "--dn-pdfs-color" , this . color _pdf ) ;
document . body . style . setProperty ( "--dn-other-color" , this . color _other ) ;
}
dnToggleColoredFiles ( ) {
const dnMainContainer = document . getElementById ( "dn-container" ) ;
if ( this . colored _files ) {
dnMainContainer == null ? void 0 : dnMainContainer . classList . add ( "dn-colored-files" ) ;
} else {
dnMainContainer == null ? void 0 : dnMainContainer . classList . remove ( "dn-colored-files" ) ;
}
this . dnSetCustomColors ( ) ;
}
2024-09-14 15:25:13 +00:00
dnSetView ( view ) {
const divElements = [ this . _VIEW _DASHBOARD , this . _VIEW _NAVIGATOR ] ;
const topNavBtns = [ this . _BTN _DASHBOARD , this . _BTN _NAVIGATOR ] ;
divElements . forEach ( ( el ) => {
el . classList . add ( "dn-display-none" ) ;
el . classList . remove ( "dn-flex" ) ;
} ) ;
topNavBtns . forEach ( ( btn ) => btn . classList . remove ( "mod-cta" ) ) ;
switch ( view ) {
case 1 :
this . _VIEW _DASHBOARD . classList . remove ( "dn-display-none" ) ;
this . _VIEW _DASHBOARD . classList . add ( "dn-flex" ) ;
this . _BTN _DASHBOARD . classList . add ( "mod-cta" ) ;
this . dnHideTopRightNav ( ) ;
break ;
case 2 :
this . _VIEW _NAVIGATOR . classList . remove ( "dn-display-none" ) ;
this . _VIEW _NAVIGATOR . classList . add ( "dn-flex" ) ;
this . _BTN _NAVIGATOR . classList . add ( "mod-cta" ) ;
this . dnShowTopRightNav ( ) ;
break ;
default :
this . _VIEW _DASHBOARD . classList . remove ( "dn-display-none" ) ;
this . _VIEW _DASHBOARD . classList . add ( "dn-flex" ) ;
this . _BTN _DASHBOARD . classList . add ( "mod-cta" ) ;
this . dnHideTopRightNav ( ) ;
}
}
dnShowTopRightNav ( ) {
this . _SELECT _SORT . classList . remove ( "dn-display-none" ) ;
this . _SELECT _TABLE _LAYOUT . classList . remove ( "dn-display-none" ) ;
this . labelLayout . classList . remove ( "dn-display-none" ) ;
this . labelSort . classList . remove ( "dn-display-none" ) ;
}
dnHideTopRightNav ( ) {
this . _SELECT _SORT . classList . add ( "dn-display-none" ) ;
this . _SELECT _TABLE _LAYOUT . classList . add ( "dn-display-none" ) ;
this . labelLayout . classList . add ( "dn-display-none" ) ;
this . labelSort . classList . add ( "dn-display-none" ) ;
}
dnSetSelectSortValue ( val ) {
if ( this . dnIsValidSort ( val ) ) {
this . selected _sort _value = val ;
this . _SELECT _SORT . value = this . selected _sort _value ;
}
}
dnSetSelectLayoutValue ( val ) {
if ( this . dnIsValidLayout ( val ) ) {
this . _SELECT _TABLE _LAYOUT . value = val ;
this . dnSelectTableLayout ( ) ;
}
}
dnSelectTableLayout ( ) {
const val = this . _SELECT _TABLE _LAYOUT . value ;
if ( this . _TABLE _LAYOUTS . includes ( val ) ) {
const tbl = document . getElementById ( "dn-table" ) ;
this . _TABLE _LAYOUTS . forEach ( ( layout ) => tbl == null ? void 0 : tbl . classList . remove ( layout ) ) ;
tbl == null ? void 0 : tbl . classList . add ( val ) ;
this . selected _table _layout = val ;
}
}
dnSelectTableRow ( evt ) {
if ( ! evt || typeof evt !== "object" ) {
return ;
}
if ( evt . target instanceof HTMLTableCellElement ) {
const allTr = document . querySelectorAll ( "#dn-table tr" ) ;
allTr . forEach ( ( row ) => row . classList . remove ( "tbl-selected" ) ) ;
const clickedTr = evt . target . parentElement ;
clickedTr . classList . add ( "tbl-selected" ) ;
}
}
dnGenerateContextMenu ( evt , file ) {
this . _DN _CTX _MENU = new import _obsidian2 . Menu ( ) ;
this . _DN _CTX _MENU . addItem (
( item ) => item . setTitle ( "Open" ) . setIcon ( "mouse-pointer-2" ) . onClick ( ( ) => {
this . app . workspace . getLeaf ( false ) . openFile ( file ) ;
this . close ( ) ;
} )
) ;
this . _DN _CTX _MENU . addSeparator ( ) ;
this . _DN _CTX _MENU . addItem (
( item ) => item . setTitle ( "Open in new tab" ) . setIcon ( "file-plus" ) . onClick ( ( ) => {
this . app . workspace . getLeaf ( "tab" ) . openFile ( file ) ;
this . close ( ) ;
} )
) ;
this . _DN _CTX _MENU . addItem (
( item ) => item . setTitle ( "Open to the right" ) . setIcon ( "separator-vertical" ) . onClick ( ( ) => {
this . app . workspace . getLeaf ( "split" ) . openFile ( file ) ;
this . close ( ) ;
} )
) ;
this . _DN _CTX _MENU . addItem (
( item ) => item . setTitle ( "Open in new window" ) . setIcon ( "picture-in-picture-2" ) . onClick ( ( ) => {
this . app . workspace . getLeaf ( "window" ) . openFile ( file ) ;
} )
) ;
this . _DN _CTX _MENU . addSeparator ( ) ;
2024-11-22 15:53:13 +00:00
this . _DN _CTX _MENU . addItem (
( item ) => item . setTitle ( "Show preview" ) . setIcon ( "eye" ) . onClick ( ( evt2 ) => {
this . dnShowPreviewFile ( evt2 , file ) ;
} )
) ;
this . _DN _CTX _MENU . addSeparator ( ) ;
this . _DN _CTX _MENU . addItem (
( item ) => item . setTitle ( "Frontmatter" ) . setIcon ( "text" ) . onClick ( ( ) => {
const fpModal = new import _obsidian2 . Modal ( this . app ) ;
fpModal . contentEl . setAttribute ( "class" , "dn-frontmatter-modal" ) ;
fpModal . contentEl . createEl ( "h4" , { text : "Frontmatter" } ) ;
const rowName = fpModal . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowName . createEl ( "div" , { text : "Name: " , cls : "dn-property-name-sm" } ) ;
rowName . createEl ( "div" , { text : file . name , cls : "dn-property-value" } ) ;
const rowPath = fpModal . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowPath . createEl ( "div" , { text : "Path: " , cls : "dn-property-name-sm" } ) ;
rowPath . createEl ( "div" , { text : getFolderStructure ( file . path ) , cls : "dn-property-value" } ) ;
fpModal . contentEl . createEl ( "br" ) ;
fpModal . contentEl . createEl ( "span" , { text : "Frontmatter: " , cls : "dn-properties" } ) ;
fpModal . contentEl . createEl ( "br" ) ;
const frontmatterDiv = fpModal . contentEl . createEl ( "div" , { cls : "dn-properties-frontmatter-modal" } ) ;
frontmatterDiv . setAttribute ( "contenteditable" , "true" ) ;
frontmatterDiv . setAttribute ( "spellcheck" , "false" ) ;
const curProps = getPropsPerFile ( file ) ;
if ( curProps ) {
const prop = curProps . split ( " \n" ) ;
for ( let i = 0 , len = prop . length ; i < len ; i ++ ) {
frontmatterDiv . createEl ( "a" , { text : prop [ i ] , cls : "dn-fproperties" } ) . onClickEvent ( ( evt2 ) => {
if ( evt2 . button === 2 ) {
evt2 . preventDefault ( ) ;
} else {
fpModal . close ( ) ;
this . _INPUT _SEARCH . value = prop [ i ] ;
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
}
} ) ;
frontmatterDiv . createEl ( "br" ) ;
}
} else {
frontmatterDiv . createEl ( "span" , { text : "No frontmatter" } ) ;
}
fpModal . contentEl . createEl ( "br" ) ;
const divBottom = fpModal . contentEl . createEl ( "div" , { cls : "dn-div-bottom-properties" } ) ;
const btnPropsOpen = divBottom . createEl ( "button" , { text : "Open" , cls : "dn-btn-properties-open-file" } ) ;
btnPropsOpen . onClickEvent ( ( ) => {
fpModal . close ( ) ;
this . dnOpenFile ( file ) ;
} ) ;
const btnCloseProps = divBottom . createEl ( "button" , { text : "Close" , cls : "dn-btn-properties-close" } ) ;
btnCloseProps . onClickEvent ( ( ) => {
fpModal . close ( ) ;
} ) ;
fpModal . open ( ) ;
frontmatterDiv . blur ( ) ;
} )
) ;
2024-09-14 15:25:13 +00:00
this . _DN _CTX _MENU . addItem (
( item ) => item . setTitle ( "File properties" ) . setIcon ( "file-cog" ) . onClick ( ( ) => {
const mdFileProps = new import _obsidian2 . Modal ( this . app ) ;
2024-11-22 15:53:13 +00:00
mdFileProps . contentEl . setAttribute ( "class" , "dn-properties-modal" ) ;
mdFileProps . contentEl . createEl ( "h4" , { text : "File properties" } ) ;
const rowName = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowName . createEl ( "div" , { text : "Name: " , cls : "dn-property-name" } ) ;
rowName . createEl ( "div" , { text : file . name , cls : "dn-property-value" } ) ;
const rowExt = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowExt . createEl ( "div" , { text : "Extension: " , cls : "dn-property-name" } ) ;
const rowExtValue = rowExt . createEl ( "div" , { cls : "dn-property-value" } ) ;
rowExtValue . createEl ( "span" , { text : file . extension , cls : "nav-file-tag" } ) ;
const rowPath = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowPath . createEl ( "div" , { text : "Path: " , cls : "dn-property-name" } ) ;
rowPath . createEl ( "div" , { text : getFolderStructure ( file . path ) , cls : "dn-property-value" } ) ;
2024-09-14 15:25:13 +00:00
mdFileProps . contentEl . createEl ( "br" ) ;
2024-11-22 15:53:13 +00:00
const rowSize = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowSize . createEl ( "div" , { text : "Size: " , cls : "dn-property-name" } ) ;
rowSize . createEl ( "div" , { text : formatFileSize ( file . stat . size ) + " bytes" + formatFileSizeKBMB ( file . stat . size ) } ) ;
2024-09-14 15:25:13 +00:00
mdFileProps . contentEl . createEl ( "br" ) ;
2024-11-22 15:53:13 +00:00
const rowDateCreated = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowDateCreated . createEl ( "div" , { text : "Created: " , cls : "dn-property-name" } ) ;
rowDateCreated . createEl ( "div" , { text : ( 0 , import _obsidian3 . moment ) ( file . stat . ctime ) . format ( this . date _format ) } ) ;
const rowDateModified = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowDateModified . createEl ( "div" , { text : "Modified: " , cls : "dn-property-name" } ) ;
rowDateModified . createEl ( "div" , { text : ( 0 , import _obsidian3 . moment ) ( file . stat . mtime ) . format ( this . date _format ) } ) ;
2024-09-14 15:25:13 +00:00
mdFileProps . contentEl . createEl ( "br" ) ;
2024-11-22 15:53:13 +00:00
const rowTags = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-property-row" } ) ;
rowTags . createEl ( "div" , { text : "Tag(s): " , cls : "dn-property-name" } ) ;
const propTags = rowTags . createEl ( "div" ) ;
const curTags = getTagsPerFile ( file ) ;
2024-11-29 13:32:34 +00:00
if ( curTags !== "" ) {
2024-09-14 15:25:13 +00:00
const tags = curTags . split ( " " ) ;
for ( let i = 0 , len = tags . length ; i < len ; i ++ ) {
2024-11-29 13:32:34 +00:00
propTags . createEl ( "a" , { text : tags [ i ] , href : tags [ i ] , cls : "tag" } ) . onClickEvent ( ( evt2 ) => {
2024-11-22 15:53:13 +00:00
if ( evt2 . button === 2 ) {
evt2 . preventDefault ( ) ;
} else {
mdFileProps . close ( ) ;
this . _INPUT _SEARCH . value = tags [ i ] ;
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
}
2024-09-14 15:25:13 +00:00
} ) ;
}
} else {
propTags . createEl ( "span" , { text : "No tags" } ) ;
}
mdFileProps . contentEl . createEl ( "br" ) ;
2024-11-22 15:53:13 +00:00
mdFileProps . contentEl . createEl ( "span" , { text : "Frontmatter: " , cls : "dn-properties" } ) ;
mdFileProps . contentEl . createEl ( "br" ) ;
const frontmatterProps = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-properties-frontmatter" } ) ;
frontmatterProps . setAttribute ( "contenteditable" , "true" ) ;
frontmatterProps . setAttribute ( "spellcheck" , "false" ) ;
const curProps = getPropsPerFile ( file ) ;
if ( curProps ) {
const prop = curProps . split ( " \n" ) ;
for ( let i = 0 , len = prop . length ; i < len ; i ++ ) {
frontmatterProps . createEl ( "a" , { text : prop [ i ] , cls : "dn-fproperties" } ) . onClickEvent ( ( evt2 ) => {
if ( evt2 . button === 2 ) {
evt2 . preventDefault ( ) ;
} else {
mdFileProps . close ( ) ;
this . _INPUT _SEARCH . value = prop [ i ] ;
this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) ;
}
} ) ;
frontmatterProps . createEl ( "br" ) ;
}
} else {
frontmatterProps . createEl ( "span" , { text : "No frontmatter" } ) ;
}
mdFileProps . contentEl . createEl ( "br" ) ;
2024-09-14 15:25:13 +00:00
const divBottom = mdFileProps . contentEl . createEl ( "div" , { cls : "dn-div-bottom-properties" } ) ;
2024-11-22 15:53:13 +00:00
const btnPropsOpen = divBottom . createEl ( "button" , { text : "Open" , cls : "dn-btn-properties-open-file" } ) ;
btnPropsOpen . onClickEvent ( ( ) => {
mdFileProps . close ( ) ;
this . dnOpenFile ( file ) ;
} ) ;
const btnCloseProps = divBottom . createEl ( "button" , { text : "Close" , cls : "dn-btn-properties-close" } ) ;
2024-09-14 15:25:13 +00:00
btnCloseProps . onClickEvent ( ( ) => {
mdFileProps . close ( ) ;
} ) ;
mdFileProps . open ( ) ;
2024-11-22 15:53:13 +00:00
frontmatterProps . blur ( ) ;
2024-09-14 15:25:13 +00:00
} )
) ;
this . _DN _CTX _MENU . showAtMouseEvent ( evt ) ;
}
2024-11-22 15:53:13 +00:00
dnHandleClick ( evt , file ) {
if ( ! evt || typeof evt !== "object" || ! ( file instanceof import _obsidian2 . TFile ) ) {
return ;
}
this . dnSelectTableRow ( evt ) ;
if ( evt . button === 2 ) {
evt . preventDefault ( ) ;
this . dnGenerateContextMenu ( evt , file ) ;
}
}
dnHandleDblClick ( evt , file ) {
if ( ! evt || typeof evt !== "object" || ! ( file instanceof import _obsidian2 . TFile ) ) {
return ;
}
evt . preventDefault ( ) ;
this . dnSelectTableRow ( evt ) ;
this . dnOpenFile ( file ) ;
}
dnHandleHoverPreview ( evt , file ) {
evt . stopImmediatePropagation ( ) ;
if ( evt . ctrlKey || evt . metaKey ) {
this . dnShowPreviewFile ( evt , file ) ;
}
}
dnShowPreviewFile ( evt , file ) {
this . _hoverDiv . empty ( ) ;
const topBar = this . _hoverDiv . createEl ( "div" , { cls : "dn-preview-top-bar" } ) ;
const btnClosePreview = topBar . createEl ( "div" , { cls : "modal-close-button" } ) ;
btnClosePreview . onClickEvent ( ( evt2 ) => {
evt2 . stopPropagation ( ) ;
this . dnHidePreview ( ) ;
} ) ;
const previewTop = topBar . createEl ( "div" , "dn-preview-titlebar" ) ;
const divPreviewName = previewTop . createEl ( "div" , { cls : "dn-property-row" } ) ;
divPreviewName . createEl ( "div" , { text : "Name: " , cls : "dn-property-name-sm" } ) ;
divPreviewName . createEl ( "div" , { text : file . name , cls : "dn-property-value" } ) ;
const divPreviewPath = previewTop . createEl ( "div" , { cls : "dn-property-row" } ) ;
divPreviewPath . createEl ( "div" , { text : "Path: " , cls : "dn-property-name-sm" } ) ;
divPreviewPath . createEl ( "div" , { text : getFolderStructure ( file . path ) , cls : "dn-property-value" } ) ;
const divButtons = topBar . createEl ( "div" , { cls : "dn-div-top-preview-btns" } ) ;
const btnPreviewOpenFile = divButtons . createEl ( "button" , { text : "Open" , cls : "dn-btn-properties-open-file" } ) ;
btnPreviewOpenFile . onClickEvent ( ( ) => {
this . dnHidePreview ( ) ;
this . close ( ) ;
this . dnOpenFile ( file ) ;
} ) ;
const btnPreviewOpenFileNewTab = divButtons . createEl ( "button" , { text : "Open in new tab" , cls : "dn-btn-properties-open-file" } ) ;
btnPreviewOpenFileNewTab . onClickEvent ( ( ) => {
this . dnHidePreview ( ) ;
this . close ( ) ;
this . app . workspace . getLeaf ( "tab" ) . openFile ( file ) ;
} ) ;
const btnPreviewOpenFileNewWindow = divButtons . createEl ( "button" , { text : "Open in new window" , cls : "dn-btn-properties-open-file" } ) ;
btnPreviewOpenFileNewWindow . onClickEvent ( ( ) => {
this . dnHidePreview ( ) ;
this . app . workspace . getLeaf ( "window" ) . openFile ( file ) ;
} ) ;
this . _hoverRender = this . _hoverDiv . createEl ( "div" , { cls : "dn-pr-content" } ) ;
2024-11-29 13:32:34 +00:00
try {
import _obsidian2 . MarkdownRenderer . render (
this . app ,
"![[" + ( 0 , import _obsidian2 . normalizePath ) ( file . path ) + "]]" ,
this . _hoverRender ,
( 0 , import _obsidian2 . normalizePath ) ( file . path ) ,
this . _previewComponent
) ;
} catch ( error ) {
return ;
}
this . _hoverDiv . style . display = "block" ;
2024-11-22 15:53:13 +00:00
previewTop . addEventListener ( "mousedown" , ( evt2 ) => this . dnHoverDragOnMouseDown ( evt2 ) ) ;
this . _hoverDiv . addEventListener ( "mousemove" , ( evt2 ) => this . dnHoverDragOnMouseMove ( evt2 ) ) ;
this . _hoverDiv . addEventListener ( "mouseup" , ( evt2 ) => this . dnHoverDragOnMouseUp ( evt2 ) ) ;
const screenWidth = window . innerWidth ;
const screenHeight = window . innerHeight ;
const divW = this . _hoverDiv . offsetWidth ;
const divH = this . _hoverDiv . offsetHeight ;
if ( this . _hoverDivLeft === "" ) {
this . _hoverDiv . style . left = ( ( screenWidth - divW ) / 2 ) . toString ( ) + "px" ;
this . _hoverDiv . style . top = ( ( screenHeight - divH ) / 2 ) . toString ( ) + "px" ;
}
previewTop . removeEventListener ( "mousedown" , ( evt2 ) => this . dnHoverDragOnMouseDown ( evt2 ) ) ;
}
dnHidePreview ( ) {
this . _isDraggingPreview = false ;
this . _hoverDiv . style . display = "none" ;
this . _hoverDiv . empty ( ) ;
}
dnHandleNormalSearch ( rExp , file ) {
return rExp . test ( file . name . toLowerCase ( ) ) || rExp . test ( getFolderStructure ( file . path ) . toLowerCase ( ) ) || rExp . test ( ( 0 , import _obsidian3 . moment ) ( file . stat . mtime ) . format ( this . date _format ) ) || rExp . test ( getTagsPerFile ( file ) . toLowerCase ( ) ) || rExp . test ( getPropsPerFile ( file ) . toLowerCase ( ) ) ;
}
dnHandleSpecialSearch ( search , file ) {
const mtime = ( 0 , import _obsidian3 . moment ) ( file . stat . mtime ) ;
switch ( search ) {
case "d" :
case "day" :
case "today" :
return mtime . isSame ( ( 0 , import _obsidian3 . moment ) ( ) , "day" ) ;
case "d-1" :
case "day-1" :
case "yesterday" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 1 , "days" ) , ( 0 , import _obsidian3 . moment ) ( ) , "day" , "[]" ) ;
case "d-2" :
case "day-2" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 2 , "days" ) , ( 0 , import _obsidian3 . moment ) ( ) , "day" , "[]" ) ;
case "d-3" :
case "day-3" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 3 , "days" ) , ( 0 , import _obsidian3 . moment ) ( ) , "day" , "[]" ) ;
case "d-4" :
case "day-4" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 4 , "days" ) , ( 0 , import _obsidian3 . moment ) ( ) , "day" , "[]" ) ;
case "d-5" :
case "day-5" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 5 , "days" ) , ( 0 , import _obsidian3 . moment ) ( ) , "day" , "[]" ) ;
case "d-6" :
case "day-6" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 6 , "days" ) , ( 0 , import _obsidian3 . moment ) ( ) , "day" , "[]" ) ;
case "d-7" :
case "day-7" :
case "w" :
case "week" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 7 , "days" ) , ( 0 , import _obsidian3 . moment ) ( ) , "day" , "[]" ) ;
case "m" :
case "month" :
return mtime . isSame ( ( 0 , import _obsidian3 . moment ) ( ) , "month" ) ;
case "m-1" :
case "month-1" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 1 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-2" :
case "month-2" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 2 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-3" :
case "month-3" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 3 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-4" :
case "month-4" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 4 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-5" :
case "month-5" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 5 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-6" :
case "month-6" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 6 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-7" :
case "month-7" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 7 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-8" :
case "month-8" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 8 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-9" :
case "month-9" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 9 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-10" :
case "month-10" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 10 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-11" :
case "month-11" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 11 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "m-12" :
case "month-12" :
return mtime . isBetween ( ( 0 , import _obsidian3 . moment ) ( ) . subtract ( 12 , "month" ) , ( 0 , import _obsidian3 . moment ) ( ) , "month" , "[]" ) ;
case "y" :
case "year" :
return mtime . isSame ( ( 0 , import _obsidian3 . moment ) ( ) , "year" ) ;
case "n" :
case "notes" :
return this . _notes . includes ( file ) ;
case "c" :
case "canvases" :
case "canvas" :
return this . _canvas . includes ( file ) ;
case "i" :
case "images" :
return this . _images . includes ( file ) ;
case "a" :
case "audios" :
return this . _audios . includes ( file ) ;
case "v" :
case "videos" :
return this . _videos . includes ( file ) ;
case "p" :
case "pdf" :
case "pdfs" :
return this . _pdf . includes ( file ) ;
case "o" :
case "other" :
case "others" :
return this . _other . includes ( file ) ;
default :
return false ;
}
}
dnOpenFileAlt ( f , evt ) {
if ( ! evt || typeof evt !== "object" || ! ( f instanceof import _obsidian2 . TFile ) ) {
return ;
}
try {
if ( evt . button === 0 && ( evt . ctrlKey || evt . metaKey ) ) {
this . app . workspace . getLeaf ( "tab" ) . openFile ( f ) ;
} else if ( evt . button === 1 ) {
this . app . workspace . getLeaf ( "tab" ) . openFile ( f ) ;
} else if ( evt . button === 0 ) {
this . dnOpenFile ( f ) ;
} else if ( evt . button === 2 && ! ( evt . target instanceof HTMLTableCellElement ) ) {
evt . preventDefault ( ) ;
this . dnGenerateContextMenu ( evt , f ) ;
}
} catch ( er ) {
return ;
}
}
dnOpenFile ( file ) {
this . app . workspace . getLeaf ( false ) . openFile ( file ) ;
this . close ( ) ;
}
dnHoverDragOnMouseDown ( evt ) {
evt . stopPropagation ( ) ;
this . _isDraggingPreview = true ;
this . initialX = evt . screenX - this . _hoverDiv . offsetLeft ;
this . initialY = evt . screenY - this . _hoverDiv . offsetTop ;
this . previousX = evt . screenX ;
this . previousY = evt . screenY ;
}
dnHoverDragOnMouseMove ( evt ) {
evt . stopPropagation ( ) ;
if ( this . _isDraggingPreview ) {
const newX = evt . screenX - this . initialX ;
const newY = evt . screenY - this . initialY ;
if ( Math . abs ( evt . screenX - this . previousX ) > 5 || Math . abs ( evt . screenY - this . previousY ) > 5 ) {
this . _hoverDiv . style . left = newX + "px" ;
this . _hoverDiv . style . top = newY + "px" ;
this . previousX = evt . screenX ;
this . previousY = evt . screenY ;
}
this . _hoverDivLeft = newX + "px" ;
this . _hoverDivTop = newY + "px" ;
}
}
dnHoverDragOnMouseUp ( evt ) {
evt . stopPropagation ( ) ;
this . _isDraggingPreview = false ;
}
2024-09-14 15:25:13 +00:00
onClose ( ) {
const { contentEl } = this ;
contentEl . empty ( ) ;
2024-11-22 15:53:13 +00:00
this . _previewComponent . unload ( ) ;
2024-09-14 15:25:13 +00:00
if ( this . _INPUT _SEARCH && this . _INPUT _SEARCH . removeEventListener ) {
2024-11-22 15:53:13 +00:00
this . _INPUT _SEARCH . removeEventListener ( "input" , ( 0 , import _obsidian2 . debounce ) ( ( ) => this . dnModalSearchVault ( this . _INPUT _SEARCH . value ) , 300 , true ) ) ;
2024-09-14 15:25:13 +00:00
}
this . _th1 . removeEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "name" ) ) ;
2024-11-22 15:53:13 +00:00
this . _th2 . removeEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "ext" ) ) ;
this . _th3 . removeEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "path" ) ) ;
this . _th4 . removeEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "size" ) ) ;
this . _th5 . removeEventListener ( "dblclick" , ( ) => this . dnAlternateSortColumn ( "modified" ) ) ;
2024-09-14 15:25:13 +00:00
this . _SELECT _SORT . removeEventListener ( "change" , ( ) => {
this . dnSortColumnWithSelect ( ) ;
} ) ;
2024-11-22 15:53:13 +00:00
this . _hoverDiv . removeEventListener ( "mousemove" , ( evt ) => this . dnHoverDragOnMouseMove ( evt ) ) ;
this . _hoverDiv . removeEventListener ( "mouseup" , ( evt ) => this . dnHoverDragOnMouseUp ( evt ) ) ;
2024-09-14 15:25:13 +00:00
if ( this . intersectionObserver ) {
this . intersectionObserver . disconnect ( ) ;
}
}
} ;
// src/main.ts
var DEFAULT _SETTINGS = {
default _view : 1 ,
font _size : 16 ,
selected _table _layout : "dn-tbl-default" ,
date _format : "YYYY-MM-DD HH:mm" ,
files _per _page : 20 ,
num _recent _files : 5 ,
excluded _ext : "" ,
excluded _path : "" ,
color _notes : "#bf48ff" ,
color _images : "#007fff" ,
color _canvas : "#ff7f28" ,
color _videos : "#d34848" ,
color _audios : "#bfbf00" ,
color _pdf : "#00a300" ,
color _other : "#828282" ,
2024-11-22 15:53:13 +00:00
colored _files : false ,
hide _ext : false ,
hide _path : false ,
hide _size : false ,
hide _date : false ,
hide _tags : false ,
hide _frontmatter : false ,
hide _columns : [ ]
2024-09-14 15:25:13 +00:00
} ;
var DNPlugin = class extends import _obsidian4 . Plugin {
async onload ( ) {
await this . loadSettings ( ) ;
2024-11-22 15:53:13 +00:00
this . DN _MODAL = new DNModal ( this . app ) ;
this . DN _MODAL . default _view = this . settings . default _view ;
this . DN _MODAL . date _format = this . settings . date _format ;
this . DN _MODAL . num _recent _files = this . settings . num _recent _files ;
this . DN _MODAL . files _per _page = this . settings . files _per _page ;
this . DN _MODAL . selected _table _layout = this . settings . selected _table _layout ;
this . DN _MODAL . excluded _extensions = this . dnGetExcludedExtensions ( this . settings . excluded _ext ) ;
this . DN _MODAL . excluded _folders = this . dnGetExcludedFolders ( this . settings . excluded _path ) ;
2024-09-14 15:25:13 +00:00
this . dnSetFontSize ( this . settings . font _size ) ;
2024-11-22 15:53:13 +00:00
this . DN _MODAL . colored _files = this . settings . colored _files ;
this . DN _MODAL . color _notes = this . settings . color _notes ;
this . DN _MODAL . color _canvas = this . settings . color _canvas ;
this . DN _MODAL . color _images = this . settings . color _images ;
this . DN _MODAL . color _videos = this . settings . color _videos ;
this . DN _MODAL . color _audios = this . settings . color _audios ;
this . DN _MODAL . color _pdf = this . settings . color _pdf ;
this . DN _MODAL . color _other = this . settings . color _other ;
this . DN _MODAL . hide _columns = this . dnSetHiddenColumns ( this . settings . hide _columns ) ;
2024-09-14 15:25:13 +00:00
this . addRibbonIcon ( "gauge" , "Open dashboard navigator" , ( evt ) => {
2024-11-22 15:53:13 +00:00
this . DN _MODAL . default _view = this . settings . default _view ;
this . DN _MODAL . open ( ) ;
2024-09-14 15:25:13 +00:00
} ) ;
this . addCommand ( {
id : "dashboard" ,
name : "Open dashboard" ,
callback : ( ) => {
2024-11-22 15:53:13 +00:00
this . DN _MODAL . default _view = 1 ;
this . DN _MODAL . open ( ) ;
2024-09-14 15:25:13 +00:00
}
} ) ;
this . addCommand ( {
id : "navigator" ,
name : "Open navigator" ,
callback : ( ) => {
2024-11-22 15:53:13 +00:00
this . DN _MODAL . default _view = 2 ;
this . DN _MODAL . open ( ) ;
2024-09-14 15:25:13 +00:00
}
} ) ;
this . addSettingTab ( new DNSettingTab ( this . app , this ) ) ;
}
2024-11-22 15:53:13 +00:00
dnSetFontSize ( val ) {
if ( val >= 12 || val <= 24 ) {
document . body . style . setProperty ( "--dn-font-size" , val . toString ( ) + "px" ) ;
}
}
dnSetHiddenColumns ( arrCols ) {
const allowedCols = [ "ext" , "path" , "size" , "date" , "tags" , "frontmatter" ] ;
arrCols = arrCols . filter ( ( col ) => allowedCols . includes ( col ) ) ;
if ( arrCols . length <= 6 && arrCols . some ( ( col ) => [ "ext" , "path" , "size" , "date" , "tags" , "frontmatter" ] . includes ( col ) ) ) {
return arrCols ;
} else {
this . settings . hide _columns = [ ] ;
this . settings . hide _ext = false ;
this . settings . hide _path = false ;
this . settings . hide _size = false ;
this . settings . hide _date = false ;
this . settings . hide _tags = false ;
this . settings . hide _frontmatter = false ;
this . saveSettings ( ) ;
return [ ] ;
}
}
dnUpdateHideColumn ( col , val ) {
const allowedCols = [ "ext" , "path" , "size" , "date" , "tags" , "frontmatter" ] ;
if ( allowedCols . includes ( col ) && val === true ) {
if ( ! this . settings . hide _columns . includes ( col ) ) {
this . settings . hide _columns . push ( col ) ;
this . DN _MODAL . hide _columns = this . settings . hide _columns ;
}
} else {
this . settings . hide _columns = this . settings . hide _columns . filter ( ( c ) => c !== col ) ;
this . DN _MODAL . hide _columns = this . settings . hide _columns ;
}
}
2024-09-14 15:25:13 +00:00
dnGetExcludedFolders ( foldersString ) {
if ( foldersString === "" ) {
return [ ] ;
}
const folders = foldersString . split ( "," ) . map ( ( folder ) => folder . trim ( ) ) ;
return folders . map ( ( folder ) => folder . replace ( /^\/|\/$|\.\./g , "" ) ) . filter ( ( folder ) => folder !== "" ) ;
}
dnGetExcludedExtensions ( excluded _ext ) {
if ( excluded _ext === "" ) {
return [ ] ;
}
return excluded _ext . split ( "," ) . map ( ( extension ) => extension . trim ( ) ) ;
}
onunload ( ) {
}
async loadSettings ( ) {
this . settings = Object . assign (
{ } ,
DEFAULT _SETTINGS ,
await this . loadData ( )
) ;
}
async saveSettings ( ) {
await this . saveData ( this . settings ) ;
}
} ;
2024-11-22 15:53:13 +00:00
/* nosourcemap */