IF YOU WOULD LIKE TO GET AN ACCOUNT, please write an email to s dot adaszewski at gmail dot com. User accounts are meant only to report issues and/or generate pull requests. This is a purpose-specific Git hosting for ADARED projects. Thank you for your understanding!
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

76 行
2.1KB

  1. import { h, Component } from 'preact';
  2. import WBTable from 'wb-table';
  3. import makeArvadosRequest from 'make-arvados-request';
  4. import arvadosTypeName from 'arvados-type-name';
  5. import arvadosObjectName from 'arvados-object-name';
  6. import urlForObject from 'url-for-object';
  7. import wbFormatDate from 'wb-format-date';
  8. import WBNameAndUuid from 'wb-name-and-uuid';
  9. class WBCommonFields extends Component {
  10. componentDidMount() {
  11. this.prepareRows();
  12. }
  13. componentWillReceiveProps(nextProps) {
  14. this.props = nextProps;
  15. // this.setState({ 'rows': null });
  16. this.prepareRows();
  17. }
  18. prepareRows() {
  19. let { uuid, app } = this.props;
  20. let { arvHost, arvToken } = app.state;
  21. let item;
  22. let owner;
  23. let modifiedByUser;
  24. let prom = makeArvadosRequest(arvHost, arvToken,
  25. '/arvados/v1/' + arvadosTypeName(uuid) +
  26. 's/' + uuid);
  27. prom = prom.then(xhr => (item = xhr.response));
  28. prom = prom.then(() => {
  29. let rows = [
  30. [ 'UUID', item.uuid ],
  31. [ 'Kind', item.kind ],
  32. [ 'Owner', (
  33. <WBNameAndUuid app={ app } uuid={ item.owner_uuid } />
  34. ) ],
  35. [ 'Created at', wbFormatDate(item.created_at) ],
  36. [ 'Modified at', wbFormatDate(item.modified_at) ],
  37. [ 'Modified by User', (
  38. <WBNameAndUuid app={ app } uuid={ item.modified_by_user_uuid } />
  39. ) ],
  40. [ 'Modified by Client', (
  41. <WBNameAndUuid app={ app } uuid={ item.modified_by_client_uuid } />
  42. ) ],
  43. [ 'API Url', (
  44. <a href={ 'https://' + app.state.arvHost + '/arvados/v1' + item.href }>
  45. { 'https://' + app.state.arvHost + '/arvados/v1' + item.href }
  46. </a>
  47. ) ],
  48. [ 'ETag', item.etag ]
  49. ];
  50. this.setState({ 'rows': rows });
  51. });
  52. }
  53. render({}, { rows }) {
  54. return (
  55. rows ? (
  56. <WBTable columns={ [ "Name", "Value" ] }
  57. headerClasses={ [ "col-sm-2", "col-sm-4" ] }
  58. verticalHeader={ true }
  59. rows={ rows } />
  60. ) : (
  61. <div>Loading...</div>
  62. )
  63. );
  64. }
  65. }
  66. export default WBCommonFields;