Tracks.js 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. import {connect} from 'react-redux';
  2. import {actionFullSetTrack, actionFullPlay, actionFullSetPlaylist , actionAddTrackToQueue} from '../store/playerReducer';
  3. import { actionNowPlaylist, actionPlaylistById, actionArtistById} from '../store/promiseReducer';
  4. import { store } from '../store/store';
  5. import Button from 'react-bootstrap/Button';
  6. import Modal from 'react-bootstrap/Modal';
  7. import { sendForm } from './SendForm';
  8. import React, {useState} from 'react';
  9. import {FontAwesomeIcon} from "@fortawesome/react-fontawesome";
  10. import {faCheck, faPlay} from "@fortawesome/free-solid-svg-icons";
  11. import { Link } from 'react-router-dom';
  12. import { Dropdown , Form} from 'react-bootstrap';
  13. export let audio = new Audio();
  14. //! --------
  15. // // const playlists = store.getState().promise?.usersPlaylists?.payload?.playlists;
  16. // const playlistOption = (playlists = null) => {
  17. // // if (playlists) {
  18. // // console.log(playlists)
  19. // return <option value={"1"}>Add to...</option>
  20. // // }
  21. // }
  22. //! ------
  23. const ButtonDeleteTrack = (track) => {
  24. const [deletePllstModal, setDeletePllstModal] = useState(false);
  25. return (
  26. <>
  27. <Dropdown.Item onClick={() => {console.log(track); setDeletePllstModal(true)}}>Delete</Dropdown.Item>
  28. <Modal
  29. show={deletePllstModal} onHide={() => setDeletePllstModal(false)}
  30. backdrop="static" keyboard={false} track={track}>
  31. <Modal.Header closeButton>
  32. <Modal.Title className='w-100 text-center'>Delete Track?</Modal.Title>
  33. </Modal.Header>
  34. <Modal.Body className='text-center'>
  35. Are you really want to delete track <span className='text-danger'><i>"{track.track.name}" - {track.track?.id3?.artist}</i></span>?
  36. </Modal.Body>
  37. <Modal.Footer className='d-flex justify-content-center'>
  38. <Button className='mx-2' variant="secondary" onClick={() => setDeletePllstModal(false)}>
  39. Close
  40. </Button>
  41. <Button track={track} className='mx-2' variant="danger" onClick={async() => {
  42. const data = new FormData();
  43. data.append('playlistId', track.track?.pivot?.playlist_id);
  44. data.append('trackId', track.track?.pivot?.track_id);
  45. await sendForm(`playlists/remove-track`, data);
  46. setDeletePllstModal(false);
  47. setTimeout(() => store.dispatch(actionPlaylistById(track.track?.pivot?.playlist_id)), 100)
  48. }}>Delete</Button>
  49. </Modal.Footer>
  50. </Modal>
  51. </>
  52. )
  53. }
  54. const Track = ({track, playlist}) =>
  55. <tr>
  56. <td scope="row" width={30} data-id={track.id}>
  57. <div className="col">
  58. <Button variant="outline-light" className='rounded-5' title='Play' onClick={async () => {
  59. console.log(playlist.tracks, playlist?.tracks[playlist?.tracks.indexOf(track)]);
  60. playlist.tracks && store.dispatch(actionFullSetPlaylist(playlist?.tracks));
  61. playlist.tracks ? store.dispatch(actionFullSetTrack(playlist?.tracks[playlist?.tracks.indexOf(track)])) : store.dispatch(actionFullSetTrack(track))
  62. store.dispatch(actionFullPlay());
  63. }}>
  64. <FontAwesomeIcon className='' icon={faPlay}/>
  65. </Button>
  66. </div>
  67. </td>
  68. <td>
  69. <Link className="link-light" to='#'> {track.name}</Link>
  70. </td>
  71. <td onClick={() => store.dispatch(actionArtistById(track.artist_id))}>
  72. <Link className="link-light" to={`/artist/${track.artist_id}`}> {track.id3.artist}</Link>
  73. </td>
  74. <td>
  75. <Link className="link-light" to='#'> {track.id3.getAlbum}</Link>
  76. </td>
  77. <td align={"right"}>
  78. <Dropdown align={"end"}>
  79. <Dropdown.Toggle variant="outline-light" id="dropdown-basic"></Dropdown.Toggle>
  80. <Dropdown.Menu variant={"dark"}>
  81. {playlist?.user_id === store.getState().auth.user.id ? <ButtonDeleteTrack track={track} /> :
  82. <Form className="input-group d-flex">
  83. <select className="dropdown-item w-auto" id="inputGroupSelect04"
  84. aria-label="Example select with button addon">
  85. {/* {playlistOption()} */}
  86. </select>
  87. <button type={"submit"} className="btn btn-outline-secondary w-auto"><FontAwesomeIcon icon={faCheck}/></button>
  88. </Form>
  89. }
  90. <Dropdown.Item onClick={() => {
  91. store.dispatch(actionAddTrackToQueue(track))
  92. }}>Add to Queue</Dropdown.Item>
  93. </Dropdown.Menu>
  94. </Dropdown>
  95. </td>
  96. </tr>
  97. export const TracksAll = ({tracks, playlist}) =>
  98. <table className="table table-dark table-hover align-middle">
  99. <thead>
  100. <tr>
  101. <th scope="col" width={30}></th>
  102. <th scope="col">Track name</th>
  103. <th scope="col">Artist</th>
  104. <th scope="col">Album</th>
  105. <th scope='col'>Action</th>
  106. </tr>
  107. </thead>
  108. <tbody>
  109. {tracks.map((tracks, i) => <CTrack key={i} track={tracks} playlist={playlist}/>)}
  110. </tbody>
  111. </table>
  112. export const СAllTracks = connect(state => ({playlist: state.promise.plstById?.payload || {},
  113. tracks: state.promise?.plstById?.payload?.tracks || []} ), )(TracksAll);
  114. export const CTrack = connect(state => ({playlist: state.promise.plstById?.payload || {},
  115. tracks: state.promise?.plstById?.payload?.tracks || []} ), )(Track);