mirror of
https://github.com/anas-elgarhy/Ayah-intellij.git
synced 2024-08-15 00:43:43 +00:00
Merge pull request #61 from anas-elgarhy/update-the-details-dialog
Add the tafseer/translation text box to the ayah details dialog and make the user able to change the player edition on the fly
This commit is contained in:
commit
1cac0188fc
2 changed files with 166 additions and 23 deletions
|
@ -3,7 +3,7 @@
|
||||||
<grid id="cbd77" binding="contentPane" layout-manager="GridLayoutManager" row-count="2" column-count="3" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
<grid id="cbd77" binding="contentPane" layout-manager="GridLayoutManager" row-count="2" column-count="3" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
||||||
<margin top="10" left="10" bottom="10" right="10"/>
|
<margin top="10" left="10" bottom="10" right="10"/>
|
||||||
<constraints>
|
<constraints>
|
||||||
<xy x="48" y="54" width="577" height="355"/>
|
<xy x="48" y="54" width="836" height="472"/>
|
||||||
</constraints>
|
</constraints>
|
||||||
<properties>
|
<properties>
|
||||||
<maximumSize width="500" height="300"/>
|
<maximumSize width="500" height="300"/>
|
||||||
|
@ -18,7 +18,7 @@
|
||||||
<properties/>
|
<properties/>
|
||||||
<border type="none"/>
|
<border type="none"/>
|
||||||
<children>
|
<children>
|
||||||
<grid id="9538f" layout-manager="GridLayoutManager" row-count="2" column-count="4" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
<grid id="9538f" layout-manager="GridLayoutManager" row-count="3" column-count="4" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
||||||
<margin top="0" left="0" bottom="0" right="0"/>
|
<margin top="0" left="0" bottom="0" right="0"/>
|
||||||
<constraints>
|
<constraints>
|
||||||
<grid row="0" column="0" row-span="1" col-span="6" vsize-policy="3" hsize-policy="3" anchor="0" fill="3" indent="0" use-parent-layout="false"/>
|
<grid row="0" column="0" row-span="1" col-span="6" vsize-policy="3" hsize-policy="3" anchor="0" fill="3" indent="0" use-parent-layout="false"/>
|
||||||
|
@ -60,25 +60,77 @@
|
||||||
</component>
|
</component>
|
||||||
</children>
|
</children>
|
||||||
</grid>
|
</grid>
|
||||||
<component id="69418" class="javax.swing.JButton" binding="previousButton">
|
<grid id="e3ffd" layout-manager="GridBagLayout">
|
||||||
<constraints>
|
<constraints>
|
||||||
<grid row="1" column="2" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
<grid row="1" column="0" row-span="1" col-span="4" vsize-policy="3" hsize-policy="3" anchor="0" fill="3" indent="0" use-parent-layout="true"/>
|
||||||
</constraints>
|
</constraints>
|
||||||
<properties>
|
<properties/>
|
||||||
<text value="Previous"/>
|
<border type="none"/>
|
||||||
<toolTipText value="Previous Aah"/>
|
<children>
|
||||||
</properties>
|
<component id="c14dc" class="javax.swing.JLabel">
|
||||||
</component>
|
<constraints>
|
||||||
<component id="b465c" class="javax.swing.JButton" binding="nextButton" default-binding="true">
|
<grid row="0" column="0" row-span="1" col-span="1" vsize-policy="0" hsize-policy="0" anchor="8" fill="0" indent="0" use-parent-layout="false"/>
|
||||||
|
<gridbag weightx="0.0" weighty="1.0"/>
|
||||||
|
</constraints>
|
||||||
|
<properties>
|
||||||
|
<text value="Tafseer/Translation"/>
|
||||||
|
<verifyInputWhenFocusTarget value="false"/>
|
||||||
|
</properties>
|
||||||
|
</component>
|
||||||
|
<component id="1bfe0" class="javax.swing.JComboBox" binding="tafseerAndTranslationComboBox">
|
||||||
|
<constraints>
|
||||||
|
<grid row="0" column="1" row-span="1" col-span="1" vsize-policy="0" hsize-policy="2" anchor="8" fill="1" indent="0" use-parent-layout="false"/>
|
||||||
|
<gridbag weightx="1.0" weighty="1.0"/>
|
||||||
|
</constraints>
|
||||||
|
<properties/>
|
||||||
|
</component>
|
||||||
|
<component id="82c3f" class="javax.swing.JLabel">
|
||||||
|
<constraints>
|
||||||
|
<grid row="0" column="2" row-span="1" col-span="1" vsize-policy="0" hsize-policy="0" anchor="8" fill="0" indent="0" use-parent-layout="false"/>
|
||||||
|
<gridbag weightx="0.0" weighty="1.0"/>
|
||||||
|
</constraints>
|
||||||
|
<properties>
|
||||||
|
<text value="Edition"/>
|
||||||
|
</properties>
|
||||||
|
</component>
|
||||||
|
<component id="3ac9d" class="javax.swing.JComboBox" binding="editionComboBox">
|
||||||
|
<constraints>
|
||||||
|
<grid row="0" column="3" row-span="1" col-span="1" vsize-policy="0" hsize-policy="2" anchor="8" fill="1" indent="0" use-parent-layout="false"/>
|
||||||
|
<gridbag weightx="1.0" weighty="1.0"/>
|
||||||
|
</constraints>
|
||||||
|
<properties/>
|
||||||
|
</component>
|
||||||
|
</children>
|
||||||
|
</grid>
|
||||||
|
<grid id="d5ada" layout-manager="GridLayoutManager" row-count="1" column-count="2" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
||||||
|
<margin top="0" left="0" bottom="0" right="0"/>
|
||||||
<constraints>
|
<constraints>
|
||||||
<grid row="1" column="0" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
<grid row="2" column="0" row-span="1" col-span="4" vsize-policy="3" hsize-policy="3" anchor="0" fill="3" indent="0" use-parent-layout="false"/>
|
||||||
</constraints>
|
</constraints>
|
||||||
<properties>
|
<properties/>
|
||||||
<hideActionText value="true"/>
|
<border type="none"/>
|
||||||
<text value="Next"/>
|
<children>
|
||||||
<toolTipText value="Nexit ayah"/>
|
<component id="b465c" class="javax.swing.JButton" binding="nextButton" default-binding="true">
|
||||||
</properties>
|
<constraints>
|
||||||
</component>
|
<grid row="0" column="0" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
||||||
|
</constraints>
|
||||||
|
<properties>
|
||||||
|
<hideActionText value="true"/>
|
||||||
|
<text value="Next"/>
|
||||||
|
<toolTipText value="Nexit ayah"/>
|
||||||
|
</properties>
|
||||||
|
</component>
|
||||||
|
<component id="69418" class="javax.swing.JButton" binding="previousButton">
|
||||||
|
<constraints>
|
||||||
|
<grid row="0" column="1" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
||||||
|
</constraints>
|
||||||
|
<properties>
|
||||||
|
<text value="Previous"/>
|
||||||
|
<toolTipText value="Previous Aah"/>
|
||||||
|
</properties>
|
||||||
|
</component>
|
||||||
|
</children>
|
||||||
|
</grid>
|
||||||
</children>
|
</children>
|
||||||
</grid>
|
</grid>
|
||||||
<component id="893ab" class="javax.swing.JCheckBox" binding="autoPlayCheckBox" default-binding="true">
|
<component id="893ab" class="javax.swing.JCheckBox" binding="autoPlayCheckBox" default-binding="true">
|
||||||
|
@ -107,7 +159,7 @@
|
||||||
</component>
|
</component>
|
||||||
</children>
|
</children>
|
||||||
</grid>
|
</grid>
|
||||||
<grid id="e3588" layout-manager="GridLayoutManager" row-count="2" column-count="1" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
<grid id="e3588" layout-manager="GridLayoutManager" row-count="3" column-count="1" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
||||||
<margin top="0" left="0" bottom="0" right="0"/>
|
<margin top="0" left="0" bottom="0" right="0"/>
|
||||||
<constraints>
|
<constraints>
|
||||||
<grid row="0" column="0" row-span="1" col-span="3" vsize-policy="3" hsize-policy="3" anchor="0" fill="3" indent="0" use-parent-layout="false"/>
|
<grid row="0" column="0" row-span="1" col-span="3" vsize-policy="3" hsize-policy="3" anchor="0" fill="3" indent="0" use-parent-layout="false"/>
|
||||||
|
@ -137,6 +189,25 @@
|
||||||
</component>
|
</component>
|
||||||
</children>
|
</children>
|
||||||
</scrollpane>
|
</scrollpane>
|
||||||
|
<scrollpane id="6058b">
|
||||||
|
<constraints>
|
||||||
|
<grid row="2" column="0" row-span="1" col-span="1" vsize-policy="7" hsize-policy="7" anchor="0" fill="3" indent="0" use-parent-layout="false"/>
|
||||||
|
</constraints>
|
||||||
|
<properties/>
|
||||||
|
<border type="none"/>
|
||||||
|
<children>
|
||||||
|
<component id="db36" class="javax.swing.JTextArea" binding="tafseerTextArea">
|
||||||
|
<constraints/>
|
||||||
|
<properties>
|
||||||
|
<editable value="false"/>
|
||||||
|
<focusable value="false"/>
|
||||||
|
<lineWrap value="true"/>
|
||||||
|
<preferredSize width="549" height="18"/>
|
||||||
|
<wrapStyleWord value="true"/>
|
||||||
|
</properties>
|
||||||
|
</component>
|
||||||
|
</children>
|
||||||
|
</scrollpane>
|
||||||
</children>
|
</children>
|
||||||
</grid>
|
</grid>
|
||||||
</children>
|
</children>
|
||||||
|
|
|
@ -2,15 +2,19 @@ package com.anas.intellij.plugins.ayah.dialogs;
|
||||||
|
|
||||||
import com.anas.alqurancloudapi.Ayah;
|
import com.anas.alqurancloudapi.Ayah;
|
||||||
import com.anas.alqurancloudapi.consts.Constants;
|
import com.anas.alqurancloudapi.consts.Constants;
|
||||||
|
import com.anas.alqurancloudapi.edition.Edition;
|
||||||
|
import com.anas.alqurancloudapi.edition.EditionFormat;
|
||||||
import com.anas.intellij.plugins.ayah.audio.AudioPlayer;
|
import com.anas.intellij.plugins.ayah.audio.AudioPlayer;
|
||||||
import com.anas.intellij.plugins.ayah.audio.PlayerListener;
|
import com.anas.intellij.plugins.ayah.audio.PlayerListener;
|
||||||
import javazoom.jl.player.advanced.PlaybackEvent;
|
import com.anas.intellij.plugins.ayah.settings.userinterface.ReadableEdition;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import java.awt.event.KeyEvent;
|
import java.awt.event.KeyEvent;
|
||||||
import java.awt.event.WindowAdapter;
|
import java.awt.event.WindowAdapter;
|
||||||
import java.awt.event.WindowEvent;
|
import java.awt.event.WindowEvent;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author <a href="https://github.com/anas-elgarhy">Anas Elgarhy</a>
|
* @author <a href="https://github.com/anas-elgarhy">Anas Elgarhy</a>
|
||||||
|
@ -28,6 +32,9 @@ public class AyahDetailsDialog extends JDialog implements PlayerListener {
|
||||||
private JButton previousButton;
|
private JButton previousButton;
|
||||||
private JButton nextButton;
|
private JButton nextButton;
|
||||||
private JCheckBox autoPlayCheckBox;
|
private JCheckBox autoPlayCheckBox;
|
||||||
|
private JTextArea tafseerTextArea;
|
||||||
|
private JComboBox<ReadableEdition> tafseerAndTranslationComboBox;
|
||||||
|
private JComboBox<ReadableEdition> editionComboBox;
|
||||||
private boolean isPlaying;
|
private boolean isPlaying;
|
||||||
private AudioPlayer audioPlayer;
|
private AudioPlayer audioPlayer;
|
||||||
private Ayah ayah;
|
private Ayah ayah;
|
||||||
|
@ -37,21 +44,55 @@ public class AyahDetailsDialog extends JDialog implements PlayerListener {
|
||||||
|
|
||||||
setContentPane(contentPane);
|
setContentPane(contentPane);
|
||||||
setModal(true);
|
setModal(true);
|
||||||
setSize(500, 300);
|
setSize(520, 320);
|
||||||
setResizable(false);
|
setResizable(false);
|
||||||
setLocationRelativeTo(null);
|
setLocationRelativeTo(null);
|
||||||
getRootPane().setDefaultButton(playButton);
|
getRootPane().setDefaultButton(playButton);
|
||||||
|
|
||||||
updateAhaDetails();
|
try {
|
||||||
|
setupTheUI();
|
||||||
|
} catch (final IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
JOptionPane.showMessageDialog(this, "Error while loading the ayah details",
|
||||||
|
"Error", JOptionPane.ERROR_MESSAGE);
|
||||||
|
}
|
||||||
|
|
||||||
addListeners();
|
addListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateAhaDetails() {
|
private void setupTheUI() throws IOException {
|
||||||
|
previousButton.setEnabled(ayah.getNumber() != 1 && ayah.getSurah().getNumber() != 1);
|
||||||
|
nextButton.setEnabled(ayah.getNumber() != Constants.AYAHS_COUNT && ayah.getSurah().getNumber() != Constants.SURAS_COUNT);
|
||||||
|
|
||||||
|
|
||||||
|
final var tafserAndTranslationComboBoxModel = new DefaultComboBoxModel<ReadableEdition>();
|
||||||
|
final var editionComboBoxModel = new DefaultComboBoxModel<ReadableEdition>();
|
||||||
|
|
||||||
|
Arrays.stream(Edition.getEditions()).forEach(edition -> {
|
||||||
|
if (edition.getFormat() == EditionFormat.AUDIO) {
|
||||||
|
editionComboBoxModel.addElement(new ReadableEdition(edition));
|
||||||
|
} else {
|
||||||
|
tafserAndTranslationComboBoxModel.addElement(new ReadableEdition(edition));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
tafseerAndTranslationComboBox.setModel(tafserAndTranslationComboBoxModel);
|
||||||
|
editionComboBox.setModel(editionComboBoxModel);
|
||||||
|
|
||||||
|
// Set the default selected item for the editionComboBox
|
||||||
|
editionComboBoxModel.setSelectedItem(new ReadableEdition(ayah.getEdition()));
|
||||||
|
// Set the actual information about the ayah in the UI
|
||||||
|
updateAyahDetails();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateAyahDetails() {
|
||||||
|
// Update the ayah details
|
||||||
ayahTextArea.setText(ayah.getText());
|
ayahTextArea.setText(ayah.getText());
|
||||||
surahNameLabel.setText(ayah.getSurah().getName());
|
surahNameLabel.setText(ayah.getSurah().getName());
|
||||||
numberOfAyahInSuarhLabel.setText("آية رقم: " + ayah.getNumberInSurah());
|
numberOfAyahInSuarhLabel.setText("آية رقم: " + ayah.getNumberInSurah());
|
||||||
ayahRevelationType.setText(ayah.getSurah().getRevelationType().getArabicName());
|
ayahRevelationType.setText(ayah.getSurah().getRevelationType().getArabicName());
|
||||||
|
// Update the tafseer or translation
|
||||||
|
updateTheTauseerTextArea();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addListeners() {
|
private void addListeners() {
|
||||||
|
@ -92,6 +133,24 @@ public class AyahDetailsDialog extends JDialog implements PlayerListener {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
tafseerAndTranslationComboBox.addActionListener(e -> {
|
||||||
|
updateTheTauseerTextArea();
|
||||||
|
});
|
||||||
|
|
||||||
|
editionComboBox.addActionListener(e -> {
|
||||||
|
final var selectedEdition = ((ReadableEdition) Objects.requireNonNull(
|
||||||
|
editionComboBox.getSelectedItem())).getEdition();
|
||||||
|
try {
|
||||||
|
ayah = Ayah.getAyah(ayah.getNumber(), selectedEdition);
|
||||||
|
updateAyahDetails();
|
||||||
|
} catch (final IOException ioException) {
|
||||||
|
ioException.printStackTrace();
|
||||||
|
JOptionPane.showMessageDialog(this,
|
||||||
|
"Error while loading the ayah - check your internet connection",
|
||||||
|
"Error", JOptionPane.ERROR_MESSAGE);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
buttonCancel.addActionListener(l -> close());
|
buttonCancel.addActionListener(l -> close());
|
||||||
|
|
||||||
// call onCancel() when cross is clicked
|
// call onCancel() when cross is clicked
|
||||||
|
@ -108,6 +167,19 @@ public class AyahDetailsDialog extends JDialog implements PlayerListener {
|
||||||
JComponent.WHEN_ANCESTOR_OF_FOCUSED_COMPONENT);
|
JComponent.WHEN_ANCESTOR_OF_FOCUSED_COMPONENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updateTheTauseerTextArea() {
|
||||||
|
final var selectedEdition = ((ReadableEdition) Objects.requireNonNull(
|
||||||
|
tafseerAndTranslationComboBox.getSelectedItem())).getEdition();
|
||||||
|
try {
|
||||||
|
tafseerTextArea.setText(Ayah.getAyah(ayah.getNumber(), selectedEdition).getText());
|
||||||
|
} catch (final IOException ioException) {
|
||||||
|
ioException.printStackTrace();
|
||||||
|
JOptionPane.showMessageDialog(this,
|
||||||
|
"Error while loading the tafseer - check your internet connection",
|
||||||
|
"Error", JOptionPane.ERROR_MESSAGE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void close() {
|
private void close() {
|
||||||
if (audioPlayer != null) {
|
if (audioPlayer != null) {
|
||||||
audioPlayer.stop();
|
audioPlayer.stop();
|
||||||
|
@ -132,7 +204,7 @@ public class AyahDetailsDialog extends JDialog implements PlayerListener {
|
||||||
try {
|
try {
|
||||||
ayah = Ayah.getAyah(ayhNumber,
|
ayah = Ayah.getAyah(ayhNumber,
|
||||||
ayah.getEdition().getIdentifier());
|
ayah.getEdition().getIdentifier());
|
||||||
updateAhaDetails();
|
updateAyahDetails();
|
||||||
return true;
|
return true;
|
||||||
} catch (final IOException ex) {
|
} catch (final IOException ex) {
|
||||||
JOptionPane.showMessageDialog(this,
|
JOptionPane.showMessageDialog(this,
|
||||||
|
|
Loading…
Reference in a new issue