mirror of
https://github.com/SimpleMobileTools/Simple-Notes.git
synced 2025-06-05 17:00:23 +02:00
add some renaming related stuff
This commit is contained in:
@@ -32,7 +32,7 @@ android {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile 'com.simplemobiletools:commons:2.9.3'
|
compile 'com.simplemobiletools:commons:2.9.4'
|
||||||
compile 'com.facebook.stetho:stetho:1.4.1'
|
compile 'com.facebook.stetho:stetho:1.4.1'
|
||||||
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
||||||
}
|
}
|
||||||
|
@@ -102,6 +102,7 @@ class MainActivity : SimpleActivity(), ViewPager.OnPageChangeListener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
||||||
|
saveCurrentNote()
|
||||||
when (item.itemId) {
|
when (item.itemId) {
|
||||||
R.id.open_note -> displayOpenNoteDialog()
|
R.id.open_note -> displayOpenNoteDialog()
|
||||||
R.id.new_note -> displayNewNoteDialog()
|
R.id.new_note -> displayNewNoteDialog()
|
||||||
@@ -231,6 +232,8 @@ class MainActivity : SimpleActivity(), ViewPager.OnPageChangeListener {
|
|||||||
|
|
||||||
private fun getCurrentNoteText() = (view_pager.adapter as NotesPagerAdapter).getCurrentNoteViewText(view_pager.currentItem)
|
private fun getCurrentNoteText() = (view_pager.adapter as NotesPagerAdapter).getCurrentNoteViewText(view_pager.currentItem)
|
||||||
|
|
||||||
|
private fun saveCurrentNote() = (view_pager.adapter as NotesPagerAdapter).saveCurrentNote(view_pager.currentItem)
|
||||||
|
|
||||||
private fun displayDeleteNotePrompt() {
|
private fun displayDeleteNotePrompt() {
|
||||||
val message = String.format(getString(R.string.delete_note_prompt_message), mCurrentNote.title)
|
val message = String.format(getString(R.string.delete_note_prompt_message), mCurrentNote.title)
|
||||||
ConfirmationDialog(this, message) {
|
ConfirmationDialog(this, message) {
|
||||||
|
@@ -32,5 +32,7 @@ class NotesPagerAdapter(fm: FragmentManager, private val notes: List<Note>) : Fr
|
|||||||
|
|
||||||
fun getCurrentNoteViewText(position: Int) = fragments[position].getCurrentNoteViewText()
|
fun getCurrentNoteViewText(position: Int) = fragments[position].getCurrentNoteViewText()
|
||||||
|
|
||||||
|
fun saveCurrentNote(position: Int) = fragments[position].saveText()
|
||||||
|
|
||||||
fun showKeyboard(position: Int) = fragments[position]?.showKeyboard()
|
fun showKeyboard(position: Int) = fragments[position]?.showKeyboard()
|
||||||
}
|
}
|
||||||
|
@@ -1,18 +1,19 @@
|
|||||||
package com.simplemobiletools.notes.dialogs
|
package com.simplemobiletools.notes.dialogs
|
||||||
|
|
||||||
import android.app.Activity
|
|
||||||
import android.content.DialogInterface.BUTTON_POSITIVE
|
import android.content.DialogInterface.BUTTON_POSITIVE
|
||||||
|
import android.provider.DocumentsContract
|
||||||
import android.support.v7.app.AlertDialog
|
import android.support.v7.app.AlertDialog
|
||||||
import android.view.WindowManager
|
import android.view.WindowManager
|
||||||
import com.simplemobiletools.commons.extensions.setupDialogStuff
|
import com.simplemobiletools.commons.extensions.*
|
||||||
import com.simplemobiletools.commons.extensions.toast
|
|
||||||
import com.simplemobiletools.commons.extensions.value
|
|
||||||
import com.simplemobiletools.notes.R
|
import com.simplemobiletools.notes.R
|
||||||
|
import com.simplemobiletools.notes.activities.SimpleActivity
|
||||||
|
import com.simplemobiletools.notes.extensions.config
|
||||||
import com.simplemobiletools.notes.helpers.DBHelper
|
import com.simplemobiletools.notes.helpers.DBHelper
|
||||||
import com.simplemobiletools.notes.models.Note
|
import com.simplemobiletools.notes.models.Note
|
||||||
import kotlinx.android.synthetic.main.new_note.view.*
|
import kotlinx.android.synthetic.main.new_note.view.*
|
||||||
|
import java.io.File
|
||||||
|
|
||||||
class RenameNoteDialog(val activity: Activity, val db: DBHelper, val note: Note, callback: (note: Note) -> Unit) {
|
class RenameNoteDialog(val activity: SimpleActivity, val db: DBHelper, val note: Note, callback: (note: Note) -> Unit) {
|
||||||
|
|
||||||
init {
|
init {
|
||||||
val view = activity.layoutInflater.inflate(R.layout.rename_note, null)
|
val view = activity.layoutInflater.inflate(R.layout.rename_note, null)
|
||||||
@@ -32,6 +33,37 @@ class RenameNoteDialog(val activity: Activity, val db: DBHelper, val note: Note,
|
|||||||
activity.toast(R.string.title_taken)
|
activity.toast(R.string.title_taken)
|
||||||
} else {
|
} else {
|
||||||
note.title = title
|
note.title = title
|
||||||
|
val path = note.path
|
||||||
|
if (path.isNotEmpty()) {
|
||||||
|
if (title.isEmpty()) {
|
||||||
|
context.toast(R.string.filename_cannot_be_empty)
|
||||||
|
return@setOnClickListener
|
||||||
|
}
|
||||||
|
|
||||||
|
val file = File(path)
|
||||||
|
val newFile = File(file.parent, title)
|
||||||
|
if (!newFile.name.isAValidFilename()) {
|
||||||
|
context.toast(R.string.invalid_name)
|
||||||
|
return@setOnClickListener
|
||||||
|
}
|
||||||
|
|
||||||
|
if (context.needsStupidWritePermissions(newFile.absolutePath)) {
|
||||||
|
if (activity.isShowingPermDialog(file))
|
||||||
|
return@setOnClickListener
|
||||||
|
|
||||||
|
var document = context.getFastDocument(file)
|
||||||
|
if (document?.isFile == false) {
|
||||||
|
document = context.getFileDocument(file.absolutePath, context.config.treeUri)
|
||||||
|
}
|
||||||
|
|
||||||
|
DocumentsContract.renameDocument(context.contentResolver, document!!.uri, newFile.name)
|
||||||
|
} else if (!file.renameTo(newFile)) {
|
||||||
|
activity.toast(R.string.rename_file_error)
|
||||||
|
return@setOnClickListener
|
||||||
|
}
|
||||||
|
note.path = newFile.absolutePath
|
||||||
|
db.updateNotePath(note)
|
||||||
|
}
|
||||||
db.updateNoteTitle(note)
|
db.updateNoteTitle(note)
|
||||||
dismiss()
|
dismiss()
|
||||||
callback.invoke(note)
|
callback.invoke(note)
|
||||||
|
@@ -59,6 +59,9 @@ class NoteFragment : Fragment() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fun saveText() {
|
fun saveText() {
|
||||||
|
if (note.path.isNotEmpty() && !File(note.path).exists())
|
||||||
|
return
|
||||||
|
|
||||||
val newText = getCurrentNoteViewText()
|
val newText = getCurrentNoteViewText()
|
||||||
val oldText = getNoteStoredValue()
|
val oldText = getNoteStoredValue()
|
||||||
if (newText != oldText) {
|
if (newText != oldText) {
|
||||||
|
@@ -1,3 +1,3 @@
|
|||||||
package com.simplemobiletools.notes.models
|
package com.simplemobiletools.notes.models
|
||||||
|
|
||||||
data class Note(var id: Int, var title: String, var value: String, val type: Int, val path: String = "")
|
data class Note(var id: Int, var title: String, var value: String, val type: Int, var path: String = "")
|
||||||
|
Reference in New Issue
Block a user