openstack-uicore-foundation 5.0.2 → 5.0.3-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (223) hide show
  1. package/.claude/settings.local.json +12 -0
  2. package/lib/components/ajaxloader.js.map +1 -1
  3. package/lib/components/attendance-tracker.js +1 -1
  4. package/lib/components/attendance-tracker.js.map +1 -1
  5. package/lib/components/bulk-actions-selector.js.map +1 -1
  6. package/lib/components/circle-button.js.map +1 -1
  7. package/lib/components/clock.js +1 -1
  8. package/lib/components/clock.js.map +1 -1
  9. package/lib/components/exclusive-wrapper.js.map +1 -1
  10. package/lib/components/extra-questions-mui.js.map +1 -1
  11. package/lib/components/extra-questions.js +1 -1
  12. package/lib/components/extra-questions.js.map +1 -1
  13. package/lib/components/form-validation.js.map +1 -1
  14. package/lib/components/forms/rsvp-form.js.map +1 -1
  15. package/lib/components/forms/simple-form.js +1 -1
  16. package/lib/components/forms/simple-form.js.map +1 -1
  17. package/lib/components/free-text-search.js +1 -1
  18. package/lib/components/free-text-search.js.map +1 -1
  19. package/lib/components/google-map.js +1 -1
  20. package/lib/components/google-map.js.map +1 -1
  21. package/lib/components/index.js +1 -1
  22. package/lib/components/index.js.map +1 -1
  23. package/lib/components/inputs/access-levels-input.js +1 -1
  24. package/lib/components/inputs/access-levels-input.js.map +1 -1
  25. package/lib/components/inputs/action-dropdown.js.map +1 -1
  26. package/lib/components/inputs/attendee-input.js +1 -1
  27. package/lib/components/inputs/attendee-input.js.map +1 -1
  28. package/lib/components/inputs/checkbox-list.js.map +1 -1
  29. package/lib/components/inputs/company-input-v2.js +1 -1
  30. package/lib/components/inputs/company-input-v2.js.map +1 -1
  31. package/lib/components/inputs/company-input.js +1 -1
  32. package/lib/components/inputs/company-input.js.map +1 -1
  33. package/lib/components/inputs/country-dropdown.js +1 -1
  34. package/lib/components/inputs/country-dropdown.js.map +1 -1
  35. package/lib/components/inputs/country-input.js +1 -1
  36. package/lib/components/inputs/country-input.js.map +1 -1
  37. package/lib/components/inputs/datetimepicker.js.map +1 -1
  38. package/lib/components/inputs/dropdown.js.map +1 -1
  39. package/lib/components/inputs/editor-input-v2.js.map +1 -1
  40. package/lib/components/inputs/editor-input-v3.js.map +1 -1
  41. package/lib/components/inputs/editor-input.js.map +1 -1
  42. package/lib/components/inputs/event-input.js +1 -1
  43. package/lib/components/inputs/event-input.js.map +1 -1
  44. package/lib/components/inputs/free-multi-text-input.js.map +1 -1
  45. package/lib/components/inputs/group-input.js +1 -1
  46. package/lib/components/inputs/group-input.js.map +1 -1
  47. package/lib/components/inputs/grouped-dropdown.js.map +1 -1
  48. package/lib/components/inputs/language-input.js +1 -1
  49. package/lib/components/inputs/language-input.js.map +1 -1
  50. package/lib/components/inputs/member-input.js +1 -1
  51. package/lib/components/inputs/member-input.js.map +1 -1
  52. package/lib/components/inputs/operator-input.js.map +1 -1
  53. package/lib/components/inputs/organization-input.js +1 -1
  54. package/lib/components/inputs/organization-input.js.map +1 -1
  55. package/lib/components/inputs/promocode-input.js +1 -1
  56. package/lib/components/inputs/promocode-input.js.map +1 -1
  57. package/lib/components/inputs/radio-list.js.map +1 -1
  58. package/lib/components/inputs/registration-company-input.js +1 -1
  59. package/lib/components/inputs/registration-company-input.js.map +1 -1
  60. package/lib/components/inputs/speaker-input.js +1 -1
  61. package/lib/components/inputs/speaker-input.js.map +1 -1
  62. package/lib/components/inputs/sponsor-input.js +1 -1
  63. package/lib/components/inputs/sponsor-input.js.map +1 -1
  64. package/lib/components/inputs/stepped-select.js.map +1 -1
  65. package/lib/components/inputs/summit-days-select.js.map +1 -1
  66. package/lib/components/inputs/summit-input.js +1 -1
  67. package/lib/components/inputs/summit-input.js.map +1 -1
  68. package/lib/components/inputs/summit-venues-select.js.map +1 -1
  69. package/lib/components/inputs/tag-input.js +1 -1
  70. package/lib/components/inputs/tag-input.js.map +1 -1
  71. package/lib/components/inputs/text-input.js.map +1 -1
  72. package/lib/components/inputs/textarea-input.js.map +1 -1
  73. package/lib/components/inputs/ticket-types-input.js +1 -1
  74. package/lib/components/inputs/ticket-types-input.js.map +1 -1
  75. package/lib/components/inputs/upload-input-v2.js +1 -1
  76. package/lib/components/inputs/upload-input-v2.js.map +1 -1
  77. package/lib/components/inputs/upload-input-v3.js +1 -1
  78. package/lib/components/inputs/upload-input-v3.js.map +1 -1
  79. package/lib/components/inputs/upload-input.js.map +1 -1
  80. package/lib/components/mui/alert-button.js +2 -0
  81. package/lib/components/mui/alert-button.js.map +1 -0
  82. package/lib/components/mui/alert-modal.js +2 -0
  83. package/lib/components/mui/alert-modal.js.map +1 -0
  84. package/lib/components/mui/auth-button.js +2 -0
  85. package/lib/components/mui/auth-button.js.map +1 -0
  86. package/lib/components/mui/cart-button.js +2 -0
  87. package/lib/components/mui/cart-button.js.map +1 -0
  88. package/lib/components/mui/checkbox-list.js.map +1 -1
  89. package/lib/components/mui/chip-list.js.map +1 -1
  90. package/lib/components/mui/chip-notify.js +1 -1
  91. package/lib/components/mui/chip-notify.js.map +1 -1
  92. package/lib/components/mui/chip-select-input.js.map +1 -1
  93. package/lib/components/mui/confirm-delete-dialog.js +2 -0
  94. package/lib/components/mui/confirm-delete-dialog.js.map +1 -0
  95. package/lib/components/mui/confirm-dialog.js.map +1 -1
  96. package/lib/components/mui/custom-alert.js.map +1 -1
  97. package/lib/components/mui/dashboard-card.js +2 -0
  98. package/lib/components/mui/dashboard-card.js.map +1 -0
  99. package/lib/components/mui/dnd-list.js.map +1 -1
  100. package/lib/components/mui/download-btn.js +2 -0
  101. package/lib/components/mui/download-btn.js.map +1 -0
  102. package/lib/components/mui/dropdown-checkbox.js.map +1 -1
  103. package/lib/components/mui/editable-table.js.map +1 -1
  104. package/lib/components/mui/form-item-table.js +1 -1
  105. package/lib/components/mui/form-item-table.js.map +1 -1
  106. package/lib/components/mui/formik-inputs/additional-input-list.js.map +1 -1
  107. package/lib/components/mui/formik-inputs/additional-input.js.map +1 -1
  108. package/lib/components/mui/formik-inputs/async-select.js.map +1 -1
  109. package/lib/components/mui/formik-inputs/checkbox-group.js.map +1 -1
  110. package/lib/components/mui/formik-inputs/checkbox.js.map +1 -1
  111. package/lib/components/mui/formik-inputs/company-input.js +1 -1
  112. package/lib/components/mui/formik-inputs/company-input.js.map +1 -1
  113. package/lib/components/mui/formik-inputs/datepicker.js.map +1 -1
  114. package/lib/components/mui/formik-inputs/discount-field.js.map +1 -1
  115. package/lib/components/mui/formik-inputs/dropdown-checkbox.js.map +1 -1
  116. package/lib/components/mui/formik-inputs/dropdown-radio.js.map +1 -1
  117. package/lib/components/mui/formik-inputs/file-size-field.js.map +1 -1
  118. package/lib/components/mui/formik-inputs/item-price-tiers.js +1 -1
  119. package/lib/components/mui/formik-inputs/item-price-tiers.js.map +1 -1
  120. package/lib/components/mui/formik-inputs/price-field.js.map +1 -1
  121. package/lib/components/mui/formik-inputs/quantity-field.js.map +1 -1
  122. package/lib/components/mui/formik-inputs/radio-group.js.map +1 -1
  123. package/lib/components/mui/formik-inputs/select-group.js.map +1 -1
  124. package/lib/components/mui/formik-inputs/select.js.map +1 -1
  125. package/lib/components/mui/formik-inputs/sponsor-input.js +1 -1
  126. package/lib/components/mui/formik-inputs/sponsor-input.js.map +1 -1
  127. package/lib/components/mui/formik-inputs/sponsorship-input.js +1 -1
  128. package/lib/components/mui/formik-inputs/sponsorship-input.js.map +1 -1
  129. package/lib/components/mui/formik-inputs/sponsorship-summit-select.js +1 -1
  130. package/lib/components/mui/formik-inputs/sponsorship-summit-select.js.map +1 -1
  131. package/lib/components/mui/formik-inputs/summit-addon-select.js +1 -1
  132. package/lib/components/mui/formik-inputs/summit-addon-select.js.map +1 -1
  133. package/lib/components/mui/formik-inputs/switch.js.map +1 -1
  134. package/lib/components/mui/formik-inputs/textfield.js.map +1 -1
  135. package/lib/components/mui/formik-inputs/timepicker.js.map +1 -1
  136. package/lib/components/mui/formik-inputs/upload.js +1 -1
  137. package/lib/components/mui/formik-inputs/upload.js.map +1 -1
  138. package/lib/components/mui/infinite-table.js.map +1 -1
  139. package/lib/components/mui/item-settings-modal.js +1 -1
  140. package/lib/components/mui/item-settings-modal.js.map +1 -1
  141. package/lib/components/mui/loading-overlay.js +2 -0
  142. package/lib/components/mui/loading-overlay.js.map +1 -0
  143. package/lib/components/mui/menu-button.js.map +1 -1
  144. package/lib/components/mui/nav-bar.js +2 -0
  145. package/lib/components/mui/nav-bar.js.map +1 -0
  146. package/lib/components/mui/notes-modal.js +1 -1
  147. package/lib/components/mui/notes-modal.js.map +1 -1
  148. package/lib/components/mui/order-summary.js +2 -0
  149. package/lib/components/mui/order-summary.js.map +1 -0
  150. package/lib/components/mui/search-input.js +1 -1
  151. package/lib/components/mui/search-input.js.map +1 -1
  152. package/lib/components/mui/show-confirm-dialog.js.map +1 -1
  153. package/lib/components/mui/snackbar-notification.js +1 -1
  154. package/lib/components/mui/snackbar-notification.js.map +1 -1
  155. package/lib/components/mui/sortable-table.js.map +1 -1
  156. package/lib/components/mui/sponsor-addon-select.js +1 -1
  157. package/lib/components/mui/sponsor-addon-select.js.map +1 -1
  158. package/lib/components/mui/status-chip.js +2 -0
  159. package/lib/components/mui/status-chip.js.map +1 -0
  160. package/lib/components/mui/stripe-payment.js +2 -0
  161. package/lib/components/mui/stripe-payment.js.map +1 -0
  162. package/lib/components/mui/summit-addon-select.js +1 -1
  163. package/lib/components/mui/summit-addon-select.js.map +1 -1
  164. package/lib/components/mui/summits-dropdown.js +1 -1
  165. package/lib/components/mui/summits-dropdown.js.map +1 -1
  166. package/lib/components/mui/table.js +1 -1
  167. package/lib/components/mui/table.js.map +1 -1
  168. package/lib/components/mui/upload-btn.js +2 -0
  169. package/lib/components/mui/upload-btn.js.map +1 -0
  170. package/lib/components/mui/upload-dialog.js +2 -0
  171. package/lib/components/mui/upload-dialog.js.map +1 -0
  172. package/lib/components/progressive-img.js.map +1 -1
  173. package/lib/components/raw-html.js.map +1 -1
  174. package/lib/components/schedule-builder-view.js +1 -1
  175. package/lib/components/schedule-builder-view.js.map +1 -1
  176. package/lib/components/sections/panel.js.map +1 -1
  177. package/lib/components/simple-link-list.js.map +1 -1
  178. package/lib/components/sponsored-project-input.js +1 -1
  179. package/lib/components/sponsored-project-input.js.map +1 -1
  180. package/lib/components/summit-dropdown.js.map +1 -1
  181. package/lib/components/table-editable.js +1 -1
  182. package/lib/components/table-editable.js.map +1 -1
  183. package/lib/components/table-selectable.js.map +1 -1
  184. package/lib/components/table-sortable.js.map +1 -1
  185. package/lib/components/table.js.map +1 -1
  186. package/lib/components/video-stream.js.map +1 -1
  187. package/lib/css/components/index.css +1 -1
  188. package/lib/css/components/index.css.map +1 -1
  189. package/lib/css/components/mui/auth-button.css +1 -0
  190. package/lib/css/components/mui/nav-bar.css +1 -0
  191. package/lib/css/components/mui/upload-dialog.css +2 -0
  192. package/lib/css/components/mui/upload-dialog.css.map +1 -0
  193. package/lib/i18n.js +1 -1
  194. package/lib/i18n.js.map +1 -1
  195. package/lib/models/index.js.map +1 -1
  196. package/lib/models/summit-event.js.map +1 -1
  197. package/lib/security/abstract-auth-callback-route-v2.js +1 -1
  198. package/lib/security/abstract-auth-callback-route-v2.js.map +1 -1
  199. package/lib/security/abstract-auth-callback-route.js +1 -1
  200. package/lib/security/abstract-auth-callback-route.js.map +1 -1
  201. package/lib/security/actions.js +1 -1
  202. package/lib/security/actions.js.map +1 -1
  203. package/lib/security/methods.js +1 -1
  204. package/lib/security/methods.js.map +1 -1
  205. package/lib/security/reducers.js +1 -1
  206. package/lib/security/reducers.js.map +1 -1
  207. package/lib/security/session-checker.js +1 -1
  208. package/lib/security/session-checker.js.map +1 -1
  209. package/lib/utils/actions.js +1 -1
  210. package/lib/utils/actions.js.map +1 -1
  211. package/lib/utils/fragment-parser.js.map +1 -1
  212. package/lib/utils/methods.js +1 -1
  213. package/lib/utils/methods.js.map +1 -1
  214. package/lib/utils/money.js.map +1 -1
  215. package/lib/utils/query-actions.js +1 -1
  216. package/lib/utils/query-actions.js.map +1 -1
  217. package/lib/utils/questions-set.js +1 -1
  218. package/lib/utils/questions-set.js.map +1 -1
  219. package/lib/utils/reducers.js +1 -1
  220. package/lib/utils/reducers.js.map +1 -1
  221. package/lib/utils/use-fit-text.js.map +1 -1
  222. package/package.json +9 -1
  223. package/.codegraph/config.json +0 -140
