StatusPill.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /*
  2. * Copyright (C) 2017 - present Instructure, Inc.
  3. *
  4. * This file is part of Canvas.
  5. *
  6. * Canvas is free software: you can redistribute it and/or modify it under
  7. * the terms of the GNU Affero General Public License as published by the Free
  8. * Software Foundation, version 3 of the License.
  9. *
  10. * Canvas is distributed in the hope that it will be useful, but WITHOUT ANY
  11. * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
  12. * A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
  13. * details.
  14. *
  15. * You should have received a copy of the GNU Affero General Public License along
  16. * with this program. If not, see <http://www.gnu.org/licenses/>.
  17. */
  18. import React from 'react';
  19. import ReactDOM from 'react-dom';
  20. import Pill from 'instructure-ui/lib/components/Pill';
  21. import I18n from 'i18n!gradebook';
  22. function forEachNode (nodeList, fn) {
  23. for (let i = 0; i < nodeList.length; i += 1) {
  24. fn(nodeList[i]);
  25. }
  26. }
  27. export default {
  28. renderPills () {
  29. const missMountPoints = document.querySelectorAll('.submission-missing-pill');
  30. const lateMountPoints = document.querySelectorAll('.submission-late-pill');
  31. forEachNode(missMountPoints, (mountPoint) => {
  32. ReactDOM.render(<Pill variant="danger" text={I18n.t('missing')} />, mountPoint);
  33. });
  34. forEachNode(lateMountPoints, (mountPoint) => {
  35. ReactDOM.render(<Pill variant="danger" text={I18n.t('late')} />, mountPoint);
  36. });
  37. }
  38. };