assetinfo.vue 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <template>
  2. <div>
  3. <modal id="asseteditModal" tabindex="-1" role="dialog" aria-labelledby="asseteditModalLabel">
  4. <h5 slot="header" class="modal-title" id="asseteditModalLabel">
  5. Edit Work Order Information
  6. </h5>
  7. <div slot="body">
  8. <div class="form-group">
  9. <label for="manufacturer">Manufacturer</label>
  10. <input type="text" name="manufacturer" id="manufacturer" class="form-control" v-model.lazy="data.pcmanu">
  11. </div>
  12. <div class="form-group">
  13. <label for="make">Make</label>
  14. <input type="text" name="make" id="make" class="form-control" v-model.lazy="data.pcmake">
  15. </div>
  16. <div class="form-group">
  17. <label for="nickname">Nickname</label>
  18. <input type="text" name="nickname" id="nickname" class="form-control" v-model.lazy="data.pcnickname">
  19. </div>
  20. <div class="form-group">
  21. <label for="os">OS</label>
  22. <input type="text" name="os" id="os" class="form-control" v-model.lazy="pcextra[2]">
  23. </div>
  24. <div class="form-group">
  25. <label for="serial">Serial Number</label>
  26. <input type="text" id="serial" name="serial" class="form-control" v-model.lazy="pcextra[104]">
  27. </div>
  28. <div class="form-group">
  29. <label for="cpu">CPU</label>
  30. <input type="text" id="cpu" name="cpu" class="form-control" v-model.lazy="pcextra[101]">
  31. </div>
  32. <div class="form-group">
  33. <label for="ram">RAM</label>
  34. <input type="text" name="ram" id="ram" class="form-control" v-model.lazy="pcextra[100]">
  35. </div>
  36. <div class="form-group">
  37. <label for="graphics">Graphics</label>
  38. <input type="text" name="graphics" id="grapics" class="form-control" v-model.lazy="pcextra[4]">
  39. </div>
  40. </div>
  41. <div slot="footer">
  42. <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
  43. <button type="button" class="btn btn-primary" @click="updateAsset()">Save</button>
  44. </div>
  45. </modal>
  46. <h4 class="text-center">{{ this.data.pcmanu }} {{ this.data.pcmake }} - <small class="text-muted">{{this.data.pcnickname}}</small></h4>
  47. <p>OS: {{this.pcextra[2]}}</p>
  48. <p>S/N: {{ this.pcextra[104] }}</p>
  49. <p>CPU: {{ this.pcextra[101]}}</p>
  50. <p>RAM: {{ this.pcextra[100] }}</p>
  51. <p>Graphics: {{this.pcextra[4]}}</p>
  52. <button type="button" class="btn btn-primary" data-toggle="modal" data-target="#asseteditModal">Edit</button>
  53. </div>
  54. </template>
  55. <script>
  56. export default {
  57. props: ['asset', 'pcextraStart'],
  58. data() {
  59. return {
  60. data: JSON.parse(this.asset),
  61. pcextra: JSON.parse(this.pcextraStart),
  62. }
  63. },
  64. mounted() {
  65. Echo.channel('assets')
  66. .listen('AssetUpdated', (e) => {
  67. this.data = JSON.parse(e.data);
  68. this.pcextra = JSON.parse(e.pcextra);
  69. });
  70. },
  71. methods: {
  72. updateAsset() {
  73. this.data.pcextra = this.pcextra;
  74. axios.put('/api/assets/' + this.data.pcid, this.data)
  75. .then((response) => {})
  76. .catch((error) => {});
  77. $('#asseteditModal').modal('hide');
  78. }
  79. }
  80. }
  81. </script>