@@ -1,2 +1,2 @@
1
- !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("openstack-uicore-foundation",[],t):"object"==typeof exports?exports["openstack-uicore-foundation"]=t():e["openstack-uicore-foundation"]=t()}(this,(()=>(()=>{"use strict";var e={9558:(e,t,n)=>{n.d(t,{shallowEqual:()=>a});n(5812),n(8041);const a=(e,t)=>{const n=Object.keys(e),a=Object.keys(t);if(n.length!==a.length)return!1;for(let a of n)if(e[a]!==t[a])return!1;return!0}},1116:e=>{e.exports=require("@babel/runtime/helpers/defineProperty")},6842:e=>{e.exports=require("i18n-react/dist/i18n-react")},5812:e=>{e.exports=require("moment-timezone")},2015:e=>{e.exports=require("react")},5433:e=>{e.exports=require("react-tooltip")},9236:e=>{e.exports=require("sweetalert2")},8041:e=>{e.exports=require("urijs")}},t={};function n(a){var r=t[a];if(void 0!==r)return r.exports;var s=t[a]={exports:{}};return e[a](s,s.exports,n),s.exports}(()=>{n.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return n.d(t,{a:t}),t}})(),(()=>{n.d=(e,t)=>{for(var a in t)n.o(t,a)&&!n.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:t[a]})}})(),(()=>{n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t)})(),(()=>{n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}})();var a={};n.r(a),n.d(a,{default:()=>E});var r=n(1116),s=n.n(r),i=n(2015),o=n.n(i);class l extends o().Component{constructor(e){super(e)}render(){return o().createElement("th",{width:this.props.width},this.props.children)}}const c=l,d=e=>e.is_edit?o().createElement("td",null,!e.shouldUseTextArea&&o().createElement("input",{type:"text",className:"form-control",defaultValue:e.children,name:e.name,id:e.id,onChange:e.handleChange}),e.shouldUseTextArea&&o().createElement("textarea",{className:"form-control",defaultValue:e.children,name:e.name,id:e.id,onChange:e.handleChange})):o().createElement("td",null,e.children);class h extends o().Component{constructor(e){super(e),this.state={is_editing:!1}}onDelete(e,t){t.preventDefault(),t.stopPropagation(),this.props.actions.delete(e)}onSave(e,t){t.preventDefault(),t.stopPropagation(),this.setState({is_editing:!1}),this.props.actions.save(e)}onEdit(e,t){t.preventDefault(),t.stopPropagation(),this.setState({is_editing:!0}),this.props.actions.edit(e)}onCancel(e,t){t.preventDefault(),t.stopPropagation(),this.setState({is_editing:!1}),this.props.actions.cancel(e)}render(){let{actions:e,id:t}=this.props;return this.state.is_editing?o().createElement("td",{className:"actions"},o().createElement("a",{href:"",onClick:this.onSave.bind(this,t),"data-tip":"save"},o().createElement("i",{className:"fa fa-floppy-o"})),o().createElement("a",{href:"",onClick:this.onCancel.bind(this,t),"data-tip":"cancel"},o().createElement("i",{className:"fa fa-times"}))):o().createElement("td",{className:"actions"},"edit"in e&&o().createElement("a",{href:"",onClick:this.onEdit.bind(this,t),"data-tip":"edit"},o().createElement("i",{className:"fa fa-pencil-square-o"})),"delete"in e&&o().createElement("a",{href:"",onClick:this.onDelete.bind(this,t),"data-tip":"delete"},o().createElement("i",{className:"fa fa-trash-o delete-icon"})))}}class p extends o().Component{render(){const{children:e,even:t,id:n}=this.props;return o().createElement("tr",{id:n,role:"row",className:t?"even":"odd"},e)}}var u=n(9236),m=n.n(u),w=n(6842),f=n.n(w),v=n(5433),g=n(9558);function y(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}const b="";class E extends o().Component{constructor(e){var t,n;super(e),this.state={rows:e.data,new_row:{}},this.onSave=null===(t=e.options.actions)||void 0===t||null===(n=t.save)||void 0===n?void 0:n.onClick,this.actions=e.options.actions||{},this.actions.edit=this.editRow.bind(this),this.actions.save=this.saveRow.bind(this),this.actions.delete=this.deleteClick.bind(this),this.actions.handleChange=this.onChangeCell.bind(this),this.actions.cancel=this.editRowCancel.bind(this),this.saveNewRow=this.saveNewRow.bind(this),this.handleNewChange=this.onChangeNewCell.bind(this)}componentDidUpdate(e,t,n){(0,g.shallowEqual)(this.props.data,e.data)||this.setState({rows:this.props.data})}saveRow(e,t){const{rows:n}=this.state;let a=n.find((t=>t.id==e));a.is_edit=!1,this.editing_row=null,this.setState({rows:n}),this.onSave(a)}deleteClick(e){var t,n;let a=null===(t=this.props.options.actions)||void 0===t||null===(n=t.delete)||void 0===n?void 0:n.onClick;this.props.options.hasOwnProperty("noAlert")?a(e):m().fire({title:f().translate("general.are_you_sure"),text:f().translate("general.remove_warning"),type:"warning",showCancelButton:!0,confirmButtonColor:"#DD6B55",confirmButtonText:f().translate("general.yes_delete")}).then((function(t){t.value&&a(e)}))}editRow(e,t){const{rows:n}=this.state;let a=n.find((t=>t.id==e));this.editing_row=function(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?y(Object(n),!0).forEach((function(t){s()(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):y(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}({},a),a.is_edit=!0,this.setState({rows:n})}editRowCancel(e,t){const{rows:n}=this.state;n.forEach((e=>{e.is_edit=!1}));let a=n.findIndex((t=>t.id==e));n[a]=this.editing_row,this.setState({rows:n})}onChangeCell(e){const{rows:t}=this.state;let n=e.target;t.find((e=>e.id==n.id))[n.name]=n.value,this.setState({rows:t})}onChangeNewCell(e){const{new_row:t}=this.state;let n=e.target;t[n.name]=n.value,this.setState({new_row:t})}saveNewRow(e){const{new_row:t}=this.state;e.preventDefault(),this.onSave(t),this.setState({new_row:{}})}render(){let{options:e,columns:t}=this.props,n=e.hasOwnProperty("className")?e.className:"",a=this.props.hasOwnProperty("textArea");return o().createElement("div",null,o().createElement("table",{className:"table table-striped table-bordered editableTable "+n},o().createElement("thead",null,o().createElement("tr",null,t.map(((e,t)=>{let n=e.width?e.width:b;return o().createElement(c,{width:n,key:"heading_"+t},e.value)})),this.actions&&o().createElement(c,{key:"actions_heading"},"Actions"))),o().createElement("tbody",null,t.length>0&&this.state.rows.map(((e,n)=>Array.isArray(e)&&e.length!==t.length?(console.warn(`Data at row ${n} is ${e.length}. It should be ${t.length}.`),o().createElement("tr",null)):o().createElement(p,{even:n%2==0,key:"row_"+e.id,id:e.id},((e,t,n,a)=>{var r=t.map(((t,r)=>o().createElement(d,{shouldUseTextArea:a,key:e.id+"_field"+r,name:t.columnKey,id:e.id,is_edit:e.is_edit,handleChange:n.handleChange},e[t.columnKey])));return n&&r.push(o().createElement(h,{key:"actions_"+e.id,id:e.id,actions:n})),r})(e,t,this.actions,a)))),o().createElement(p,{even:0,id:"new_row",key:"new_row"},((e,t,n,a,r)=>{var s=e.map(((e,n)=>{let s=void 0!==t[e.columnKey]?t[e.columnKey]:"";return o().createElement("td",{key:"new_row_"+n},r&&o().createElement("textarea",{className:"form-control",id:"new_"+e.columnKey,name:e.columnKey,onChange:a,value:s}),!r&&o().createElement("input",{className:"form-control",id:"new_"+e.columnKey,name:e.columnKey,onChange:a,value:s}))}));return s.push(o().createElement("td",{key:"add_new"},o().createElement("button",{className:"btn btn-default",onClick:n}," Add "))),s})(t,this.state.new_row,this.saveNewRow,this.handleNewChange,a)))),o().createElement(v.Tooltip,{delayShow:10}))}}return a})()));
1
+ !function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("openstack-uicore-foundation",[],t):"object"==typeof exports?exports["openstack-uicore-foundation"]=t():e["openstack-uicore-foundation"]=t()}(this,(()=>(()=>{"use strict";var e={9128:(e,t,n)=>{n.d(t,{shallowEqual:()=>a});require("@sentry/react");n(5812),n(8041);const a=(e,t)=>{const n=Object.keys(e),a=Object.keys(t);if(n.length!==a.length)return!1;for(let a of n)if(e[a]!==t[a])return!1;return!0}},1116:e=>{e.exports=require("@babel/runtime/helpers/defineProperty")},6842:e=>{e.exports=require("i18n-react/dist/i18n-react")},5812:e=>{e.exports=require("moment-timezone")},2015:e=>{e.exports=require("react")},5433:e=>{e.exports=require("react-tooltip")},9236:e=>{e.exports=require("sweetalert2")},8041:e=>{e.exports=require("urijs")}},t={};function n(a){var r=t[a];if(void 0!==r)return r.exports;var s=t[a]={exports:{}};return e[a](s,s.exports,n),s.exports}(()=>{n.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return n.d(t,{a:t}),t}})(),(()=>{n.d=(e,t)=>{for(var a in t)n.o(t,a)&&!n.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:t[a]})}})(),(()=>{n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t)})(),(()=>{n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})}})();var a={};n.r(a),n.d(a,{default:()=>E});var r=n(1116),s=n.n(r),i=n(2015),o=n.n(i);class l extends o().Component{constructor(e){super(e)}render(){return o().createElement("th",{width:this.props.width},this.props.children)}}const c=l,d=e=>e.is_edit?o().createElement("td",null,!e.shouldUseTextArea&&o().createElement("input",{type:"text",className:"form-control",defaultValue:e.children,name:e.name,id:e.id,onChange:e.handleChange}),e.shouldUseTextArea&&o().createElement("textarea",{className:"form-control",defaultValue:e.children,name:e.name,id:e.id,onChange:e.handleChange})):o().createElement("td",null,e.children);class h extends o().Component{constructor(e){super(e),this.state={is_editing:!1}}onDelete(e,t){t.preventDefault(),t.stopPropagation(),this.props.actions.delete(e)}onSave(e,t){t.preventDefault(),t.stopPropagation(),this.setState({is_editing:!1}),this.props.actions.save(e)}onEdit(e,t){t.preventDefault(),t.stopPropagation(),this.setState({is_editing:!0}),this.props.actions.edit(e)}onCancel(e,t){t.preventDefault(),t.stopPropagation(),this.setState({is_editing:!1}),this.props.actions.cancel(e)}render(){let{actions:e,id:t}=this.props;return this.state.is_editing?o().createElement("td",{className:"actions"},o().createElement("a",{href:"",onClick:this.onSave.bind(this,t),"data-tip":"save"},o().createElement("i",{className:"fa fa-floppy-o"})),o().createElement("a",{href:"",onClick:this.onCancel.bind(this,t),"data-tip":"cancel"},o().createElement("i",{className:"fa fa-times"}))):o().createElement("td",{className:"actions"},"edit"in e&&o().createElement("a",{href:"",onClick:this.onEdit.bind(this,t),"data-tip":"edit"},o().createElement("i",{className:"fa fa-pencil-square-o"})),"delete"in e&&o().createElement("a",{href:"",onClick:this.onDelete.bind(this,t),"data-tip":"delete"},o().createElement("i",{className:"fa fa-trash-o delete-icon"})))}}class p extends o().Component{render(){const{children:e,even:t,id:n}=this.props;return o().createElement("tr",{id:n,role:"row",className:t?"even":"odd"},e)}}var u=n(9236),m=n.n(u),w=n(6842),f=n.n(w),v=n(5433),y=n(9128);function g(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,a)}return n}const b="";class E extends o().Component{constructor(e){var t,n;super(e),this.state={rows:e.data,new_row:{}},this.onSave=null===(t=e.options.actions)||void 0===t||null===(n=t.save)||void 0===n?void 0:n.onClick,this.actions=e.options.actions||{},this.actions.edit=this.editRow.bind(this),this.actions.save=this.saveRow.bind(this),this.actions.delete=this.deleteClick.bind(this),this.actions.handleChange=this.onChangeCell.bind(this),this.actions.cancel=this.editRowCancel.bind(this),this.saveNewRow=this.saveNewRow.bind(this),this.handleNewChange=this.onChangeNewCell.bind(this)}componentDidUpdate(e,t,n){(0,y.shallowEqual)(this.props.data,e.data)||this.setState({rows:this.props.data})}saveRow(e,t){const{rows:n}=this.state;let a=n.find((t=>t.id==e));a.is_edit=!1,this.editing_row=null,this.setState({rows:n}),this.onSave(a)}deleteClick(e){var t,n;let a=null===(t=this.props.options.actions)||void 0===t||null===(n=t.delete)||void 0===n?void 0:n.onClick;this.props.options.hasOwnProperty("noAlert")?a(e):m().fire({title:f().translate("general.are_you_sure"),text:f().translate("general.remove_warning"),type:"warning",showCancelButton:!0,confirmButtonColor:"#DD6B55",confirmButtonText:f().translate("general.yes_delete")}).then((function(t){t.value&&a(e)}))}editRow(e,t){const{rows:n}=this.state;let a=n.find((t=>t.id==e));this.editing_row=function(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?g(Object(n),!0).forEach((function(t){s()(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):g(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}({},a),a.is_edit=!0,this.setState({rows:n})}editRowCancel(e,t){const{rows:n}=this.state;n.forEach((e=>{e.is_edit=!1}));let a=n.findIndex((t=>t.id==e));n[a]=this.editing_row,this.setState({rows:n})}onChangeCell(e){const{rows:t}=this.state;let n=e.target;t.find((e=>e.id==n.id))[n.name]=n.value,this.setState({rows:t})}onChangeNewCell(e){const{new_row:t}=this.state;let n=e.target;t[n.name]=n.value,this.setState({new_row:t})}saveNewRow(e){const{new_row:t}=this.state;e.preventDefault(),this.onSave(t),this.setState({new_row:{}})}render(){let{options:e,columns:t}=this.props,n=e.hasOwnProperty("className")?e.className:"",a=this.props.hasOwnProperty("textArea");return o().createElement("div",null,o().createElement("table",{className:"table table-striped table-bordered editableTable "+n},o().createElement("thead",null,o().createElement("tr",null,t.map(((e,t)=>{let n=e.width?e.width:b;return o().createElement(c,{width:n,key:"heading_"+t},e.value)})),this.actions&&o().createElement(c,{key:"actions_heading"},"Actions"))),o().createElement("tbody",null,t.length>0&&this.state.rows.map(((e,n)=>Array.isArray(e)&&e.length!==t.length?(console.warn(`Data at row ${n} is ${e.length}. It should be ${t.length}.`),o().createElement("tr",null)):o().createElement(p,{even:n%2==0,key:"row_"+e.id,id:e.id},((e,t,n,a)=>{var r=t.map(((t,r)=>o().createElement(d,{shouldUseTextArea:a,key:e.id+"_field"+r,name:t.columnKey,id:e.id,is_edit:e.is_edit,handleChange:n.handleChange},e[t.columnKey])));return n&&r.push(o().createElement(h,{key:"actions_"+e.id,id:e.id,actions:n})),r})(e,t,this.actions,a)))),o().createElement(p,{even:0,id:"new_row",key:"new_row"},((e,t,n,a,r)=>{var s=e.map(((e,n)=>{let s=void 0!==t[e.columnKey]?t[e.columnKey]:"";return o().createElement("td",{key:"new_row_"+n},r&&o().createElement("textarea",{className:"form-control",id:"new_"+e.columnKey,name:e.columnKey,onChange:a,value:s}),!r&&o().createElement("input",{className:"form-control",id:"new_"+e.columnKey,name:e.columnKey,onChange:a,value:s}))}));return s.push(o().createElement("td",{key:"add_new"},o().createElement("button",{className:"btn btn-default",onClick:n}," Add "))),s})(t,this.state.new_row,this.saveNewRow,this.handleNewChange,a)))),o().createElement(v.Tooltip,{delayShow:10}))}}return a})()));
2
2
  //# sourceMappingURL=table-editable.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"components/table-editable.js","mappings":"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","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/./src/utils/methods.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/defineProperty\"","webpack://openstack-uicore-foundation/external commonjs \"i18n-react/dist/i18n-react\"","webpack://openstack-uicore-foundation/external commonjs \"moment-timezone\"","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/external commonjs \"react-tooltip\"","webpack://openstack-uicore-foundation/external commonjs \"sweetalert2\"","webpack://openstack-uicore-foundation/external commonjs \"urijs\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableTableHeading.js","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableActionsTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableTableRow.js","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableTable.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","/**\n * Copyright 2018 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport moment from 'moment-timezone';\nimport URI from \"urijs\";\n\nexport const findElementPos = (obj) => {\n var curtop = -70;\n if (obj.offsetParent) {\n do {\n curtop += obj.offsetTop;\n } while (obj = obj.offsetParent);\n return [curtop];\n }\n};\n\nexport const epochToMoment = (atime) => {\n if(!atime) return atime;\n atime = atime * 1000;\n return moment(atime);\n};\n\nexport const epochToMomentTimeZone = (atime, time_zone) => {\n if(!atime) return atime;\n atime = atime * 1000;\n return moment(atime).tz(time_zone);\n};\n\nexport const formatEpoch = (atime, format = 'M/D/YYYY h:mm a') => {\n if(!atime) return atime;\n return epochToMoment(atime).format(format);\n};\n\nexport const parseLocationHour = (hour) => {\n let parsedHour = hour.toString();\n if(parsedHour.length < 4) parsedHour = `0${parsedHour}`;\n parsedHour = parsedHour.match(/.{2}/g);\n parsedHour = parsedHour.join(':');\n return parsedHour;\n}\n\nexport const objectToQueryString = (obj) => {\n var str = \"\";\n for (var key in obj) {\n if (str != \"\") {\n str += \"&\";\n }\n str += key + \"=\" + encodeURIComponent(obj[key]);\n }\n\n return str;\n};\n\nexport const getBackURL = () => {\n let url = URI(window.location.href);\n let query = url.search(true);\n let fragment = url.fragment();\n let backUrl = query.hasOwnProperty('BackUrl') ? query['BackUrl'] : null;\n if(backUrl != null && fragment != null && fragment != ''){\n backUrl += `#${fragment}`;\n }\n return backUrl;\n};\n\nexport const toSlug = (text) =>{\n text = text.toLowerCase();\n return text.replace(/[^a-zA-Z0-9]+/g,'_');\n}\n\nexport const getAuthCallback = () => {\n if(typeof window !== 'undefined') {\n return `${window.location.origin}/auth/callback`;\n }\n return null;\n};\n\nexport const getCurrentLocation = () => {\n let location = '';\n if(typeof window !== 'undefined') {\n location = window.location;\n // check if we are on iframe\n if (window.top)\n location = window.top.location;\n }\n return location;\n};\n\nexport const getOrigin = () => {\n if(typeof window !== 'undefined') {\n return window.location.origin;\n }\n return null;\n};\n\nexport const getCurrentPathName = () => {\n if(typeof window !== 'undefined') {\n return window.location.pathname;\n }\n return null;\n};\n\nexport const getCurrentHref = () => {\n if(typeof window !== 'undefined') {\n return window.location.href;\n }\n return null;\n};\n\nexport const getAllowedUserGroups = () => {\n if(typeof window !== 'undefined') {\n return window.ALLOWED_USER_GROUPS || '';\n }\n return null;\n};\n\nexport const buildAPIBaseUrl = (relativeUrl) => {\n if(typeof window !== 'undefined'){\n return `${window.API_BASE_URL}${relativeUrl}`;\n }\n return null``;\n};\n\nexport const putOnLocalStorage = (key, value) => {\n if(typeof window !== 'undefined') {\n window.localStorage.setItem(key, value);\n }\n};\n\nexport const getFromLocalStorage = (key, removeIt) => {\n if(typeof window !== 'undefined') {\n let val = window.localStorage.getItem(key);\n if(removeIt){\n console.log(`getFromLocalStorage removing key ${key}`);\n removeFromLocalStorage(key);\n }\n return val;\n }\n return null;\n};\n\nexport const removeFromLocalStorage = (key) => {\n if(typeof window !== 'undefined') {\n window.localStorage.removeItem(key);\n }\n}\n\nexport const isClearingSessionState = () => {\n if(typeof window !== 'undefined') {\n return window.clearing_session_state;\n }\n return false;\n};\n\nexport const setSessionClearingState = (val) => {\n if(typeof window !== 'undefined') {\n window.clearing_session_state = val;\n }\n};\n\nexport const getCurrentUserLanguage = () => {\n let language = 'en';\n if(typeof navigator !== 'undefined') {\n language = (navigator.languages && navigator.languages[0]) || navigator.language || navigator.userLanguage;\n }\n return language;\n};\n\nexport const scrollToError = (errors) => {\n if(Object.keys(errors).length > 0) {\n const firstError = Object.keys(errors)[0];\n const firstNode = document.getElementById(firstError);\n if (firstNode) window.scrollTo(0, findElementPos(firstNode));\n }\n};\n\nexport const hasErrors = (field, errors) => {\n if(field in errors) {\n return errors[field];\n }\n return '';\n};\n\nexport const shallowEqual = (object1, object2) => {\n const keys1 = Object.keys(object1);\n const keys2 = Object.keys(object2);\n\n if (keys1.length !== keys2.length) {\n return false;\n }\n\n for (let key of keys1) {\n if (object1[key] !== object2[key]) {\n return false;\n }\n }\n\n return true;\n};\n\nexport const arraysEqual = (a1, a2) =>\n a1.length === a2.length && a1.every((o, idx) => shallowEqual(o, a2[idx]));\n\nexport const isEmpty = (obj) => {\n return Object.keys(obj).length === 0;\n};\n\n\nexport const base64URLEncode = (str) => {\n return str\n .toString('base64')\n .replace(/\\+/g, '-')\n .replace(/\\//g, '_')\n .replace(/=/g, '')\n}\n\nexport const retryPromise = async (\n cb,\n maxNumberOfRetries = 3\n) => {\n for (let i = 0; i < maxNumberOfRetries; i++) {\n if (await cb()) {\n return true;\n }\n }\n\n return false;\n}\n\nexport const getTimeServiceUrl = () => {\n if(typeof window !== 'undefined') {\n return window.TIMEINTERVALSINCE1970_API_URL || process.env.TIMEINTERVALSINCE1970_API_URL;\n }\n return null;\n};\n\nexport const getEventLocation = (event, summitVenueCount, summitShowLocDate = null, nowUtc = null) => {\n const shouldShowVenues = (summitShowLocDate && nowUtc) ? summitShowLocDate * 1000 < nowUtc : true;\n const locationName = [];\n const { location } = event;\n\n if (!shouldShowVenues) return 'TBA';\n\n if (!location) return 'TBA';\n\n if (summitVenueCount > 1 && location.venue?.name) locationName.push(location.venue.name);\n if (location.floor?.name) locationName.push(location.floor.name);\n if (location.name) locationName.push(location.name);\n\n return locationName.length > 0 ? locationName.join(' - ') : 'TBA';\n};\n\nexport const getEventHosts = (event) => {\n let hosts = [];\n if (event.speakers?.length > 0) {\n hosts = [...event.speakers];\n }\n if (event.moderator) hosts.push(event.moderator);\n\n return hosts;\n};\n\nconst loadImage = async url => {\n const img = document.createElement('img')\n img.src = url\n img.crossOrigin = 'anonymous'\n\n return new Promise((resolve, reject) => {\n img.onload = () => resolve(img)\n img.onerror = reject\n })\n}\n\nexport const convertSVGtoImg = async (svgUrl) => {\n const img = await loadImage(svgUrl)\n const newWidth = 100\n const newHeight = Math.floor(img.naturalHeight * 100 / img.naturalWidth)\n\n const canvas = document.createElement('canvas')\n canvas.width = newWidth\n canvas.height = newHeight\n canvas.getContext('2d').drawImage(img, 0, 0, newWidth, newHeight)\n\n const url = await canvas.toDataURL(`image/png`, 1.0)\n console.log(url, newWidth, newHeight);\n return {url, width: newWidth, height: newHeight}\n}\n\nexport const isRateEnabled = (value) =>\n value !== null && value !== undefined && value !== \"\";\n","module.exports = require(\"@babel/runtime/helpers/defineProperty\");","module.exports = require(\"i18n-react/dist/i18n-react\");","module.exports = require(\"moment-timezone\");","module.exports = require(\"react\");","module.exports = require(\"react-tooltip\");","module.exports = require(\"sweetalert2\");","module.exports = require(\"urijs\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import React from 'react';\n\nclass EditableTableHeading extends React.Component {\n\n constructor (props) {\n super(props);\n }\n\n render () {\n return (\n <th width={this.props.width}>\n {this.props.children}\n </th>\n );\n }\n\n}\n\nexport default EditableTableHeading;","import React from 'react';\n\nconst EditableTableCell = (props) => {\n\n if (props.is_edit) {\n return (\n <td>\n {!props.shouldUseTextArea &&\n <input type=\"text\" className=\"form-control\" defaultValue={props.children} name={props.name} id={props.id} onChange={props.handleChange}/>\n }\n {props.shouldUseTextArea &&\n <textarea className=\"form-control\" defaultValue={props.children} name={props.name} id={props.id} onChange={props.handleChange}/>\n }\n </td>\n );\n } else {\n return (\n <td>{props.children}</td>\n );\n }\n\n};\n\nexport default EditableTableCell;","import React from 'react';\n\nexport default class EditableActionsTableCell extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.state = {\n is_editing: false\n }\n\n }\n\n onDelete(id, ev) {\n ev.preventDefault();\n ev.stopPropagation();\n\n this.props.actions.delete(id);\n }\n\n onSave(id, ev) {\n ev.preventDefault();\n ev.stopPropagation();\n\n this.setState({\n is_editing: false\n });\n\n this.props.actions.save(id);\n }\n\n onEdit(id, ev) {\n ev.preventDefault();\n ev.stopPropagation();\n\n this.setState({\n is_editing: true\n });\n\n this.props.actions.edit(id);\n }\n\n onCancel(id, ev) {\n ev.preventDefault();\n ev.stopPropagation();\n\n this.setState({\n is_editing: false\n });\n\n this.props.actions.cancel(id);\n }\n\n render() {\n let {actions, id} = this.props;\n\n if (this.state.is_editing) {\n return (\n <td className=\"actions\">\n <a href=\"\" onClick={this.onSave.bind(this,id)} data-tip=\"save\" >\n <i className=\"fa fa-floppy-o\"></i>\n </a>\n <a href=\"\" onClick={this.onCancel.bind(this,id)} data-tip=\"cancel\" >\n <i className=\"fa fa-times\"></i>\n </a>\n </td>\n );\n } else {\n return (\n <td className=\"actions\">\n {'edit' in actions &&\n <a href=\"\" onClick={this.onEdit.bind(this,id)} data-tip=\"edit\" >\n <i className=\"fa fa-pencil-square-o\"></i>\n </a>\n }\n {'delete' in actions &&\n <a href=\"\" onClick={this.onDelete.bind(this,id)} data-tip=\"delete\" >\n <i className=\"fa fa-trash-o delete-icon\"></i>\n </a>\n }\n </td>\n );\n }\n }\n};\n","import React from 'react';\n\nexport default class EditableTableRow extends React.Component {\n\n render() {\n const { children, even, id } = this.props;\n\n return (\n <tr id={id} role=\"row\" className={even ? 'even' : 'odd'}>\n {children}\n </tr>\n );\n }\n}\n","import React from 'react';\nimport EditableTableHeading from './EditableTableHeading';\nimport EditableTableCell from './EditableTableCell';\nimport EditableActionsTableCell from './EditableActionsTableCell';\nimport EditableTableRow from './EditableTableRow';\nimport Swal from \"sweetalert2\";\nimport T from \"i18n-react/dist/i18n-react\";\nimport { Tooltip } from \"react-tooltip\";\nimport { shallowEqual } from '../../utils/methods'\n\nimport './editable-table.less';\n\n\nconst defaults = {\n colWidth: ''\n};\n\nconst createRow = (row, columns, actions, shouldUseTextArea) => {\n\n var action_buttons = '';\n var cells = columns.map((col,i) => {\n return (\n <EditableTableCell shouldUseTextArea={shouldUseTextArea} key={row['id'] + '_field' + i} name={col.columnKey} id={row.id} is_edit={row.is_edit} handleChange={actions.handleChange}>\n {row[col.columnKey]}\n </EditableTableCell>\n );\n });\n\n if (actions) {\n cells.push(<EditableActionsTableCell key={'actions_' + row['id']} id={row['id']} actions={actions}/>);\n }\n\n return cells;\n};\n\nconst createNewRow = (columns, new_row, addNew, handleChange, shouldUseTextArea) => {\n\n var cells = columns.map((col,i) => {\n let cell_value = (typeof new_row[col.columnKey] !== 'undefined') ? new_row[col.columnKey] : '';\n return (\n <td key={'new_row_' + i}>\n {shouldUseTextArea &&\n <textarea className=\"form-control\" id={'new_' + col.columnKey} name={col.columnKey} onChange={handleChange}\n value={cell_value}/>\n }\n {!shouldUseTextArea &&\n <input className=\"form-control\" id={'new_' + col.columnKey} name={col.columnKey} onChange={handleChange}\n value={cell_value}/>\n }\n </td>\n );\n });\n\n cells.push(\n <td key='add_new'>\n <button className=\"btn btn-default\" onClick={addNew}> Add </button>\n </td>\n );\n\n return cells;\n};\n\n\nexport default class EditableTable extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.state = {\n rows: props.data,\n new_row: {}\n };\n\n // we store the delete and save functions in props cause we need to extend them\n this.onSave = props.options.actions?.save?.onClick;\n\n this.actions = props.options.actions || {};\n this.actions.edit = this.editRow.bind(this);\n this.actions.save = this.saveRow.bind(this);\n this.actions.delete = this.deleteClick.bind(this);\n this.actions.handleChange = this.onChangeCell.bind(this);\n this.actions.cancel = this.editRowCancel.bind(this);\n\n this.saveNewRow = this.saveNewRow.bind(this);\n this.handleNewChange = this.onChangeNewCell.bind(this);\n }\n\n componentDidUpdate(prevProps, prevState, snapshot) {\n if(!shallowEqual(this.props.data, prevProps.data)) {\n this.setState({rows: this.props.data})\n }\n }\n\n saveRow(id, ev) {\n const { rows } = this.state;\n let row = rows.find(r => r.id == id);\n row.is_edit = false;\n\n this.editing_row = null;\n\n this.setState({\n rows: rows\n });\n\n this.onSave(row);\n }\n\n deleteClick(id) {\n let onDelete = this.props.options.actions?.delete?.onClick;\n let noAlert = this.props.options.hasOwnProperty('noAlert');\n\n if (noAlert) {\n onDelete(id);\n } else {\n Swal.fire({\n title: T.translate(\"general.are_you_sure\"),\n text: T.translate(\"general.remove_warning\"),\n type: \"warning\",\n showCancelButton: true,\n confirmButtonColor: \"#DD6B55\",\n confirmButtonText: T.translate(\"general.yes_delete\")\n }).then(function(result){\n if (result.value) {\n onDelete(id);\n }\n });\n }\n }\n\n editRow(id, ev) {\n const { rows } = this.state;\n let row = rows.find(r => r.id == id);\n\n //save editing row for cancel\n this.editing_row = {...row};\n\n row.is_edit = true;\n\n this.setState({\n rows: rows\n });\n }\n\n editRowCancel(id, ev) {\n const { rows } = this.state;\n rows.forEach(r => {\n r.is_edit = false;\n });\n\n let rowIdx = rows.findIndex(r => r.id == id);\n\n rows[rowIdx] = this.editing_row;\n\n this.setState({\n rows: rows\n });\n }\n\n onChangeCell(ev) {\n const { rows } = this.state;\n let field = ev.target;\n let row = rows.find(r => r.id == field.id);\n\n row[field.name] = field.value;\n\n this.setState({\n rows: rows\n });\n }\n\n onChangeNewCell(ev) {\n const {new_row} = this.state;\n let field = ev.target;\n\n new_row[field.name] = field.value;\n\n this.setState({\n new_row: new_row\n });\n }\n\n saveNewRow(ev) {\n const {new_row} = this.state;\n ev.preventDefault();\n\n this.onSave(new_row);\n\n this.setState({\n new_row: {}\n });\n }\n\n render() {\n let {options, columns } = this.props;\n let tableClass = options.hasOwnProperty('className') ? options.className : '';\n let textArea = this.props.hasOwnProperty(\"textArea\");\n return (\n <div>\n <table className={\"table table-striped table-bordered editableTable \" + tableClass}>\n <thead>\n <tr>\n {columns.map((col,i) => {\n let colWidth = (col.width) ? col.width : defaults.colWidth;\n return (\n <EditableTableHeading width={colWidth} key={'heading_' + i} >\n {col.value}\n </EditableTableHeading>\n );\n })}\n {this.actions &&\n <EditableTableHeading key='actions_heading' >\n Actions\n </EditableTableHeading>\n }\n </tr>\n </thead>\n <tbody>\n {columns.length > 0 && this.state.rows.map((row,i) => {\n if(Array.isArray(row) && row.length !== columns.length) {\n console.warn(`Data at row ${i} is ${row.length}. It should be ${columns.length}.`);\n return <tr />\n }\n return (\n <EditableTableRow even={i%2 === 0} key={'row_' + row.id} id={row.id} >\n {createRow(row, columns, this.actions, textArea)}\n </EditableTableRow>\n\n );\n })}\n <EditableTableRow even={0} id='new_row' key='new_row'>\n {createNewRow(columns, this.state.new_row, this.saveNewRow, this.handleNewChange, textArea)}\n </EditableTableRow>\n </tbody>\n </table>\n <Tooltip delayShow={10} />\n </div>\n );\n }\n};\n"],"names":["root","factory","exports","module","define","amd","this","shallowEqual","object1","object2","keys1","Object","keys","keys2","length","key","require","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","o","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","EditableTableHeading","React","constructor","props","super","render","width","children","is_edit","shouldUseTextArea","type","className","defaultValue","name","id","onChange","handleChange","EditableActionsTableCell","state","is_editing","onDelete","ev","preventDefault","stopPropagation","actions","delete","onSave","setState","save","onEdit","edit","onCancel","cancel","href","onClick","bind","EditableTableRow","even","role","defaults","EditableTable","rows","data","new_row","options","editRow","saveRow","deleteClick","onChangeCell","editRowCancel","saveNewRow","handleNewChange","onChangeNewCell","componentDidUpdate","prevProps","prevState","snapshot","row","find","editing_row","Swal","title","T","text","showCancelButton","confirmButtonColor","confirmButtonText","then","result","forEach","rowIdx","findIndex","field","target","columns","tableClass","textArea","map","col","i","colWidth","Array","isArray","console","warn","cells","columnKey","push","createRow","addNew","cell_value","createNewRow","Tooltip","delayShow"],"sourceRoot":""}
