while Kivy file manager and KivyMD file manager exist, they lack in their functionality as listed below. Hence the existing KivyMD file manager is customised to have search and sort option to access any file quickly. This post explains the working of the modified file manager. You can download the code of the modified Kivymd file manager below
Table of Contents
Limitations of existing file managers in kivy and kivymd
- They do not remember the last opened path
- We are unable to choose multiple files from different directories
- There is no explicit indication of which files are chosen
- There is no dynamic sort option
- No search option exist in the file manager
These pain points motivated us to modify the existing file manager to have all these functionalities.
data:image/s3,"s3://crabby-images/c33ed/c33ed9e600531b4b6621f053aff08cde08cc35f7" alt="Do you need help in python app development"
Download the modified file manager
Download the modified file manager for kivyMD from this link
Existing file managers
Following images show the existing file managers in Kivyย andย KivyMD
data:image/s3,"s3://crabby-images/8ad74/8ad74b019f968ff1f10d9cf9227149177e5ddd22" alt="File manager in kivy"
data:image/s3,"s3://crabby-images/00e13/00e13c1b5a9b13ddf457b3e0f86f18adee20a312" alt="Existing File manager in kivyMD"
Modified file manager for kivyMD
Following image shows the modified file manager and its components
data:image/s3,"s3://crabby-images/58341/58341245d507c187d8b8cab53c10cd9988f54ed2" alt="Components of modified KivyMD file manager"
The modified file manager has the following components
- A tick mark indicator for selected files. This is shown in both preview or non-preview mode
- A search box to filter the files based on the search text
- A user choice to sort the files based on their name or the date of modification
- An option to sort the files in ascending order or descending order
- A reset option to clear the current selection
- Further, this file manager does not clear the current selection till the file manager is closed or the accept button is clicked
Working of the modified file manager
Following figure shows the file manager
data:image/s3,"s3://crabby-images/70c2f/70c2f73049c2cca0ed122c091d699eb08d57e301" alt="Modified kivyMD file manager displays files and folders upon selection"
Upon the first file 1.jpg is clicked, a tick mark is added to the file and the file counter in the top right is increased by 1
data:image/s3,"s3://crabby-images/d81b0/d81b07fe117c322863dbd3dcb104ccbcda2540ae" alt="Modified kivyMD file manager with one file selected"
Following figures shows the files sorted by combinations of name, date, ascending order and descending order.
data:image/s3,"s3://crabby-images/0cbae/0cbaea89bdb4d7d07d261bcf7ee588ce87b6bec5" alt="Modified kivyMD file manager with files sorted in ascending order of names"
data:image/s3,"s3://crabby-images/0e560/0e56060790765ecc35c397b363a9a6fd57ea808b" alt="Modified kivyMD file manager with files sorted in descending order of names"
data:image/s3,"s3://crabby-images/b64bd/b64bd82fc02751536b8f60e6236e8279f79d579b" alt="Modified kivyMD file manager with files sorted in ascending order of date modified"
data:image/s3,"s3://crabby-images/aa4cb/aa4cb33d8bb8b64314c22bca0dad9259f45a136a" alt="Modified kivyMD file manager with files sorted in descending order of date modified"
When the current count (top right) is clicked, all the current selection is cleared and the tick marks are removed and the counter is set to zero.
data:image/s3,"s3://crabby-images/d2667/d2667a28344532682969924bec1f55c3ef4d40dd" alt="Modified kivyMD file manager with current selection cleared"
When the text 4 is used to search as shown in the image below, the files and folders are filtered based on this text.
data:image/s3,"s3://crabby-images/c4e23/c4e23f8fbf748665049be01393653922a3cc00c0" alt="Modified kivyMD file manager with files filtered based on search text"
Multiple words can also be used for the search. For example, the text “4 bw” is used to filter the image “4 next bw.jpg” as shown in the image below
data:image/s3,"s3://crabby-images/555f5/555f5f9cda7396afcab1455c5e8dc66c31f68b08" alt="Modified kivyMD file manager with files filtered based on multiple search text"