User.jsx 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. import React from 'react';
  2. import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
  3. import Container from '../ControlPanel/Container/Container';
  4. import ListItem from '../ControlPanel/ListItem/ListItem';
  5. import { useSelector } from 'react-redux';
  6. import { Link } from 'react-router-dom';
  7. import './User.scss';
  8. const User = ({ data, toggleFav, handleModal, checkItem, logOut, logInAs }) => {
  9. const { i18n, userName } = useSelector(state => state.session);
  10. const printNameServers = servers => {
  11. let serversArray = servers.split(',');
  12. return serversArray.map(
  13. (server, index) => <div key={index}>{server}</div>
  14. );
  15. }
  16. const printLoginActionButton = user => {
  17. let currentUser = userName;
  18. if (currentUser === user) {
  19. return (
  20. <div>
  21. <button onClick={logOut}>{i18n['Log out']}
  22. {data.FOCUSED ? <span className="shortcut-button">L</span> : <FontAwesomeIcon icon="user-lock" />}
  23. </button>
  24. </div>
  25. );
  26. } else {
  27. return (
  28. <div>
  29. <button onClick={() => logInAs(user)}>{i18n['login as']} {user}
  30. {data.FOCUSED ? <span className="shortcut-button">L</span> : <FontAwesomeIcon icon="user-lock" />}
  31. </button>
  32. </div>
  33. );
  34. }
  35. }
  36. const toggleFavorite = (starred) => {
  37. if (starred) {
  38. toggleFav(data.NAME, 'add');
  39. } else {
  40. toggleFav(data.NAME, 'delete');
  41. }
  42. }
  43. const checkItemName = () => {
  44. checkItem(data.NAME);
  45. }
  46. const handleSuspend = () => {
  47. let suspendedStatus = data.SUSPENDED === 'yes' ? 'unsuspend' : 'suspend';
  48. handleModal(data.spnd_conf, `/api/v1/${suspendedStatus}/user/index.php?user=${data.NAME}`);
  49. }
  50. const handleDelete = () => {
  51. handleModal(data.delete_conf, `/api/v1/delete/user/index.php?user=${data.NAME}`);
  52. }
  53. return (
  54. <ListItem
  55. id={data.NAME}
  56. date={data.DATE}
  57. checked={data.isChecked}
  58. starred={data.STARRED}
  59. toggleFav={toggleFavorite}
  60. checkItem={checkItemName}
  61. focused={data.FOCUSED}
  62. suspended={data.SUSPENDED === 'yes'}>
  63. <Container className="r-col w-85">
  64. <div className="name">{data.NAME}</div>
  65. <div>{data.FNAME} {data.LNAME}</div>
  66. <div className="stats">
  67. <Container className="c-1">
  68. <div className="bandwidth">
  69. {i18n.Bandwidth}
  70. <span><span className="stat">{data.U_BANDWIDTH}</span> {data.U_BANDWIDTH_MEASURE}</span>
  71. <div className="percent" style={{ width: `${data.U_BANDWIDTH_PERCENT}%` || '0%' }}></div>
  72. </div>
  73. <div className="disk">
  74. {i18n.Disk}: <span><span className="stat">{data.U_DISK}</span> {data.U_DISK_MEASURE}</span>
  75. <div className="percent" style={{ width: `${data.U_DISK_PERCENT}%` || '0%' }}></div>
  76. </div>
  77. <div className="sub-disk-stats">
  78. <div>
  79. <div><span>{i18n.Web}:</span> <span><b>{data.U_DISK_WEB}</b> {data.U_DISK_WEB_MEASURE}</span></div>
  80. <div><span>{i18n.Mail}:</span> <span><b>{data.U_DISK_MAIL}</b> {data.U_DISK_MAIL_MEASURE}</span></div>
  81. </div>
  82. <div>
  83. <div><span>{i18n.Databases}:</span> <span><b>{data.U_DATABASES}</b> {data.U_DATABASES_MEASURE}</span></div>
  84. <div><span>{i18n['User Directories']}:</span> <span><b>{data.U_DISK_DIRS}</b> {data.U_DISK_DIRS_MEASURE}</span></div>
  85. </div>
  86. </div>
  87. </Container>
  88. <Container className="c-2">
  89. <div><span>{i18n['Web Domains']}:</span> <span><b>{data.U_WEB_DOMAINS}</b> / {data.WEB_DOMAINS}</span></div>
  90. <div><span>{i18n['DNS Domains']}:</span> <span><b>{data.U_DNS_DOMAINS}</b> / {data.DNS_DOMAINS}</span></div>
  91. <div><span>{i18n['Mail Domains']}:</span> <span><b>{data.U_MAIL_DOMAINS}</b> / {data.MAIL_DOMAINS}</span></div>
  92. <div><span>{i18n.Databases}:</span> <span><b>{data.U_DATABASES}</b> / {data.DATABASES}</span></div>
  93. <div><span>{i18n['Cron Jobs']}:</span> <span><b>{data.U_CRON_JOBS}</b> / {data.CRON_JOBS}</span></div>
  94. <div><span>{i18n.Backups}:</span> <span><b>{data.U_BACKUPS}</b> / {data.BACKUPS}</span></div>
  95. </Container>
  96. <Container className="c-3">
  97. <div><span>{i18n.Email}:</span> <span className="stat email">{data.CONTACT}</span></div>
  98. <div><span>{i18n.Package}:</span> <span className="stat">{data.PACKAGE}</span></div>
  99. <div><span>{i18n['SSH Access']}:</span> <span className="stat">{data.SHELL}</span></div>
  100. <div><span>{i18n['IP Addresses']}:</span> <span className="stat">{data.IP_OWNED}</span></div>
  101. <div className="ns"><span>{i18n['Name Servers']}:</span> <span className="stat">{printNameServers(data.NS)}</span></div>
  102. </Container>
  103. </div>
  104. </Container>
  105. <div className="actions">
  106. {printLoginActionButton(data.NAME)}
  107. <div>
  108. <Link to={`/edit/user?user=${data.NAME}`}>{i18n.edit}
  109. {data.FOCUSED ? <span className="shortcut-button html-unicode">&#8617;</span> : <FontAwesomeIcon icon="pen" />}
  110. </Link>
  111. </div>
  112. <div>
  113. <button
  114. className="link-gray"
  115. onClick={handleSuspend}>
  116. {data.spnd_action}
  117. {data.FOCUSED ? <span className="shortcut-button">S</span> : <FontAwesomeIcon icon={data.SUSPENDED === 'yes' ? 'unlock' : 'lock'} />}
  118. </button>
  119. </div>
  120. <div>
  121. <button className="link-delete" onClick={handleDelete}>
  122. {i18n.Delete}
  123. {data.FOCUSED ? <span className="shortcut-button del">Del</span> : <FontAwesomeIcon icon="times" />}
  124. </button>
  125. </div>
  126. </div>
  127. </ListItem>
  128. );
  129. }
  130. export default User;