1
+ {"version":3,"file":"components/table-editable.js","mappings":"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","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/external commonjs \"@sentry/react\"","webpack://openstack-uicore-foundation/./src/utils/methods.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/defineProperty\"","webpack://openstack-uicore-foundation/external commonjs \"i18n-react/dist/i18n-react\"","webpack://openstack-uicore-foundation/external commonjs \"moment-timezone\"","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/external commonjs \"react-tooltip\"","webpack://openstack-uicore-foundation/external commonjs \"sweetalert2\"","webpack://openstack-uicore-foundation/external commonjs \"urijs\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableTableHeading.js","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableActionsTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableTableRow.js","webpack://openstack-uicore-foundation/./src/components/table-editable/EditableTable.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"@sentry/react\");","/**\n * Copyright 2018 OpenStack Foundation\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n **/\n\nimport * as Sentry from \"@sentry/react\";\nimport moment from 'moment-timezone';\nimport URI from \"urijs\";\n\nexport const findElementPos = (obj) => {\n var curtop = -70;\n if (obj.offsetParent) {\n do {\n curtop += obj.offsetTop;\n } while (obj = obj.offsetParent);\n return [curtop];\n }\n};\n\nexport const epochToMoment = (atime) => {\n if(!atime) return atime;\n atime = atime * 1000;\n return moment(atime);\n};\n\nexport const epochToMomentTimeZone = (atime, time_zone) => {\n if(!atime) return atime;\n atime = atime * 1000;\n return moment(atime).tz(time_zone);\n};\n\nexport const formatEpoch = (atime, format = 'M/D/YYYY h:mm a') => {\n if(!atime) return atime;\n return epochToMoment(atime).format(format);\n};\n\nexport const parseLocationHour = (hour) => {\n let parsedHour = hour.toString();\n if(parsedHour.length < 4) parsedHour = `0${parsedHour}`;\n parsedHour = parsedHour.match(/.{2}/g);\n parsedHour = parsedHour.join(':');\n return parsedHour;\n}\n\nexport const objectToQueryString = (obj) => {\n var str = \"\";\n for (var key in obj) {\n if (str != \"\") {\n str += \"&\";\n }\n str += key + \"=\" + encodeURIComponent(obj[key]);\n }\n\n return str;\n};\n\nexport const getBackURL = () => {\n let url = URI(window.location.href);\n let query = url.search(true);\n let fragment = url.fragment();\n let backUrl = query.hasOwnProperty('BackUrl') ? query['BackUrl'] : null;\n if(backUrl != null && fragment != null && fragment != ''){\n backUrl += `#${fragment}`;\n }\n return backUrl;\n};\n\nexport const toSlug = (text) =>{\n text = text.toLowerCase();\n return text.replace(/[^a-zA-Z0-9]+/g,'_');\n}\n\nexport const getAuthCallback = () => {\n if(typeof window !== 'undefined') {\n return `${window.location.origin}/auth/callback`;\n }\n return null;\n};\n\nexport const getCurrentLocation = () => {\n let location = '';\n if(typeof window !== 'undefined') {\n location = window.location;\n // check if we are on iframe\n if (window.top)\n location = window.top.location;\n }\n return location;\n};\n\nexport const getOrigin = () => {\n if(typeof window !== 'undefined') {\n return window.location.origin;\n }\n return null;\n};\n\nexport const getCurrentPathName = () => {\n if(typeof window !== 'undefined') {\n return window.location.pathname;\n }\n return null;\n};\n\nexport const getCurrentHref = () => {\n if(typeof window !== 'undefined') {\n return window.location.href;\n }\n return null;\n};\n\nexport const getAllowedUserGroups = () => {\n if(typeof window !== 'undefined') {\n return window.ALLOWED_USER_GROUPS || '';\n }\n return null;\n};\n\nexport const buildAPIBaseUrl = (relativeUrl) => {\n if(typeof window !== 'undefined'){\n return `${window.API_BASE_URL}${relativeUrl}`;\n }\n return null``;\n};\n\nexport const putOnLocalStorage = (key, value) => {\n if(typeof window !== 'undefined') {\n window.localStorage.setItem(key, value);\n }\n};\n\nexport const getFromLocalStorage = (key, removeIt) => {\n if(typeof window !== 'undefined') {\n let val = window.localStorage.getItem(key);\n if(removeIt){\n console.log(`getFromLocalStorage removing key ${key}`);\n removeFromLocalStorage(key);\n }\n return val;\n }\n return null;\n};\n\nexport const removeFromLocalStorage = (key) => {\n if(typeof window !== 'undefined') {\n window.localStorage.removeItem(key);\n }\n}\n\nexport const isClearingSessionState = () => {\n if(typeof window !== 'undefined') {\n return window.clearing_session_state;\n }\n return false;\n};\n\nexport const setSessionClearingState = (val) => {\n if(typeof window !== 'undefined') {\n window.clearing_session_state = val;\n }\n};\n\nexport const getCurrentUserLanguage = () => {\n let language = 'en';\n if(typeof navigator !== 'undefined') {\n language = (navigator.languages && navigator.languages[0]) || navigator.language || navigator.userLanguage;\n }\n return language;\n};\n\nexport const scrollToError = (errors) => {\n if(Object.keys(errors).length > 0) {\n const firstError = Object.keys(errors)[0];\n const firstNode = document.getElementById(firstError);\n if (firstNode) window.scrollTo(0, findElementPos(firstNode));\n }\n};\n\nexport const hasErrors = (field, errors) => {\n if(field in errors) {\n return errors[field];\n }\n return '';\n};\n\nexport const shallowEqual = (object1, object2) => {\n const keys1 = Object.keys(object1);\n const keys2 = Object.keys(object2);\n\n if (keys1.length !== keys2.length) {\n return false;\n }\n\n for (let key of keys1) {\n if (object1[key] !== object2[key]) {\n return false;\n }\n }\n\n return true;\n};\n\nexport const arraysEqual = (a1, a2) =>\n a1.length === a2.length && a1.every((o, idx) => shallowEqual(o, a2[idx]));\n\nexport const isEmpty = (obj) => {\n return Object.keys(obj).length === 0;\n};\n\n\nexport const base64URLEncode = (str) => {\n return str\n .toString('base64')\n .replace(/\\+/g, '-')\n .replace(/\\//g, '_')\n .replace(/=/g, '')\n}\n\nexport const retryPromise = async (\n cb,\n maxNumberOfRetries = 3\n) => {\n for (let i = 0; i < maxNumberOfRetries; i++) {\n if (await cb()) {\n return true;\n }\n }\n\n return false;\n}\n\nexport const getTimeServiceUrl = () => {\n if(typeof window !== 'undefined') {\n return window.TIMEINTERVALSINCE1970_API_URL || process.env.TIMEINTERVALSINCE1970_API_URL;\n }\n return null;\n};\n\nexport const getEventLocation = (event, summitVenueCount, summitShowLocDate = null, nowUtc = null) => {\n const shouldShowVenues = (summitShowLocDate && nowUtc) ? summitShowLocDate * 1000 < nowUtc : true;\n const locationName = [];\n const { location } = event;\n\n if (!shouldShowVenues) return 'TBA';\n\n if (!location) return 'TBA';\n\n if (summitVenueCount > 1 && location.venue?.name) locationName.push(location.venue.name);\n if (location.floor?.name) locationName.push(location.floor.name);\n if (location.name) locationName.push(location.name);\n\n return locationName.length > 0 ? locationName.join(' - ') : 'TBA';\n};\n\nexport const getEventHosts = (event) => {\n let hosts = [];\n if (event.speakers?.length > 0) {\n hosts = [...event.speakers];\n }\n if (event.moderator) hosts.push(event.moderator);\n\n return hosts;\n};\n\nconst loadImage = async url => {\n const img = document.createElement('img')\n img.src = url\n img.crossOrigin = 'anonymous'\n\n return new Promise((resolve, reject) => {\n img.onload = () => resolve(img)\n img.onerror = reject\n })\n}\n\nexport const convertSVGtoImg = async (svgUrl) => {\n const img = await loadImage(svgUrl)\n const newWidth = 100\n const newHeight = Math.floor(img.naturalHeight * 100 / img.naturalWidth)\n\n const canvas = document.createElement('canvas')\n canvas.width = newWidth\n canvas.height = newHeight\n canvas.getContext('2d').drawImage(img, 0, 0, newWidth, newHeight)\n\n const url = await canvas.toDataURL(`image/png`, 1.0)\n console.log(url, newWidth, newHeight);\n return {url, width: newWidth, height: newHeight}\n}\n\nexport const isRateEnabled = (value) =>\n value !== null && value !== undefined && value !== \"\";\n\nconst isSentryInitialized = () => typeof window !== \"undefined\" && !!window.SENTRY_DSN;\n\nexport const handleSentryException = (err) =>\n isSentryInitialized()\n ? Sentry.captureException(err)\n : console.log(\"Error on registration: \", err);","module.exports = require(\"@babel/runtime/helpers/defineProperty\");","module.exports = require(\"i18n-react/dist/i18n-react\");","module.exports = require(\"moment-timezone\");","module.exports = require(\"react\");","module.exports = require(\"react-tooltip\");","module.exports = require(\"sweetalert2\");","module.exports = require(\"urijs\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import React from 'react';\n\nclass EditableTableHeading extends React.Component {\n\n constructor (props) {\n super(props);\n }\n\n render () {\n return (\n <th width={this.props.width}>\n {this.props.children}\n </th>\n );\n }\n\n}\n\nexport default EditableTableHeading;","import React from 'react';\n\nconst EditableTableCell = (props) => {\n\n if (props.is_edit) {\n return (\n <td>\n {!props.shouldUseTextArea &&\n <input type=\"text\" className=\"form-control\" defaultValue={props.children} name={props.name} id={props.id} onChange={props.handleChange}/>\n }\n {props.shouldUseTextArea &&\n <textarea className=\"form-control\" defaultValue={props.children} name={props.name} id={props.id} onChange={props.handleChange}/>\n }\n </td>\n );\n } else {\n return (\n <td>{props.children}</td>\n );\n }\n\n};\n\nexport default EditableTableCell;","import React from 'react';\n\nexport default class EditableActionsTableCell extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.state = {\n is_editing: false\n }\n\n }\n\n onDelete(id, ev) {\n ev.preventDefault();\n ev.stopPropagation();\n\n this.props.actions.delete(id);\n }\n\n onSave(id, ev) {\n ev.preventDefault();\n ev.stopPropagation();\n\n this.setState({\n is_editing: false\n });\n\n this.props.actions.save(id);\n }\n\n onEdit(id, ev) {\n ev.preventDefault();\n ev.stopPropagation();\n\n this.setState({\n is_editing: true\n });\n\n this.props.actions.edit(id);\n }\n\n onCancel(id, ev) {\n ev.preventDefault();\n ev.stopPropagation();\n\n this.setState({\n is_editing: false\n });\n\n this.props.actions.cancel(id);\n }\n\n render() {\n let {actions, id} = this.props;\n\n if (this.state.is_editing) {\n return (\n <td className=\"actions\">\n <a href=\"\" onClick={this.onSave.bind(this,id)} data-tip=\"save\" >\n <i className=\"fa fa-floppy-o\"></i>\n </a>\n <a href=\"\" onClick={this.onCancel.bind(this,id)} data-tip=\"cancel\" >\n <i className=\"fa fa-times\"></i>\n </a>\n </td>\n );\n } else {\n return (\n <td className=\"actions\">\n {'edit' in actions &&\n <a href=\"\" onClick={this.onEdit.bind(this,id)} data-tip=\"edit\" >\n <i className=\"fa fa-pencil-square-o\"></i>\n </a>\n }\n {'delete' in actions &&\n <a href=\"\" onClick={this.onDelete.bind(this,id)} data-tip=\"delete\" >\n <i className=\"fa fa-trash-o delete-icon\"></i>\n </a>\n }\n </td>\n );\n }\n }\n};\n","import React from 'react';\n\nexport default class EditableTableRow extends React.Component {\n\n render() {\n const { children, even, id } = this.props;\n\n return (\n <tr id={id} role=\"row\" className={even ? 'even' : 'odd'}>\n {children}\n </tr>\n );\n }\n}\n","import React from 'react';\nimport EditableTableHeading from './EditableTableHeading';\nimport EditableTableCell from './EditableTableCell';\nimport EditableActionsTableCell from './EditableActionsTableCell';\nimport EditableTableRow from './EditableTableRow';\nimport Swal from \"sweetalert2\";\nimport T from \"i18n-react/dist/i18n-react\";\nimport { Tooltip } from \"react-tooltip\";\nimport { shallowEqual } from '../../utils/methods'\n\nimport './editable-table.less';\n\n\nconst defaults = {\n colWidth: ''\n};\n\nconst createRow = (row, columns, actions, shouldUseTextArea) => {\n\n var action_buttons = '';\n var cells = columns.map((col,i) => {\n return (\n <EditableTableCell shouldUseTextArea={shouldUseTextArea} key={row['id'] + '_field' + i} name={col.columnKey} id={row.id} is_edit={row.is_edit} handleChange={actions.handleChange}>\n {row[col.columnKey]}\n </EditableTableCell>\n );\n });\n\n if (actions) {\n cells.push(<EditableActionsTableCell key={'actions_' + row['id']} id={row['id']} actions={actions}/>);\n }\n\n return cells;\n};\n\nconst createNewRow = (columns, new_row, addNew, handleChange, shouldUseTextArea) => {\n\n var cells = columns.map((col,i) => {\n let cell_value = (typeof new_row[col.columnKey] !== 'undefined') ? new_row[col.columnKey] : '';\n return (\n <td key={'new_row_' + i}>\n {shouldUseTextArea &&\n <textarea className=\"form-control\" id={'new_' + col.columnKey} name={col.columnKey} onChange={handleChange}\n value={cell_value}/>\n }\n {!shouldUseTextArea &&\n <input className=\"form-control\" id={'new_' + col.columnKey} name={col.columnKey} onChange={handleChange}\n value={cell_value}/>\n }\n </td>\n );\n });\n\n cells.push(\n <td key='add_new'>\n <button className=\"btn btn-default\" onClick={addNew}> Add </button>\n </td>\n );\n\n return cells;\n};\n\n\nexport default class EditableTable extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.state = {\n rows: props.data,\n new_row: {}\n };\n\n // we store the delete and save functions in props cause we need to extend them\n this.onSave = props.options.actions?.save?.onClick;\n\n this.actions = props.options.actions || {};\n this.actions.edit = this.editRow.bind(this);\n this.actions.save = this.saveRow.bind(this);\n this.actions.delete = this.deleteClick.bind(this);\n this.actions.handleChange = this.onChangeCell.bind(this);\n this.actions.cancel = this.editRowCancel.bind(this);\n\n this.saveNewRow = this.saveNewRow.bind(this);\n this.handleNewChange = this.onChangeNewCell.bind(this);\n }\n\n componentDidUpdate(prevProps, prevState, snapshot) {\n if(!shallowEqual(this.props.data, prevProps.data)) {\n this.setState({rows: this.props.data})\n }\n }\n\n saveRow(id, ev) {\n const { rows } = this.state;\n let row = rows.find(r => r.id == id);\n row.is_edit = false;\n\n this.editing_row = null;\n\n this.setState({\n rows: rows\n });\n\n this.onSave(row);\n }\n\n deleteClick(id) {\n let onDelete = this.props.options.actions?.delete?.onClick;\n let noAlert = this.props.options.hasOwnProperty('noAlert');\n\n if (noAlert) {\n onDelete(id);\n } else {\n Swal.fire({\n title: T.translate(\"general.are_you_sure\"),\n text: T.translate(\"general.remove_warning\"),\n type: \"warning\",\n showCancelButton: true,\n confirmButtonColor: \"#DD6B55\",\n confirmButtonText: T.translate(\"general.yes_delete\")\n }).then(function(result){\n if (result.value) {\n onDelete(id);\n }\n });\n }\n }\n\n editRow(id, ev) {\n const { rows } = this.state;\n let row = rows.find(r => r.id == id);\n\n //save editing row for cancel\n this.editing_row = {...row};\n\n row.is_edit = true;\n\n this.setState({\n rows: rows\n });\n }\n\n editRowCancel(id, ev) {\n const { rows } = this.state;\n rows.forEach(r => {\n r.is_edit = false;\n });\n\n let rowIdx = rows.findIndex(r => r.id == id);\n\n rows[rowIdx] = this.editing_row;\n\n this.setState({\n rows: rows\n });\n }\n\n onChangeCell(ev) {\n const { rows } = this.state;\n let field = ev.target;\n let row = rows.find(r => r.id == field.id);\n\n row[field.name] = field.value;\n\n this.setState({\n rows: rows\n });\n }\n\n onChangeNewCell(ev) {\n const {new_row} = this.state;\n let field = ev.target;\n\n new_row[field.name] = field.value;\n\n this.setState({\n new_row: new_row\n });\n }\n\n saveNewRow(ev) {\n const {new_row} = this.state;\n ev.preventDefault();\n\n this.onSave(new_row);\n\n this.setState({\n new_row: {}\n });\n }\n\n render() {\n let {options, columns } = this.props;\n let tableClass = options.hasOwnProperty('className') ? options.className : '';\n let textArea = this.props.hasOwnProperty(\"textArea\");\n return (\n <div>\n <table className={\"table table-striped table-bordered editableTable \" + tableClass}>\n <thead>\n <tr>\n {columns.map((col,i) => {\n let colWidth = (col.width) ? col.width : defaults.colWidth;\n return (\n <EditableTableHeading width={colWidth} key={'heading_' + i} >\n {col.value}\n </EditableTableHeading>\n );\n })}\n {this.actions &&\n <EditableTableHeading key='actions_heading' >\n Actions\n </EditableTableHeading>\n }\n </tr>\n </thead>\n <tbody>\n {columns.length > 0 && this.state.rows.map((row,i) => {\n if(Array.isArray(row) && row.length !== columns.length) {\n console.warn(`Data at row ${i} is ${row.length}. It should be ${columns.length}.`);\n return <tr />\n }\n return (\n <EditableTableRow even={i%2 === 0} key={'row_' + row.id} id={row.id} >\n {createRow(row, columns, this.actions, textArea)}\n </EditableTableRow>\n\n );\n })}\n <EditableTableRow even={0} id='new_row' key='new_row'>\n {createNewRow(columns, this.state.new_row, this.saveNewRow, this.handleNewChange, textArea)}\n </EditableTableRow>\n </tbody>\n </table>\n <Tooltip delayShow={10} />\n </div>\n );\n }\n};\n"],"names":["root","factory","exports","module","define","amd","this","require","shallowEqual","object1","object2","keys1","Object","keys","keys2","length","key","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","o","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","EditableTableHeading","React","constructor","props","super","render","width","children","is_edit","shouldUseTextArea","type","className","defaultValue","name","id","onChange","handleChange","EditableActionsTableCell","state","is_editing","onDelete","ev","preventDefault","stopPropagation","actions","delete","onSave","setState","save","onEdit","edit","onCancel","cancel","href","onClick","bind","EditableTableRow","even","role","defaults","EditableTable","_props$options$action","_props$options$action2","rows","data","new_row","options","editRow","saveRow","deleteClick","onChangeCell","editRowCancel","saveNewRow","handleNewChange","onChangeNewCell","componentDidUpdate","prevProps","prevState","snapshot","row","find","editing_row","_this$props$options$a","_this$props$options$a2","Swal","title","T","text","showCancelButton","confirmButtonColor","confirmButtonText","then","result","_objectSpread","forEach","rowIdx","findIndex","field","target","columns","tableClass","textArea","map","col","i","colWidth","Array","isArray","console","warn","createRow","cells","EditableTableCell","columnKey","push","createNewRow","addNew","cell_value","Tooltip","delayShow"],"sourceRoot":""}
@@ -1 +1 @@
1
- {"version":3,"file":"components/table-selectable.js","mappings":"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","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/./src/components/raw-html/index.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/extends\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/objectWithoutProperties\"","webpack://openstack-uicore-foundation/external commonjs \"prop-types\"","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/external commonjs \"react-tooltip\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableTableHeading.js","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableTableRow.js","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableActionsTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableTable.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","import React from 'react';\n\nconst RawHTML = ({children, replaceNewLine = false, className = \"\", ...rest}) =>\n <span className={className}\n dangerouslySetInnerHTML={{ __html: replaceNewLine ? children?.replace(/\\n/g, '<br />') : children}} {...rest}/>\n\nexport default RawHTML;","module.exports = require(\"@babel/runtime/helpers/extends\");","module.exports = require(\"@babel/runtime/helpers/objectWithoutProperties\");","module.exports = require(\"prop-types\");","module.exports = require(\"react\");","module.exports = require(\"react-tooltip\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import React from 'react';\nimport PropTypes from 'prop-types';\n\nclass SelectableTableHeading extends React.Component {\n\n\tconstructor (props) {\n\t\tsuper(props);\n\t\tthis.handleSort = this.handleSort.bind(this);\n\t}\n\n\tgetSortClass() {\n\n\t\tif (!this.props.sortable) return null;\n\n\t\tswitch(this.props.sortDir) {\n\t\t\tcase 1:\n\t\t\t\treturn 'sorting_asc';\n\t\t\tcase -1:\n\t\t\t\treturn 'sorting_desc';\n\t\t\tdefault:\n\t\t\t\treturn this.props.sortable ? 'sorting' : null\n\t\t}\n\t}\n\n\thandleSort(e) {\n\t\te.preventDefault();\n\t\tif(!this.props.hasOwnProperty('onSort') || !this.props.sortable) return;\n\n\t\tthis.props.onSort(\n\t\t\tthis.props.columnIndex,\n\t\t\tthis.props.columnKey,\n\t\t\tthis.props.sortDir ? this.props.sortDir*-1 : 1,\n\t\t\tthis.props.sortFunc\n\t\t);\n\t}\n\n\trender () {\n\t\treturn (\n\t\t\t<th onClick={this.handleSort}\n\t\t\t\tclassName={this.getSortClass()}\n\t\t\t\twidth={this.props.width}\n\t\t\t\t>\n\t\t\t\t{this.props.children}\n\t\t\t</th>\n\t\t);\t\n\t}\n\t\n}\n\nSelectableTableHeading.propTypes = {\n\tonSort: PropTypes.func,\n\tsortDir: PropTypes.number,\n\tcolumnIndex: PropTypes.number,\n\tcolumnKey: PropTypes.any,\n\tsortable: PropTypes.bool,\n\tsortFunc: PropTypes.func\n};\n\nexport default SelectableTableHeading;","import React from 'react';\nimport RawHTML from '../raw-html';\n\nconst SelectableTableCell = (props) => {\n let {children} = props;\n\tlet value = '';\n\tif(children) {\n\t if (React.isValidElement(children)) {\n\t value = children;\n } else {\n\t value = <RawHTML>{children.toString()}</RawHTML>\n }\n }\n\n\treturn (\n\t\t<td {...props}>\n {value}\n\t\t</td>\n\t);\n};\n\nexport default SelectableTableCell;\n","import React from 'react';\n\nexport default class SelectableTableRow extends React.Component {\n\n constructor(props) {\n super(props);\n this.handleEdit = this.handleEdit.bind(this);\n this.handleSelect = this.handleSelect.bind(this);\n }\n\n shouldDisplayAction(action) {\n let {id} = this.props;\n if (!action.hasOwnProperty('display')) {\n return true;\n } else {\n return action.display(id);\n }\n }\n\n handleEdit(id, ev) {\n // by pass\n if(ev.target.type === \"checkbox\")\n return;\n ev.stopPropagation();\n ev.preventDefault();\n this.props.actions.edit.onClick(id);\n }\n\n handleSelect(id, ev) {\n this.props.actions.edit.onSelected(id, ev.target.checked);\n }\n\n render() {\n\n let {even, actions, id, children, checked} = this.props;\n let canEdit = (actions?.edit && this.shouldDisplayAction(actions.edit));\n let rowClass = even ? 'even' : 'odd';\n\n if (canEdit) {\n return (\n <tr role=\"row\" className={rowClass + \" can-edit\"} onClick={this.handleEdit.bind(this, id)}>\n <td key={id + '_select'}>\n <input\n type=\"checkbox\"\n id={id + '_select'}\n name={id + '_select'}\n checked={checked}\n onChange={this.handleSelect.bind(this, id)}\n />\n </td>\n {children}\n </tr>\n );\n }\n\n return (\n <tr role=\"row\" className={rowClass}>\n <td key={id + '_select'} >\n <input\n type=\"checkbox\"\n id={id + '_select'}\n name={id + '_select'}\n checked={checked}\n onChange={this.handleSelect.bind(this, id)}\n />\n </td>\n {children}\n </tr>\n );\n\n }\n};\n\n","import React from 'react';\n\nexport default class SelectableActionsTableCell extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.handleAction = this.handleAction.bind(this);\n this.shouldDisplayAction = this.shouldDisplayAction.bind(this);\n\n }\n\n shouldDisplayAction(action) {\n let {id} = this.props;\n\n if (!action.hasOwnProperty('display')) {\n return true;\n } else {\n return action.display(id);\n }\n }\n\n handleAction(action, id, ev) {\n ev.stopPropagation();\n ev.preventDefault();\n\n action(id);\n }\n\n render() {\n let {actions, id} = this.props;\n return (\n <td className=\"actions\" key=\"actions\">\n {actions.hasOwnProperty('delete') && this.shouldDisplayAction(actions.delete) &&\n <a href=\"\" data-tip=\"delete\" onClick={this.handleAction.bind(this, actions.delete.onClick, id)} >\n <i className=\"fa fa-trash-o delete-icon\"></i>\n </a>\n }\n {actions.hasOwnProperty('custom') && actions.custom.map(a =>\n this.shouldDisplayAction(a) &&\n <a href=\"\" data-tip={a.tooltip} key={'custom_' + a.name} onClick={this.handleAction.bind(this, a.onClick, id)}>\n {a.icon}\n </a>\n )}\n </td>\n );\n }\n};\n","import React from 'react';\nimport SelectableTableHeading from './SelectableTableHeading';\nimport SelectableTableCell from './SelectableTableCell';\nimport SelectableTableRow from './SelectableTableRow';\nimport SelectableActionsTableCell from './SelectableActionsTableCell';\nimport { Tooltip } from 'react-tooltip'\nimport './selectable-table.less';\n\nconst defaults = {\n sortFunc: (a, b) => (a < b ? -1 : a > b ? 1 : 0),\n sortable: false,\n sortCol: 0,\n sortDir: 1,\n colWidth: \"\",\n};\n\nconst createRow = (row, columns, actions) => {\n var action_buttons = \"\";\n var cells = columns.map((col, i) => {\n if (col.hasOwnProperty(\"render\"))\n return (\n <SelectableTableCell\n key={row[\"id\"] + \"_field\" + i}\n name={col.columnKey}\n id={row.id}\n >\n {col.render(row, row[col.columnKey])}\n </SelectableTableCell>\n );\n\n return (\n <SelectableTableCell\n key={row[\"id\"] + \"_field\" + i}\n name={col.columnKey}\n id={row.id}\n >\n {row[col.columnKey]}\n </SelectableTableCell>\n );\n });\n\n if (actions) {\n cells.push(\n <SelectableActionsTableCell\n key=\"actions_cell\"\n id={row[\"id\"]}\n actions={actions}\n />\n );\n }\n\n return cells;\n};\n\nconst getSortDir = (columnKey, columnIndex, sortCol, sortDir) => {\n if (columnKey && columnKey === sortCol) {\n return sortDir;\n }\n if (sortCol === columnIndex) {\n return sortDir;\n }\n return null;\n};\n\nclass SelectableTable extends React.Component {\n constructor(props) {\n super(props);\n }\n\n render() {\n let { options, columns } = this.props;\n let tableClass = options.hasOwnProperty(\"className\")\n ? options.className\n : \"\";\n tableClass += options.actions?.edit ? \" table-hover\" : \"\";\n\n return (\n <div>\n <table\n className={\n \"table table-striped selectableTable \" + tableClass\n }\n >\n <thead>\n <tr>\n <th>\n {!options.disableSelectAll && (\n <input\n type=\"checkbox\"\n id=\"select_all\"\n name=\"select_all\"\n onChange={\n options.actions?.edit?.onSelectedAll\n }\n checked={options.selectedAll}\n />\n )}\n </th>\n {columns.map((col, i) => {\n let sortCol =\n typeof options.sortCol != \"undefined\"\n ? options.sortCol\n : defaults.sortCol;\n let sortDir =\n typeof options.sortDir != \"undefined\"\n ? options.sortDir\n : defaults.sortDir;\n let sortFunc =\n typeof options.sortFunc != \"undefined\"\n ? options.sortFunc\n : defaults.sortFunc;\n let sortable =\n typeof col.sortable != \"undefined\"\n ? col.sortable\n : defaults.sortable;\n let colWidth =\n typeof col.width != \"undefined\"\n ? col.width\n : defaults.colWidth;\n\n return (\n <SelectableTableHeading\n onSort={this.props.onSort}\n sortDir={getSortDir(\n col.columnKey,\n i,\n sortCol,\n sortDir\n )}\n sortable={sortable}\n sortFunc={sortFunc}\n columnIndex={i}\n columnKey={col.columnKey}\n width={colWidth}\n key={\"heading_\" + i}\n >\n {col.value}\n </SelectableTableHeading>\n );\n })}\n {options.actions && (\n <SelectableTableHeading key=\"actions_heading\">\n {options.actionsHeader || \" \"}\n </SelectableTableHeading>\n )}\n </tr>\n </thead>\n <tbody>\n {columns.length > 0 &&\n this.props.data.map((row, i) => {\n if (\n Array.isArray(row) &&\n row.length !== columns.length\n ) {\n console.warn(\n `Data at row ${i} is ${row.length}. It should be ${columns.length}.`\n );\n return <tr key={\"row_\" + i} />;\n }\n\n return (\n <SelectableTableRow\n checked={row.checked}\n even={i % 2 === 0}\n key={\"row_\" + row[\"id\"]}\n id={row[\"id\"]}\n actions={options.actions}\n >\n {createRow(\n row,\n columns,\n options.actions\n )}\n </SelectableTableRow>\n );\n })}\n </tbody>\n </table>\n <Tooltip delayShow={10} />\n </div>\n );\n }\n}\n\nexport default SelectableTable;\n"],"names":["root","factory","exports","module","define","amd","this","children","replaceNewLine","className","rest","dangerouslySetInnerHTML","__html","replace","require","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","SelectableTableHeading","React","constructor","props","super","handleSort","bind","getSortClass","sortable","sortDir","e","preventDefault","onSort","columnIndex","columnKey","sortFunc","render","onClick","width","propTypes","PropTypes","toString","SelectableTableRow","handleEdit","handleSelect","shouldDisplayAction","action","id","display","ev","target","type","stopPropagation","actions","edit","onSelected","checked","even","rowClass","role","name","onChange","SelectableActionsTableCell","handleAction","delete","href","custom","map","tooltip","icon","defaults","b","sortCol","colWidth","getSortDir","SelectableTable","options","columns","tableClass","disableSelectAll","onSelectedAll","selectedAll","col","i","actionsHeader","length","data","row","Array","isArray","console","warn","cells","push","createRow","Tooltip","delayShow"],"sourceRoot":""}
1
+ {"version":3,"file":"components/table-selectable.js","mappings":"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","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/./src/components/raw-html/index.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/extends\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/objectWithoutProperties\"","webpack://openstack-uicore-foundation/external commonjs \"prop-types\"","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/external commonjs \"react-tooltip\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableTableHeading.js","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableTableRow.js","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableActionsTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-selectable/SelectableTable.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","import React from 'react';\n\nconst RawHTML = ({children, replaceNewLine = false, className = \"\", ...rest}) =>\n <span className={className}\n dangerouslySetInnerHTML={{ __html: replaceNewLine ? children?.replace(/\\n/g, '<br />') : children}} {...rest}/>\n\nexport default RawHTML;","module.exports = require(\"@babel/runtime/helpers/extends\");","module.exports = require(\"@babel/runtime/helpers/objectWithoutProperties\");","module.exports = require(\"prop-types\");","module.exports = require(\"react\");","module.exports = require(\"react-tooltip\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import React from 'react';\nimport PropTypes from 'prop-types';\n\nclass SelectableTableHeading extends React.Component {\n\n\tconstructor (props) {\n\t\tsuper(props);\n\t\tthis.handleSort = this.handleSort.bind(this);\n\t}\n\n\tgetSortClass() {\n\n\t\tif (!this.props.sortable) return null;\n\n\t\tswitch(this.props.sortDir) {\n\t\t\tcase 1:\n\t\t\t\treturn 'sorting_asc';\n\t\t\tcase -1:\n\t\t\t\treturn 'sorting_desc';\n\t\t\tdefault:\n\t\t\t\treturn this.props.sortable ? 'sorting' : null\n\t\t}\n\t}\n\n\thandleSort(e) {\n\t\te.preventDefault();\n\t\tif(!this.props.hasOwnProperty('onSort') || !this.props.sortable) return;\n\n\t\tthis.props.onSort(\n\t\t\tthis.props.columnIndex,\n\t\t\tthis.props.columnKey,\n\t\t\tthis.props.sortDir ? this.props.sortDir*-1 : 1,\n\t\t\tthis.props.sortFunc\n\t\t);\n\t}\n\n\trender () {\n\t\treturn (\n\t\t\t<th onClick={this.handleSort}\n\t\t\t\tclassName={this.getSortClass()}\n\t\t\t\twidth={this.props.width}\n\t\t\t\t>\n\t\t\t\t{this.props.children}\n\t\t\t</th>\n\t\t);\t\n\t}\n\t\n}\n\nSelectableTableHeading.propTypes = {\n\tonSort: PropTypes.func,\n\tsortDir: PropTypes.number,\n\tcolumnIndex: PropTypes.number,\n\tcolumnKey: PropTypes.any,\n\tsortable: PropTypes.bool,\n\tsortFunc: PropTypes.func\n};\n\nexport default SelectableTableHeading;","import React from 'react';\nimport RawHTML from '../raw-html';\n\nconst SelectableTableCell = (props) => {\n let {children} = props;\n\tlet value = '';\n\tif(children) {\n\t if (React.isValidElement(children)) {\n\t value = children;\n } else {\n\t value = <RawHTML>{children.toString()}</RawHTML>\n }\n }\n\n\treturn (\n\t\t<td {...props}>\n {value}\n\t\t</td>\n\t);\n};\n\nexport default SelectableTableCell;\n","import React from 'react';\n\nexport default class SelectableTableRow extends React.Component {\n\n constructor(props) {\n super(props);\n this.handleEdit = this.handleEdit.bind(this);\n this.handleSelect = this.handleSelect.bind(this);\n }\n\n shouldDisplayAction(action) {\n let {id} = this.props;\n if (!action.hasOwnProperty('display')) {\n return true;\n } else {\n return action.display(id);\n }\n }\n\n handleEdit(id, ev) {\n // by pass\n if(ev.target.type === \"checkbox\")\n return;\n ev.stopPropagation();\n ev.preventDefault();\n this.props.actions.edit.onClick(id);\n }\n\n handleSelect(id, ev) {\n this.props.actions.edit.onSelected(id, ev.target.checked);\n }\n\n render() {\n\n let {even, actions, id, children, checked} = this.props;\n let canEdit = (actions?.edit && this.shouldDisplayAction(actions.edit));\n let rowClass = even ? 'even' : 'odd';\n\n if (canEdit) {\n return (\n <tr role=\"row\" className={rowClass + \" can-edit\"} onClick={this.handleEdit.bind(this, id)}>\n <td key={id + '_select'}>\n <input\n type=\"checkbox\"\n id={id + '_select'}\n name={id + '_select'}\n checked={checked}\n onChange={this.handleSelect.bind(this, id)}\n />\n </td>\n {children}\n </tr>\n );\n }\n\n return (\n <tr role=\"row\" className={rowClass}>\n <td key={id + '_select'} >\n <input\n type=\"checkbox\"\n id={id + '_select'}\n name={id + '_select'}\n checked={checked}\n onChange={this.handleSelect.bind(this, id)}\n />\n </td>\n {children}\n </tr>\n );\n\n }\n};\n\n","import React from 'react';\n\nexport default class SelectableActionsTableCell extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.handleAction = this.handleAction.bind(this);\n this.shouldDisplayAction = this.shouldDisplayAction.bind(this);\n\n }\n\n shouldDisplayAction(action) {\n let {id} = this.props;\n\n if (!action.hasOwnProperty('display')) {\n return true;\n } else {\n return action.display(id);\n }\n }\n\n handleAction(action, id, ev) {\n ev.stopPropagation();\n ev.preventDefault();\n\n action(id);\n }\n\n render() {\n let {actions, id} = this.props;\n return (\n <td className=\"actions\" key=\"actions\">\n {actions.hasOwnProperty('delete') && this.shouldDisplayAction(actions.delete) &&\n <a href=\"\" data-tip=\"delete\" onClick={this.handleAction.bind(this, actions.delete.onClick, id)} >\n <i className=\"fa fa-trash-o delete-icon\"></i>\n </a>\n }\n {actions.hasOwnProperty('custom') && actions.custom.map(a =>\n this.shouldDisplayAction(a) &&\n <a href=\"\" data-tip={a.tooltip} key={'custom_' + a.name} onClick={this.handleAction.bind(this, a.onClick, id)}>\n {a.icon}\n </a>\n )}\n </td>\n );\n }\n};\n","import React from 'react';\nimport SelectableTableHeading from './SelectableTableHeading';\nimport SelectableTableCell from './SelectableTableCell';\nimport SelectableTableRow from './SelectableTableRow';\nimport SelectableActionsTableCell from './SelectableActionsTableCell';\nimport { Tooltip } from 'react-tooltip'\nimport './selectable-table.less';\n\nconst defaults = {\n sortFunc: (a, b) => (a < b ? -1 : a > b ? 1 : 0),\n sortable: false,\n sortCol: 0,\n sortDir: 1,\n colWidth: \"\",\n};\n\nconst createRow = (row, columns, actions) => {\n var action_buttons = \"\";\n var cells = columns.map((col, i) => {\n if (col.hasOwnProperty(\"render\"))\n return (\n <SelectableTableCell\n key={row[\"id\"] + \"_field\" + i}\n name={col.columnKey}\n id={row.id}\n >\n {col.render(row, row[col.columnKey])}\n </SelectableTableCell>\n );\n\n return (\n <SelectableTableCell\n key={row[\"id\"] + \"_field\" + i}\n name={col.columnKey}\n id={row.id}\n >\n {row[col.columnKey]}\n </SelectableTableCell>\n );\n });\n\n if (actions) {\n cells.push(\n <SelectableActionsTableCell\n key=\"actions_cell\"\n id={row[\"id\"]}\n actions={actions}\n />\n );\n }\n\n return cells;\n};\n\nconst getSortDir = (columnKey, columnIndex, sortCol, sortDir) => {\n if (columnKey && columnKey === sortCol) {\n return sortDir;\n }\n if (sortCol === columnIndex) {\n return sortDir;\n }\n return null;\n};\n\nclass SelectableTable extends React.Component {\n constructor(props) {\n super(props);\n }\n\n render() {\n let { options, columns } = this.props;\n let tableClass = options.hasOwnProperty(\"className\")\n ? options.className\n : \"\";\n tableClass += options.actions?.edit ? \" table-hover\" : \"\";\n\n return (\n <div>\n <table\n className={\n \"table table-striped selectableTable \" + tableClass\n }\n >\n <thead>\n <tr>\n <th>\n {!options.disableSelectAll && (\n <input\n type=\"checkbox\"\n id=\"select_all\"\n name=\"select_all\"\n onChange={\n options.actions?.edit?.onSelectedAll\n }\n checked={options.selectedAll}\n />\n )}\n </th>\n {columns.map((col, i) => {\n let sortCol =\n typeof options.sortCol != \"undefined\"\n ? options.sortCol\n : defaults.sortCol;\n let sortDir =\n typeof options.sortDir != \"undefined\"\n ? options.sortDir\n : defaults.sortDir;\n let sortFunc =\n typeof options.sortFunc != \"undefined\"\n ? options.sortFunc\n : defaults.sortFunc;\n let sortable =\n typeof col.sortable != \"undefined\"\n ? col.sortable\n : defaults.sortable;\n let colWidth =\n typeof col.width != \"undefined\"\n ? col.width\n : defaults.colWidth;\n\n return (\n <SelectableTableHeading\n onSort={this.props.onSort}\n sortDir={getSortDir(\n col.columnKey,\n i,\n sortCol,\n sortDir\n )}\n sortable={sortable}\n sortFunc={sortFunc}\n columnIndex={i}\n columnKey={col.columnKey}\n width={colWidth}\n key={\"heading_\" + i}\n >\n {col.value}\n </SelectableTableHeading>\n );\n })}\n {options.actions && (\n <SelectableTableHeading key=\"actions_heading\">\n {options.actionsHeader || \" \"}\n </SelectableTableHeading>\n )}\n </tr>\n </thead>\n <tbody>\n {columns.length > 0 &&\n this.props.data.map((row, i) => {\n if (\n Array.isArray(row) &&\n row.length !== columns.length\n ) {\n console.warn(\n `Data at row ${i} is ${row.length}. It should be ${columns.length}.`\n );\n return <tr key={\"row_\" + i} />;\n }\n\n return (\n <SelectableTableRow\n checked={row.checked}\n even={i % 2 === 0}\n key={\"row_\" + row[\"id\"]}\n id={row[\"id\"]}\n actions={options.actions}\n >\n {createRow(\n row,\n columns,\n options.actions\n )}\n </SelectableTableRow>\n );\n })}\n </tbody>\n </table>\n <Tooltip delayShow={10} />\n </div>\n );\n }\n}\n\nexport default SelectableTable;\n"],"names":["root","factory","exports","module","define","amd","this","_ref","children","replaceNewLine","className","rest","_objectWithoutProperties","_excluded","React","_extends","dangerouslySetInnerHTML","__html","replace","require","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","value","SelectableTableHeading","constructor","props","super","handleSort","bind","getSortClass","sortable","sortDir","e","preventDefault","onSort","columnIndex","columnKey","sortFunc","render","onClick","width","propTypes","PropTypes","RawHTML","toString","SelectableTableRow","handleEdit","handleSelect","shouldDisplayAction","action","id","display","ev","target","type","stopPropagation","actions","edit","onSelected","checked","even","rowClass","role","name","onChange","SelectableActionsTableCell","handleAction","delete","href","custom","map","tooltip","icon","defaults","b","sortCol","colWidth","getSortDir","SelectableTable","_options$actions","_options$actions2","_options$actions2$edi","options","columns","tableClass","disableSelectAll","onSelectedAll","selectedAll","col","i","actionsHeader","length","data","row","Array","isArray","console","warn","createRow","cells","SelectableTableCell","push","Tooltip","delayShow"],"sourceRoot":""}
@@ -1 +1 @@
1
- {"version":3,"file":"components/table-sortable.js","mappings":"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","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/./src/components/raw-html/index.js","webpack://openstack-uicore-foundation/./src/components/table/TableCell.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/defineProperty\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/extends\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/objectWithoutProperties\"","webpack://openstack-uicore-foundation/external commonjs \"i18n-react/dist/i18n-react\"","webpack://openstack-uicore-foundation/external commonjs \"lodash\"","webpack://openstack-uicore-foundation/external commonjs \"prop-types\"","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/external commonjs \"react-dnd\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/external commonjs \"immutability-helper\"","webpack://openstack-uicore-foundation/external commonjs \"react-dnd-html5-backend\"","webpack://openstack-uicore-foundation/./src/components/table-sortable/SortableTableHeading.js","webpack://openstack-uicore-foundation/./src/components/table-sortable/SortableActionsTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-sortable/SortableTableRow.js","webpack://openstack-uicore-foundation/./src/components/table-sortable/SortableTable.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","import React from 'react';\n\nconst RawHTML = ({children, replaceNewLine = false, className = \"\", ...rest}) =>\n <span className={className}\n dangerouslySetInnerHTML={{ __html: replaceNewLine ? children?.replace(/\\n/g, '<br />') : children}} {...rest}/>\n\nexport default RawHTML;","import React from 'react';\nimport RawHTML from '../raw-html';\n\nconst TableCell = (props) => {\n let {children} = props;\n\tlet value = '';\n\tif(children) {\n\t if (React.isValidElement(children)) {\n\t value = children;\n } else {\n\t value = <RawHTML>{children.toString()}</RawHTML>\n }\n }\n\n\treturn (\n\t\t<td {...props}>\n {value}\n\t\t</td>\n\t);\n};\n\nexport default TableCell;\n","module.exports = require(\"@babel/runtime/helpers/defineProperty\");","module.exports = require(\"@babel/runtime/helpers/extends\");","module.exports = require(\"@babel/runtime/helpers/objectWithoutProperties\");","module.exports = require(\"i18n-react/dist/i18n-react\");","module.exports = require(\"lodash\");","module.exports = require(\"prop-types\");","module.exports = require(\"react\");","module.exports = require(\"react-dnd\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"immutability-helper\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react-dnd-html5-backend\");","import React from 'react';\n\nclass SortableTableHeading extends React.Component {\n\n\tconstructor (props) {\n\t\tsuper(props);\n\t}\n\n\trender () {\n\t\treturn (\n\t\t\t<th width={this.props.width}>\n\t\t\t\t{this.props.children}\n\t\t\t</th>\n\t\t);\t\n\t}\n\t\n}\n\nexport default SortableTableHeading;","import React from 'react';\n\nexport default class SortableActionsTableCell extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.handleAction = this.handleAction.bind(this);\n\n }\n\n shouldDisplayAction(action) {\n let {id} = this.props;\n\n if (!action.hasOwnProperty('display')) {\n return true;\n } else {\n return action.display(id);\n }\n }\n\n handleAction(action, id, ev) {\n ev.stopPropagation();\n ev.preventDefault();\n\n action(id);\n }\n\n render() {\n let {actions, id} = this.props;\n return (\n <td className=\"actions\" key=\"actions\">\n {actions.hasOwnProperty('edit') && this.shouldDisplayAction(actions.edit) &&\n <a href=\"\" data-tip=\"edit\" onClick={this.handleAction.bind(this, actions.edit.onClick, id)} >\n <i className=\"fa fa-pencil-square-o\"></i>\n </a>\n }\n {actions.hasOwnProperty('delete') && this.shouldDisplayAction(actions.delete) &&\n <a href=\"\" data-tip=\"delete\" onClick={this.handleAction.bind(this, actions.delete.onClick, id)} >\n <i className=\"fa fa-trash-o delete-icon\"></i>\n </a>\n }\n {'custom' in actions && actions.custom.map(a =>\n this.shouldDisplayAction(a, id) &&\n <a href=\"\" data-tip={a.tooltip} key={'custom_' + a.name} onClick={this.handleAction.bind(this, a.onClick, id)}>\n {a.icon}\n </a>\n )}\n </td>\n );\n }\n};\n","import React, { useRef } from 'react';\nimport { useDrag, useDrop } from 'react-dnd';\nimport PropTypes from 'prop-types';\n\nconst SortableTableRow = ({ text, even, id, index, moveCard, dropItem, children, findRow }) => {\n const originalIndex = findRow(id).index;\n\n const style = {\n border: '1px dashed gray',\n padding: '0.5rem 1rem',\n marginBottom: '.5rem',\n backgroundColor: 'white',\n cursor: 'move',\n };\n\n const refRow = useRef(null);\n const [{ handlerId }, drop] = useDrop({\n accept: 'row',\n collect(monitor) {\n return {\n handlerId: monitor.getHandlerId(),\n };\n },\n hover(item, monitor) {\n if (!refRow.current) {\n return;\n }\n const dragIndex = item.index;\n const hoverIndex = index;\n // Don't replace items with themselves\n if (dragIndex === hoverIndex) {\n return;\n }\n // Determine rectangle on screen\n const hoverBoundingRect = refRow.current?.getBoundingClientRect();\n // Get vertical middle\n const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;\n // Determine mouse position\n const clientOffset = monitor.getClientOffset();\n // Get pixels to the top\n const hoverClientY = clientOffset.y - hoverBoundingRect.top;\n // Only perform the move when the mouse has crossed half of the items height\n // When dragging downwards, only move when the cursor is below 50%\n // When dragging upwards, only move when the cursor is above 50%\n // Dragging downwards\n if (dragIndex < hoverIndex && hoverClientY < hoverMiddleY) {\n return;\n }\n // Dragging upwards\n if (dragIndex > hoverIndex && hoverClientY > hoverMiddleY) {\n return;\n }\n // Time to actually perform the action\n moveCard(dragIndex, hoverIndex);\n // Note: we're mutating the monitor item here!\n // Generally it's better to avoid mutations,\n // but it's good here for the sake of performance\n // to avoid expensive index searches.\n item.index = hoverIndex;\n },\n });\n const [{ isDragging }, drag] = useDrag({\n type: 'row',\n item: () => {\n return { id, index };\n },\n end:(_item, monitor) => {\n const { id: droppedId, index } = _item;\n const didDrop = monitor.didDrop()\n if(didDrop)\n return dropItem(droppedId, index + 1)\n // rollback\n return moveCard(index, originalIndex);\n },\n collect: (monitor) => ({\n isDragging: monitor.isDragging(),\n }),\n });\n\n const opacity = isDragging ? 0 : 1;\n\n drag(drop(refRow));\n\n return (\n <tr id={id} ref={refRow} role=\"row\" className={even ? 'even' : 'odd'} style={{ ...style, opacity }}>\n {children}\n </tr>\n );\n}\n\nSortableTableRow.propTypes = {\n index: PropTypes.number.isRequired,\n id: PropTypes.any.isRequired,\n moveCard: PropTypes.func.isRequired,\n};\n\nexport default SortableTableRow;\n\n","import React, {useEffect, useState, useCallback} from 'react';\nimport PropTypes from 'prop-types';\nimport update from 'immutability-helper';\nimport {DndProvider} from 'react-dnd'\nimport {HTML5Backend} from 'react-dnd-html5-backend'\nimport SortableTableHeading from './SortableTableHeading';\nimport SortableActionsTableCell from './SortableActionsTableCell';\nimport SortableTableRow from './SortableTableRow';\nimport T from 'i18n-react/dist/i18n-react';\nimport TableCell from \"../table/TableCell\";\nimport _ from 'lodash';\n\nimport './table-sortable.less';\n\nconst defaults = {\n colWidth: ''\n}\n\nconst createRow = (row, columns, actions) => {\n\n let cells = columns.map((col, i) => {\n if (col.hasOwnProperty(\"render\"))\n return (\n <TableCell key={'cell_' + i} title={col.hasOwnProperty(\"title\") ? row[col.columnKey] : null}>\n {col.render(row, row[col.columnKey])}\n </TableCell>\n );\n\n return (\n <TableCell key={'cell_' + i} title={col.hasOwnProperty(\"title\") ? row[col.columnKey] : null}>\n {row[col.columnKey]}\n </TableCell>\n );\n });\n\n if (actions) {\n cells.push(<SortableActionsTableCell key='actions' id={row['id']} actions={actions}/>);\n }\n\n return cells;\n};\n\n\nconst renderNewRow = (columns, new_row, addNew, handleChange) => {\n\n let cells = columns.map((col, i) => {\n let cell_value = (typeof new_row[col.columnKey] !== 'undefined') ? new_row[col.columnKey] : '';\n\n if (col?.input === \"checkbox\")\n return (\n <td key={'new_row_' + i} className=\"checkbox-cell\">\n <input type=\"checkbox\"\n id={'new_' + col.columnKey}\n name={col.columnKey}\n onChange={handleChange}\n checked={cell_value}\n title={col?.value}\n />\n </td>);\n else\n return (\n <td key={'new_row_' + i}>\n <input\n className=\"form-control\"\n id={'new_' + col.columnKey}\n name={col.columnKey}\n placeholder={col?.value}\n onChange={handleChange}\n value={cell_value}/>\n </td>);\n\n });\n\n cells.push(\n <td key='add_new'>\n <button className=\"btn btn-default\" onClick={addNew}> Add</button>\n </td>\n );\n\n return cells;\n};\n\nconst SortableTable = ({data, options, columns, dropCallback, orderField, idField}) => {\n\n const [rows, setRows] = useState(data);\n const [newRow, setNewRow] = useState({});\n\n useEffect(() => {\n setRows(data);\n }, [data])\n\n\n const renderRow = (row, columns, options, index) => {\n return (\n <SortableTableRow even={index % 2 === 0} key={row.id} index={index} id={row.id}\n moveCard={moveRow}\n findRow={findRow}\n dropItem={onDropItem}>\n {createRow(row, columns, options.actions)}\n </SortableTableRow>\n )\n };\n\n const saveNewRow = (ev) => {\n ev.preventDefault();\n options?.actions?.save?.onClick(newRow);\n setNewRow({});\n }\n\n const sortRows = (rows2Sort) => {\n rows2Sort.sort(function (a, b) {\n const x = a[orderField];\n const y = b[orderField];\n return ((x < y) ? -1 : ((x > y) ? 1 : 0));\n });\n return rows2Sort;\n }\n\n const findRow = useCallback(\n (id) => {\n const row = rows.filter((r) => r[idField] === id)[0]\n return {\n row,\n index: rows.indexOf(row),\n }\n },\n [rows],\n )\n\n const moveRow = useCallback(\n (dragIndex, hoverIndex) => {\n\n setRows((prevRows) => {\n\n prevRows = update(prevRows, {\n $splice: [\n [dragIndex, 1],\n [hoverIndex, 0, prevRows[dragIndex]],\n ],\n });\n\n for (let i in prevRows) {\n prevRows[i][orderField] = parseInt(i) + 1;\n }\n\n return sortRows(prevRows)\n });\n },\n [rows, setRows],\n )\n\n const onDropItem = (id, newOrder) => {\n const sortedRows = sortRows(rows);\n setRows(sortedRows);\n dropCallback(sortedRows, id, newOrder)\n }\n\n const handleNewChange = (ev) => {\n let field = ev.target;\n let newRowTmp = {...newRow};\n let {name, value} = field;\n\n if (field.type === 'checkbox') {\n value = field.checked;\n }\n newRowTmp[name] = value;\n setNewRow(newRowTmp);\n }\n\n let tableClass = options.hasOwnProperty('className') ? options.className : '';\n let shouldRenderNewRow = options?.actions?.save?.onClick && options?.actions?.save?.onClick !== null;\n\n return (\n <div className=\"sortable-table-box\">\n <i>{T.translate(\"general.drag_and_drop\")}</i>\n <table className={\"table table-striped table-hover sortableTable \" + tableClass}>\n <thead>\n <tr>\n {columns.map((col, i) => {\n let colWidth = (col.width) ? col.width : defaults.colWidth;\n return (\n <SortableTableHeading width={colWidth} key={i}>\n {col.value}\n </SortableTableHeading>\n );\n })}\n {options.actions &&\n <SortableTableHeading key='actions'>\n Actions\n </SortableTableHeading>\n }\n </tr>\n </thead>\n <tbody>\n {columns.length > 0 && rows.map((row, i) => {\n if (Array.isArray(row) && row.length !== columns.length) {\n console.warn(`Data at row ${i} is ${row.length}. It should be ${columns.length}.`);\n return <tr/>\n }\n return (\n <DndProvider backend={HTML5Backend} key={i}>\n {renderRow(row, columns, options, i)}\n </DndProvider>\n );\n })}\n </tbody>\n {shouldRenderNewRow &&\n <tfoot>\n <tr>\n {renderNewRow(columns, newRow, saveNewRow, handleNewChange)}\n </tr>\n </tfoot>\n }\n </table>\n </div>\n );\n};\n\nSortableTable.defaultProps = {\n idField: 'id',\n}\n\nSortableTable.propTypes = {\n data: PropTypes.array.isRequired,\n options: PropTypes.shape({\n className: PropTypes.string,\n actions: PropTypes.object\n }).isRequired,\n columns: PropTypes.arrayOf(PropTypes.shape({\n columnKey: PropTypes.string.isRequired,\n value: PropTypes.any.isRequired,\n input: PropTypes.string,\n render: PropTypes.func,\n })).isRequired,\n dropCallback: PropTypes.func.isRequired,\n orderField: PropTypes.string.isRequired,\n idField: PropTypes.string,\n}\n\nexport default SortableTable;\n"],"names":["root","factory","exports","module","define","amd","this","children","replaceNewLine","className","rest","dangerouslySetInnerHTML","__html","replace","props","value","React","toString","require","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","SortableTableHeading","constructor","super","render","width","SortableActionsTableCell","handleAction","bind","shouldDisplayAction","action","id","display","ev","stopPropagation","preventDefault","actions","edit","href","onClick","delete","custom","map","tooltip","name","icon","SortableTableRow","text","even","index","moveCard","dropItem","findRow","originalIndex","refRow","useRef","handlerId","drop","useDrop","accept","collect","monitor","getHandlerId","hover","item","current","dragIndex","hoverIndex","hoverBoundingRect","getBoundingClientRect","hoverMiddleY","bottom","top","hoverClientY","getClientOffset","y","isDragging","drag","useDrag","type","end","_item","droppedId","didDrop","opacity","ref","role","style","border","padding","marginBottom","backgroundColor","cursor","propTypes","PropTypes","isRequired","defaults","SortableTable","data","options","columns","dropCallback","orderField","idField","rows","setRows","useState","newRow","setNewRow","useEffect","renderRow","row","moveRow","onDropItem","cells","col","i","TableCell","title","columnKey","push","createRow","sortRows","rows2Sort","sort","b","x","useCallback","filter","indexOf","prevRows","update","$splice","parseInt","newOrder","sortedRows","tableClass","shouldRenderNewRow","save","T","colWidth","length","Array","isArray","console","warn","DndProvider","backend","HTML5Backend","new_row","addNew","handleChange","cell_value","input","onChange","checked","placeholder","renderNewRow","field","target","newRowTmp","defaultProps"],"sourceRoot":""}
1
+ {"version":3,"file":"components/table-sortable.js","mappings":"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","sources":["webpack://openstack-uicore-foundation/webpack/universalModuleDefinition","webpack://openstack-uicore-foundation/./src/components/raw-html/index.js","webpack://openstack-uicore-foundation/./src/components/table/TableCell.js","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/defineProperty\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/extends\"","webpack://openstack-uicore-foundation/external commonjs \"@babel/runtime/helpers/objectWithoutProperties\"","webpack://openstack-uicore-foundation/external commonjs \"i18n-react/dist/i18n-react\"","webpack://openstack-uicore-foundation/external commonjs \"lodash\"","webpack://openstack-uicore-foundation/external commonjs \"prop-types\"","webpack://openstack-uicore-foundation/external commonjs \"react\"","webpack://openstack-uicore-foundation/external commonjs \"react-dnd\"","webpack://openstack-uicore-foundation/webpack/bootstrap","webpack://openstack-uicore-foundation/webpack/runtime/compat get default export","webpack://openstack-uicore-foundation/webpack/runtime/define property getters","webpack://openstack-uicore-foundation/webpack/runtime/hasOwnProperty shorthand","webpack://openstack-uicore-foundation/webpack/runtime/make namespace object","webpack://openstack-uicore-foundation/external commonjs \"immutability-helper\"","webpack://openstack-uicore-foundation/external commonjs \"react-dnd-html5-backend\"","webpack://openstack-uicore-foundation/./src/components/table-sortable/SortableTableHeading.js","webpack://openstack-uicore-foundation/./src/components/table-sortable/SortableActionsTableCell.js","webpack://openstack-uicore-foundation/./src/components/table-sortable/SortableTableRow.js","webpack://openstack-uicore-foundation/./src/components/table-sortable/SortableTable.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"openstack-uicore-foundation\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"openstack-uicore-foundation\"] = factory();\n\telse\n\t\troot[\"openstack-uicore-foundation\"] = factory();\n})(this, () => {\nreturn ","import React from 'react';\n\nconst RawHTML = ({children, replaceNewLine = false, className = \"\", ...rest}) =>\n <span className={className}\n dangerouslySetInnerHTML={{ __html: replaceNewLine ? children?.replace(/\\n/g, '<br />') : children}} {...rest}/>\n\nexport default RawHTML;","import React from 'react';\nimport RawHTML from '../raw-html';\n\nconst TableCell = (props) => {\n let {children} = props;\n\tlet value = '';\n\tif(children) {\n\t if (React.isValidElement(children)) {\n\t value = children;\n } else {\n\t value = <RawHTML>{children.toString()}</RawHTML>\n }\n }\n\n\treturn (\n\t\t<td {...props}>\n {value}\n\t\t</td>\n\t);\n};\n\nexport default TableCell;\n","module.exports = require(\"@babel/runtime/helpers/defineProperty\");","module.exports = require(\"@babel/runtime/helpers/extends\");","module.exports = require(\"@babel/runtime/helpers/objectWithoutProperties\");","module.exports = require(\"i18n-react/dist/i18n-react\");","module.exports = require(\"lodash\");","module.exports = require(\"prop-types\");","module.exports = require(\"react\");","module.exports = require(\"react-dnd\");","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"immutability-helper\");","const __WEBPACK_NAMESPACE_OBJECT__ = require(\"react-dnd-html5-backend\");","import React from 'react';\n\nclass SortableTableHeading extends React.Component {\n\n\tconstructor (props) {\n\t\tsuper(props);\n\t}\n\n\trender () {\n\t\treturn (\n\t\t\t<th width={this.props.width}>\n\t\t\t\t{this.props.children}\n\t\t\t</th>\n\t\t);\t\n\t}\n\t\n}\n\nexport default SortableTableHeading;","import React from 'react';\n\nexport default class SortableActionsTableCell extends React.Component {\n\n constructor(props) {\n super(props);\n\n this.handleAction = this.handleAction.bind(this);\n\n }\n\n shouldDisplayAction(action) {\n let {id} = this.props;\n\n if (!action.hasOwnProperty('display')) {\n return true;\n } else {\n return action.display(id);\n }\n }\n\n handleAction(action, id, ev) {\n ev.stopPropagation();\n ev.preventDefault();\n\n action(id);\n }\n\n render() {\n let {actions, id} = this.props;\n return (\n <td className=\"actions\" key=\"actions\">\n {actions.hasOwnProperty('edit') && this.shouldDisplayAction(actions.edit) &&\n <a href=\"\" data-tip=\"edit\" onClick={this.handleAction.bind(this, actions.edit.onClick, id)} >\n <i className=\"fa fa-pencil-square-o\"></i>\n </a>\n }\n {actions.hasOwnProperty('delete') && this.shouldDisplayAction(actions.delete) &&\n <a href=\"\" data-tip=\"delete\" onClick={this.handleAction.bind(this, actions.delete.onClick, id)} >\n <i className=\"fa fa-trash-o delete-icon\"></i>\n </a>\n }\n {'custom' in actions && actions.custom.map(a =>\n this.shouldDisplayAction(a, id) &&\n <a href=\"\" data-tip={a.tooltip} key={'custom_' + a.name} onClick={this.handleAction.bind(this, a.onClick, id)}>\n {a.icon}\n </a>\n )}\n </td>\n );\n }\n};\n","import React, { useRef } from 'react';\nimport { useDrag, useDrop } from 'react-dnd';\nimport PropTypes from 'prop-types';\n\nconst SortableTableRow = ({ text, even, id, index, moveCard, dropItem, children, findRow }) => {\n const originalIndex = findRow(id).index;\n\n const style = {\n border: '1px dashed gray',\n padding: '0.5rem 1rem',\n marginBottom: '.5rem',\n backgroundColor: 'white',\n cursor: 'move',\n };\n\n const refRow = useRef(null);\n const [{ handlerId }, drop] = useDrop({\n accept: 'row',\n collect(monitor) {\n return {\n handlerId: monitor.getHandlerId(),\n };\n },\n hover(item, monitor) {\n if (!refRow.current) {\n return;\n }\n const dragIndex = item.index;\n const hoverIndex = index;\n // Don't replace items with themselves\n if (dragIndex === hoverIndex) {\n return;\n }\n // Determine rectangle on screen\n const hoverBoundingRect = refRow.current?.getBoundingClientRect();\n // Get vertical middle\n const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;\n // Determine mouse position\n const clientOffset = monitor.getClientOffset();\n // Get pixels to the top\n const hoverClientY = clientOffset.y - hoverBoundingRect.top;\n // Only perform the move when the mouse has crossed half of the items height\n // When dragging downwards, only move when the cursor is below 50%\n // When dragging upwards, only move when the cursor is above 50%\n // Dragging downwards\n if (dragIndex < hoverIndex && hoverClientY < hoverMiddleY) {\n return;\n }\n // Dragging upwards\n if (dragIndex > hoverIndex && hoverClientY > hoverMiddleY) {\n return;\n }\n // Time to actually perform the action\n moveCard(dragIndex, hoverIndex);\n // Note: we're mutating the monitor item here!\n // Generally it's better to avoid mutations,\n // but it's good here for the sake of performance\n // to avoid expensive index searches.\n item.index = hoverIndex;\n },\n });\n const [{ isDragging }, drag] = useDrag({\n type: 'row',\n item: () => {\n return { id, index };\n },\n end:(_item, monitor) => {\n const { id: droppedId, index } = _item;\n const didDrop = monitor.didDrop()\n if(didDrop)\n return dropItem(droppedId, index + 1)\n // rollback\n return moveCard(index, originalIndex);\n },\n collect: (monitor) => ({\n isDragging: monitor.isDragging(),\n }),\n });\n\n const opacity = isDragging ? 0 : 1;\n\n drag(drop(refRow));\n\n return (\n <tr id={id} ref={refRow} role=\"row\" className={even ? 'even' : 'odd'} style={{ ...style, opacity }}>\n {children}\n </tr>\n );\n}\n\nSortableTableRow.propTypes = {\n index: PropTypes.number.isRequired,\n id: PropTypes.any.isRequired,\n moveCard: PropTypes.func.isRequired,\n};\n\nexport default SortableTableRow;\n\n","import React, {useEffect, useState, useCallback} from 'react';\nimport PropTypes from 'prop-types';\nimport update from 'immutability-helper';\nimport {DndProvider} from 'react-dnd'\nimport {HTML5Backend} from 'react-dnd-html5-backend'\nimport SortableTableHeading from './SortableTableHeading';\nimport SortableActionsTableCell from './SortableActionsTableCell';\nimport SortableTableRow from './SortableTableRow';\nimport T from 'i18n-react/dist/i18n-react';\nimport TableCell from \"../table/TableCell\";\nimport _ from 'lodash';\n\nimport './table-sortable.less';\n\nconst defaults = {\n colWidth: ''\n}\n\nconst createRow = (row, columns, actions) => {\n\n let cells = columns.map((col, i) => {\n if (col.hasOwnProperty(\"render\"))\n return (\n <TableCell key={'cell_' + i} title={col.hasOwnProperty(\"title\") ? row[col.columnKey] : null}>\n {col.render(row, row[col.columnKey])}\n </TableCell>\n );\n\n return (\n <TableCell key={'cell_' + i} title={col.hasOwnProperty(\"title\") ? row[col.columnKey] : null}>\n {row[col.columnKey]}\n </TableCell>\n );\n });\n\n if (actions) {\n cells.push(<SortableActionsTableCell key='actions' id={row['id']} actions={actions}/>);\n }\n\n return cells;\n};\n\n\nconst renderNewRow = (columns, new_row, addNew, handleChange) => {\n\n let cells = columns.map((col, i) => {\n let cell_value = (typeof new_row[col.columnKey] !== 'undefined') ? new_row[col.columnKey] : '';\n\n if (col?.input === \"checkbox\")\n return (\n <td key={'new_row_' + i} className=\"checkbox-cell\">\n <input type=\"checkbox\"\n id={'new_' + col.columnKey}\n name={col.columnKey}\n onChange={handleChange}\n checked={cell_value}\n title={col?.value}\n />\n </td>);\n else\n return (\n <td key={'new_row_' + i}>\n <input\n className=\"form-control\"\n id={'new_' + col.columnKey}\n name={col.columnKey}\n placeholder={col?.value}\n onChange={handleChange}\n value={cell_value}/>\n </td>);\n\n });\n\n cells.push(\n <td key='add_new'>\n <button className=\"btn btn-default\" onClick={addNew}> Add</button>\n </td>\n );\n\n return cells;\n};\n\nconst SortableTable = ({data, options, columns, dropCallback, orderField, idField}) => {\n\n const [rows, setRows] = useState(data);\n const [newRow, setNewRow] = useState({});\n\n useEffect(() => {\n setRows(data);\n }, [data])\n\n\n const renderRow = (row, columns, options, index) => {\n return (\n <SortableTableRow even={index % 2 === 0} key={row.id} index={index} id={row.id}\n moveCard={moveRow}\n findRow={findRow}\n dropItem={onDropItem}>\n {createRow(row, columns, options.actions)}\n </SortableTableRow>\n )\n };\n\n const saveNewRow = (ev) => {\n ev.preventDefault();\n options?.actions?.save?.onClick(newRow);\n setNewRow({});\n }\n\n const sortRows = (rows2Sort) => {\n rows2Sort.sort(function (a, b) {\n const x = a[orderField];\n const y = b[orderField];\n return ((x < y) ? -1 : ((x > y) ? 1 : 0));\n });\n return rows2Sort;\n }\n\n const findRow = useCallback(\n (id) => {\n const row = rows.filter((r) => r[idField] === id)[0]\n return {\n row,\n index: rows.indexOf(row),\n }\n },\n [rows],\n )\n\n const moveRow = useCallback(\n (dragIndex, hoverIndex) => {\n\n setRows((prevRows) => {\n\n prevRows = update(prevRows, {\n $splice: [\n [dragIndex, 1],\n [hoverIndex, 0, prevRows[dragIndex]],\n ],\n });\n\n for (let i in prevRows) {\n prevRows[i][orderField] = parseInt(i) + 1;\n }\n\n return sortRows(prevRows)\n });\n },\n [rows, setRows],\n )\n\n const onDropItem = (id, newOrder) => {\n const sortedRows = sortRows(rows);\n setRows(sortedRows);\n dropCallback(sortedRows, id, newOrder)\n }\n\n const handleNewChange = (ev) => {\n let field = ev.target;\n let newRowTmp = {...newRow};\n let {name, value} = field;\n\n if (field.type === 'checkbox') {\n value = field.checked;\n }\n newRowTmp[name] = value;\n setNewRow(newRowTmp);\n }\n\n let tableClass = options.hasOwnProperty('className') ? options.className : '';\n let shouldRenderNewRow = options?.actions?.save?.onClick && options?.actions?.save?.onClick !== null;\n\n return (\n <div className=\"sortable-table-box\">\n <i>{T.translate(\"general.drag_and_drop\")}</i>\n <table className={\"table table-striped table-hover sortableTable \" + tableClass}>\n <thead>\n <tr>\n {columns.map((col, i) => {\n let colWidth = (col.width) ? col.width : defaults.colWidth;\n return (\n <SortableTableHeading width={colWidth} key={i}>\n {col.value}\n </SortableTableHeading>\n );\n })}\n {options.actions &&\n <SortableTableHeading key='actions'>\n Actions\n </SortableTableHeading>\n }\n </tr>\n </thead>\n <tbody>\n {columns.length > 0 && rows.map((row, i) => {\n if (Array.isArray(row) && row.length !== columns.length) {\n console.warn(`Data at row ${i} is ${row.length}. It should be ${columns.length}.`);\n return <tr/>\n }\n return (\n <DndProvider backend={HTML5Backend} key={i}>\n {renderRow(row, columns, options, i)}\n </DndProvider>\n );\n })}\n </tbody>\n {shouldRenderNewRow &&\n <tfoot>\n <tr>\n {renderNewRow(columns, newRow, saveNewRow, handleNewChange)}\n </tr>\n </tfoot>\n }\n </table>\n </div>\n );\n};\n\nSortableTable.defaultProps = {\n idField: 'id',\n}\n\nSortableTable.propTypes = {\n data: PropTypes.array.isRequired,\n options: PropTypes.shape({\n className: PropTypes.string,\n actions: PropTypes.object\n }).isRequired,\n columns: PropTypes.arrayOf(PropTypes.shape({\n columnKey: PropTypes.string.isRequired,\n value: PropTypes.any.isRequired,\n input: PropTypes.string,\n render: PropTypes.func,\n })).isRequired,\n dropCallback: PropTypes.func.isRequired,\n orderField: PropTypes.string.isRequired,\n idField: PropTypes.string,\n}\n\nexport default SortableTable;\n"],"names":["root","factory","exports","module","define","amd","this","_ref","children","replaceNewLine","className","rest","_objectWithoutProperties","_excluded","React","_extends","dangerouslySetInnerHTML","__html","replace","props","value","RawHTML","toString","require","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","undefined","__webpack_modules__","n","getter","__esModule","d","a","definition","key","o","Object","defineProperty","enumerable","get","obj","prop","prototype","hasOwnProperty","call","r","Symbol","toStringTag","SortableTableHeading","constructor","super","render","width","SortableActionsTableCell","handleAction","bind","shouldDisplayAction","action","id","display","ev","stopPropagation","preventDefault","actions","edit","href","onClick","delete","custom","map","tooltip","name","icon","SortableTableRow","text","even","index","moveCard","dropItem","findRow","originalIndex","refRow","useRef","handlerId","drop","useDrop","accept","collect","monitor","getHandlerId","hover","item","_refRow$current","current","dragIndex","hoverIndex","hoverBoundingRect","getBoundingClientRect","hoverMiddleY","bottom","top","hoverClientY","getClientOffset","y","isDragging","drag","useDrag","type","end","_item","droppedId","didDrop","opacity","ref","role","style","_objectSpread","border","padding","marginBottom","backgroundColor","cursor","propTypes","PropTypes","isRequired","defaults","SortableTable","data","options","columns","dropCallback","orderField","idField","_options$actions2","_options$actions2$sav","_options$actions3","_options$actions3$sav","rows","setRows","useState","newRow","setNewRow","useEffect","renderRow","row","moveRow","onDropItem","createRow","cells","col","i","TableCell","title","columnKey","push","sortRows","rows2Sort","sort","b","x","useCallback","filter","indexOf","prevRows","update","$splice","parseInt","newOrder","sortedRows","tableClass","shouldRenderNewRow","save","T","colWidth","length","Array","isArray","console","warn","DndProvider","backend","HTML5Backend","renderNewRow","new_row","addNew","handleChange","cell_value","input","onChange","checked","placeholder","_options$actions","_options$actions$save","field","target","newRowTmp","defaultProps"],"sourceRoot":""}