focalxaiinspection
Version:
Focalx AI Inspection
193 lines (191 loc) • 12.2 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _reactBootstrap = require("react-bootstrap");
var _reactRouterDom = require("react-router-dom");
require("./DamageList.scss");
var _GetInspectionReport = _interopRequireDefault(require("../../services/Api/GetInspectionReport"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
//import GetBaseURL from "../../services/Api/base";
var DamageList = function DamageList() {
//const baseUrl = GetBaseURL();
var car_info = JSON.parse(sessionStorage.getItem('carInformation'));
var baseUrl = car_info.baseUrl;
var accessToken = sessionStorage.getItem('token');
var schemaName = sessionStorage.getItem('schema_name');
var _useState = (0, _react.useState)(null),
_useState2 = _slicedToArray(_useState, 2),
data = _useState2[0],
setData = _useState2[1];
var _useState3 = (0, _react.useState)(null),
_useState4 = _slicedToArray(_useState3, 2),
damageTypeData = _useState4[0],
setDamageTypeData = _useState4[1];
var _useState5 = (0, _react.useState)(true),
_useState6 = _slicedToArray(_useState5, 2),
loading = _useState6[0],
setLoading = _useState6[1];
var _useState7 = (0, _react.useState)(null),
_useState8 = _slicedToArray(_useState7, 2),
selectedCard = _useState8[0],
setSelectedCard = _useState8[1];
var _useState9 = (0, _react.useState)(false),
_useState10 = _slicedToArray(_useState9, 2),
showModel = _useState10[0],
setShowModel = _useState10[1];
var _useState11 = (0, _react.useState)(null),
_useState12 = _slicedToArray(_useState11, 2),
itemIndex = _useState12[0],
setItemIndex = _useState12[1];
var location = (0, _reactRouterDom.useLocation)();
var searchParams = new URLSearchParams(location.search);
var id = searchParams.get("id");
//console.log(id);
(0, _react.useEffect)(function () {
(0, _GetInspectionReport.default)().then(function (data) {
var damageDataList = [];
data.image_report.map(function (item) {
if (item.damages && item.damages.length > 0) {
var position = item.position;
item.damages.map(function (damageData) {
var damageItem = damageData;
damageItem.position = position;
damageDataList.push(damageItem);
});
}
});
//console.log(damageDataList);
setDamageTypeData(damageDataList);
renderDamageList(damageDataList);
setLoading(false);
}).catch(function (error) {
console.log("Error getting inspection report:", error);
setLoading(false);
});
}, []);
var handleDamageApproval = function handleDamageApproval(id, status) {
try {
//console.log(status);
var apiUrl = "https://".concat(schemaName, ".").concat(baseUrl, "/api/v1/service/damage/").concat(id, "/");
var formdata = new FormData();
formdata.append("user_action", status);
var requestOptions = {
method: 'POST',
headers: {
'Authorization': "Bearer ".concat(accessToken)
},
body: formdata
};
fetch(apiUrl, requestOptions).then(function (response) {
return response.json();
}).then(function (result) {
var damageListItem = damageTypeData;
damageListItem[itemIndex].user_action_status = result.damage.user_action_status;
renderDamageList(damageListItem);
//setData(damageListItem);
setShowModel(false);
}).catch(function (error) {
return console.log('error', error);
});
setShowModel(false);
} catch (e) {
console.log(e.message);
}
};
var renderDamageList = function renderDamageList(listData) {
if (listData && listData.length > 0) {
setData(listData.map(function (item, index) {
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
className: "custom-card car-service-card pointer",
key: index,
onClick: function onClick() {
return handleModel(index, item);
}
}, /*#__PURE__*/_react.default.createElement("figure", null, /*#__PURE__*/_react.default.createElement("div", {
className: "image-wrap"
}, /*#__PURE__*/_react.default.createElement("img", {
src: item.annotated_damage_image_url_public,
alt: ""
}))), /*#__PURE__*/_react.default.createElement("div", {
className: "description"
}, /*#__PURE__*/_react.default.createElement("p", {
className: "car-model"
}, item.part.name || "-"), /*#__PURE__*/_react.default.createElement("p", null, item.damage_type.name || "-"), /*#__PURE__*/_react.default.createElement("p", null, item.is_manual ? "Manually added" : "Auto detected"), /*#__PURE__*/_react.default.createElement("p", null, item.category), /*#__PURE__*/_react.default.createElement("div", {
className: "status"
}, item.user_action_status === "REJECTED" && /*#__PURE__*/_react.default.createElement("img", {
width: 20,
src: require('../../Assets/images/rejected_icon.png'),
alt: ""
}), item.user_action_status === "ACCEPTED" && /*#__PURE__*/_react.default.createElement("img", {
width: 20,
src: require('../../Assets/images/accepted_damage.svg').default,
alt: ""
})))));
}));
} else {
setData( /*#__PURE__*/_react.default.createElement("p", {
className: "no-data"
}, "No data to display."));
}
};
var handleModel = function handleModel(index, item) {
setShowModel(true);
setItemIndex(index);
setSelectedCard(item);
};
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, loading && /*#__PURE__*/_react.default.createElement("div", {
className: "lds-roller-overlay"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "lds-roller"
}, /*#__PURE__*/_react.default.createElement("div", null), /*#__PURE__*/_react.default.createElement("div", null), /*#__PURE__*/_react.default.createElement("div", null), /*#__PURE__*/_react.default.createElement("div", null), /*#__PURE__*/_react.default.createElement("div", null), /*#__PURE__*/_react.default.createElement("div", null), /*#__PURE__*/_react.default.createElement("div", null), /*#__PURE__*/_react.default.createElement("div", null))), data, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Modal, {
className: "damage-modal",
show: showModel,
centered: true,
onHide: function onHide() {
setShowModel(false);
setSelectedCard(null);
}
}, /*#__PURE__*/_react.default.createElement("button", {
type: "button",
className: "custom-btn-close",
"aria-label": "Close",
onClick: function onClick() {
setShowModel(false);
setSelectedCard(null);
}
}, /*#__PURE__*/_react.default.createElement("img", {
src: require('../../Assets/images/close-with-circle.svg').default,
alt: ""
})), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Modal.Body, null, selectedCard && /*#__PURE__*/_react.default.createElement("div", {
className: "damage-modal-details"
}, /*#__PURE__*/_react.default.createElement("figure", null, /*#__PURE__*/_react.default.createElement("img", {
src: selectedCard.annotated_damage_image_url_public,
alt: ""
})), /*#__PURE__*/_react.default.createElement("ul", {
className: "description"
}, /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement("span", null, "Type"), /*#__PURE__*/_react.default.createElement("span", null, selectedCard.damage_type.name || "-")), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement("span", null, "Location"), /*#__PURE__*/_react.default.createElement("span", null, selectedCard.position.name || "-")), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement("span", null, "Part"), /*#__PURE__*/_react.default.createElement("span", null, selectedCard.part.name || "-")), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement("span", null, "K1-K5"), /*#__PURE__*/_react.default.createElement("span", null, selectedCard.category || "-"))))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Modal.Footer, null, /*#__PURE__*/_react.default.createElement("button", {
onClick: function onClick() {
return handleDamageApproval(selectedCard.id, "REJECTED");
},
className: "custom-secondary-outline-button left-side-btn justify-content-center"
}, "Reject"), /*#__PURE__*/_react.default.createElement("button", {
onClick: function onClick() {
return handleDamageApproval(selectedCard.id, "ACCEPTED");
},
className: "custom-primary-button right-side-btn justify-content-center text-white"
}, "Accept"))));
};
var _default = DamageList;
exports.default = _default;