@servicetitan/table 31.2.0 → 32.0.0

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 (181) hide show
  1. package/dist/demo/column-hiding/index.js +1 -0
  2. package/dist/demo/column-hiding/index.js.map +1 -1
  3. package/dist/demo/column-hiding/product.js +7 -6
  4. package/dist/demo/column-hiding/product.js.map +1 -1
  5. package/dist/demo/column-hiding/products.js +12 -11
  6. package/dist/demo/column-hiding/products.js.map +1 -1
  7. package/dist/demo/column-hiding/table.js +126 -32
  8. package/dist/demo/column-hiding/table.js.map +1 -1
  9. package/dist/demo/column-hiding/table.store.js +30 -27
  10. package/dist/demo/column-hiding/table.store.js.map +1 -1
  11. package/dist/demo/filters/async-select-filter.js +59 -12
  12. package/dist/demo/filters/async-select-filter.js.map +1 -1
  13. package/dist/demo/filters/categories.js +20 -16
  14. package/dist/demo/filters/categories.js.map +1 -1
  15. package/dist/demo/filters/multiselect-filter.js +37 -5
  16. package/dist/demo/filters/multiselect-filter.js.map +1 -1
  17. package/dist/demo/filters/range-filter.js +104 -10
  18. package/dist/demo/filters/range-filter.js.map +1 -1
  19. package/dist/demo/filters/select-filter.js +139 -41
  20. package/dist/demo/filters/select-filter.js.map +1 -1
  21. package/dist/demo/filters/single-select-filter.js +109 -18
  22. package/dist/demo/filters/single-select-filter.js.map +1 -1
  23. package/dist/demo/filters/table.store.js +77 -86
  24. package/dist/demo/filters/table.store.js.map +1 -1
  25. package/dist/demo/footer-page-size/index.js +1 -0
  26. package/dist/demo/footer-page-size/index.js.map +1 -1
  27. package/dist/demo/footer-page-size/table.js +82 -6
  28. package/dist/demo/footer-page-size/table.js.map +1 -1
  29. package/dist/demo/index.js +1 -0
  30. package/dist/demo/index.js.map +1 -1
  31. package/dist/demo/master-detail/detail-table.js +41 -9
  32. package/dist/demo/master-detail/detail-table.js.map +1 -1
  33. package/dist/demo/master-detail/detail-table.store.js +60 -56
  34. package/dist/demo/master-detail/detail-table.store.js.map +1 -1
  35. package/dist/demo/master-detail/index.js +1 -0
  36. package/dist/demo/master-detail/index.js.map +1 -1
  37. package/dist/demo/master-detail/master-table.store.js +65 -61
  38. package/dist/demo/master-detail/master-table.store.js.map +1 -1
  39. package/dist/demo/master-detail/product-detail.js +2 -1
  40. package/dist/demo/master-detail/product-detail.js.map +1 -1
  41. package/dist/demo/master-detail/product-details.js +10 -9
  42. package/dist/demo/master-detail/product-details.js.map +1 -1
  43. package/dist/demo/master-detail/product.js +7 -6
  44. package/dist/demo/master-detail/product.js.map +1 -1
  45. package/dist/demo/master-detail/products.js +12 -11
  46. package/dist/demo/master-detail/products.js.map +1 -1
  47. package/dist/demo/master-detail/table-master-detail.js +39 -8
  48. package/dist/demo/master-detail/table-master-detail.js.map +1 -1
  49. package/dist/demo/overview/actions-cell.js +47 -10
  50. package/dist/demo/overview/actions-cell.js.map +1 -1
  51. package/dist/demo/overview/index.js +1 -0
  52. package/dist/demo/overview/index.js.map +1 -1
  53. package/dist/demo/overview/product.js +7 -6
  54. package/dist/demo/overview/product.js.map +1 -1
  55. package/dist/demo/overview/products.js +15 -14
  56. package/dist/demo/overview/products.js.map +1 -1
  57. package/dist/demo/overview/table.js +176 -21
  58. package/dist/demo/overview/table.js.map +1 -1
  59. package/dist/demo/overview/table.store.js +45 -51
  60. package/dist/demo/overview/table.store.js.map +1 -1
  61. package/dist/demo/row-details/index.js +1 -0
  62. package/dist/demo/row-details/index.js.map +1 -1
  63. package/dist/demo/row-details/row-details-table.js +52 -5
  64. package/dist/demo/row-details/row-details-table.js.map +1 -1
  65. package/dist/demo/row-details/row-details-table.store.js +27 -19
  66. package/dist/demo/row-details/row-details-table.store.js.map +1 -1
  67. package/dist/demo/state-caching/beverages.js +11 -10
  68. package/dist/demo/state-caching/beverages.js.map +1 -1
  69. package/dist/demo/state-caching/index.js +1 -0
  70. package/dist/demo/state-caching/index.js.map +1 -1
  71. package/dist/demo/state-caching/product.js +2 -1
  72. package/dist/demo/state-caching/product.js.map +1 -1
  73. package/dist/demo/state-caching/products.js +12 -11
  74. package/dist/demo/state-caching/products.js.map +1 -1
  75. package/dist/demo/state-caching/state-caching-table.js +44 -3
  76. package/dist/demo/state-caching/state-caching-table.js.map +1 -1
  77. package/dist/demo/state-caching/state-caching-table.store.js +42 -54
  78. package/dist/demo/state-caching/state-caching-table.store.js.map +1 -1
  79. package/dist/details/expand-column.js +31 -7
  80. package/dist/details/expand-column.js.map +1 -1
  81. package/dist/details/index.js +1 -0
  82. package/dist/details/index.js.map +1 -1
  83. package/dist/editable-cell/boolean-editable-cell.js +15 -4
  84. package/dist/editable-cell/boolean-editable-cell.js.map +1 -1
  85. package/dist/editable-cell/get-action-cell.js +14 -7
  86. package/dist/editable-cell/get-action-cell.js.map +1 -1
  87. package/dist/editable-cell/get-editable-cell.js +16 -8
  88. package/dist/editable-cell/get-editable-cell.js.map +1 -1
  89. package/dist/editable-cell/get-select-editable-cell.js +19 -5
  90. package/dist/editable-cell/get-select-editable-cell.js.map +1 -1
  91. package/dist/editable-cell/index.js +1 -0
  92. package/dist/editable-cell/index.js.map +1 -1
  93. package/dist/editable-cell/text-editable-cell.js +23 -5
  94. package/dist/editable-cell/text-editable-cell.js.map +1 -1
  95. package/dist/export/export.js +38 -1
  96. package/dist/export/export.js.map +1 -1
  97. package/dist/export/export.module.css.d.ts +3 -0
  98. package/dist/export/index.js +1 -0
  99. package/dist/export/index.js.map +1 -1
  100. package/dist/filters/async-select/async-select-filter.js +167 -132
  101. package/dist/filters/async-select/async-select-filter.js.map +1 -1
  102. package/dist/filters/column-menu-filters.js +39 -8
  103. package/dist/filters/column-menu-filters.js.map +1 -1
  104. package/dist/filters/datetime-filter/datetime-filter.js +73 -50
  105. package/dist/filters/datetime-filter/datetime-filter.js.map +1 -1
  106. package/dist/filters/field-values-filter.js +80 -72
  107. package/dist/filters/field-values-filter.js.map +1 -1
  108. package/dist/filters/index.js +1 -0
  109. package/dist/filters/index.js.map +1 -1
  110. package/dist/filters/multiselect-filter/multiselect-filter.js +77 -73
  111. package/dist/filters/multiselect-filter/multiselect-filter.js.map +1 -1
  112. package/dist/filters/numeric-filter-extended/numeric-extended-operators.js +10 -3
  113. package/dist/filters/numeric-filter-extended/numeric-extended-operators.js.map +1 -1
  114. package/dist/filters/numeric-filter-extended/numeric-filter-extended.js +39 -16
  115. package/dist/filters/numeric-filter-extended/numeric-filter-extended.js.map +1 -1
  116. package/dist/filters/range-filter/range-filter.js +76 -72
  117. package/dist/filters/range-filter/range-filter.js.map +1 -1
  118. package/dist/filters/select-filter/object-search.js +4 -3
  119. package/dist/filters/select-filter/object-search.js.map +1 -1
  120. package/dist/filters/select-filter/operators.js +6 -5
  121. package/dist/filters/select-filter/operators.js.map +1 -1
  122. package/dist/filters/select-filter/select-filter.js +180 -145
  123. package/dist/filters/select-filter/select-filter.js.map +1 -1
  124. package/dist/filters/select-filter/value-getter.js +2 -1
  125. package/dist/filters/select-filter/value-getter.js.map +1 -1
  126. package/dist/filters/single-select/single-select-filter.js +29 -15
  127. package/dist/filters/single-select/single-select-filter.js.map +1 -1
  128. package/dist/filters/standard-filter-with-multiselect/filter-cell-ext.js +114 -67
  129. package/dist/filters/standard-filter-with-multiselect/filter-cell-ext.js.map +1 -1
  130. package/dist/filters/standard-filter-with-multiselect/filter-cell-ext.module.css.d.ts +7 -0
  131. package/dist/filters/standard-filter-with-multiselect/multiselect-operators.js +10 -3
  132. package/dist/filters/standard-filter-with-multiselect/multiselect-operators.js.map +1 -1
  133. package/dist/filters/standard-filter-with-multiselect/standard-filter-with-multiselect.js +77 -55
  134. package/dist/filters/standard-filter-with-multiselect/standard-filter-with-multiselect.js.map +1 -1
  135. package/dist/filters/standard-filter-with-multiselect/table-column-menu-filter-ext.js +23 -10
  136. package/dist/filters/standard-filter-with-multiselect/table-column-menu-filter-ext.js.map +1 -1
  137. package/dist/filters/time-filter/time-filter.js +63 -49
  138. package/dist/filters/time-filter/time-filter.js.map +1 -1
  139. package/dist/index.js +4 -2
  140. package/dist/index.js.map +1 -1
  141. package/dist/select-cell/index.js +1 -0
  142. package/dist/select-cell/index.js.map +1 -1
  143. package/dist/select-cell/select-cell.js +36 -11
  144. package/dist/select-cell/select-cell.js.map +1 -1
  145. package/dist/select-cell/select-cell.module.css.d.ts +3 -0
  146. package/dist/table-state.js +479 -660
  147. package/dist/table-state.js.map +1 -1
  148. package/dist/table.js +235 -250
  149. package/dist/table.js.map +1 -1
  150. package/dist/table.module.css.d.ts +5 -0
  151. package/dist/use-observing-table-state/demo/components/use-observing-table-state-demo.js +97 -5
  152. package/dist/use-observing-table-state/demo/components/use-observing-table-state-demo.js.map +1 -1
  153. package/dist/use-observing-table-state/demo/stores/use-observing-table-state-demo.store.js +71 -97
  154. package/dist/use-observing-table-state/demo/stores/use-observing-table-state-demo.store.js.map +1 -1
  155. package/dist/use-observing-table-state/index.js +1 -0
  156. package/dist/use-observing-table-state/index.js.map +1 -1
  157. package/dist/use-observing-table-state/use-observing-table-state.js +26 -20
  158. package/dist/use-observing-table-state/use-observing-table-state.js.map +1 -1
  159. package/dist/utils/filters.js +14 -9
  160. package/dist/utils/filters.js.map +1 -1
  161. package/dist/utils/use-td-props.js +3 -2
  162. package/dist/utils/use-td-props.js.map +1 -1
  163. package/package.json +13 -13
  164. package/dist/filters/async-select/async-select-filter.stories.js +0 -7
  165. package/dist/filters/async-select/async-select-filter.stories.js.map +0 -1
  166. package/dist/filters/multiselect-filter/multiselect-filter.stories.js +0 -7
  167. package/dist/filters/multiselect-filter/multiselect-filter.stories.js.map +0 -1
  168. package/dist/filters/range-filter/range-filter.stories.js +0 -9
  169. package/dist/filters/range-filter/range-filter.stories.js.map +0 -1
  170. package/dist/filters/select-filter/__tests__/object-search.test.js +0 -28
  171. package/dist/filters/select-filter/__tests__/object-search.test.js.map +0 -1
  172. package/dist/filters/select-filter/select-filter.stories.js +0 -8
  173. package/dist/filters/select-filter/select-filter.stories.js.map +0 -1
  174. package/dist/filters/single-select/single-select-filter.stories.js +0 -8
  175. package/dist/filters/single-select/single-select-filter.stories.js.map +0 -1
  176. package/dist/table.stories.js +0 -12
  177. package/dist/table.stories.js.map +0 -1
  178. package/dist/use-observing-table-state/use-observing-table-state.stories.js +0 -11
  179. package/dist/use-observing-table-state/use-observing-table-state.stories.js.map +0 -1
  180. package/dist/utils/__tests__/filters.test.js +0 -24
  181. package/dist/utils/__tests__/filters.test.js.map +0 -1
@@ -1,162 +1,197 @@
1
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
1
+ function _define_property(obj, key, value) {
2
+ if (key in obj) {
3
+ Object.defineProperty(obj, key, {
4
+ value: value,
5
+ enumerable: true,
6
+ configurable: true,
7
+ writable: true
8
+ });
9
+ } else {
10
+ obj[key] = value;
11
+ }
12
+ return obj;
13
+ }
14
+ function _ts_decorate(decorators, target, key, desc) {
2
15
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
16
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
17
+ else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
18
  return c > 3 && r && Object.defineProperty(target, key, r), r;
6
- };
7
- var __metadata = (this && this.__metadata) || function (k, v) {
19
+ }
20
+ function _ts_metadata(k, v) {
8
21
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
- };
22
+ }
10
23
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
24
  import { Component, Fragment } from 'react';
12
- import { Checkbox, Radio, Input, Spinner, BodyText, } from '@servicetitan/design-system';
13
- import { renderCustomColumnMenuFilter, } from '../column-menu-filters';
25
+ import { Checkbox, Radio, Input, Spinner, BodyText } from '@servicetitan/design-system';
26
+ import { renderCustomColumnMenuFilter } from '../column-menu-filters';
14
27
  import { makeObservable, observable, runInAction } from 'mobx';
15
28
  import { observer } from 'mobx-react';
16
- let SelectorAsync = class SelectorAsync extends Component {
17
- constructor(props) {
18
- super(props);
19
- Object.defineProperty(this, "shownOptions", {
20
- enumerable: true,
21
- configurable: true,
22
- writable: true,
23
- value: []
24
- });
25
- Object.defineProperty(this, "search", {
26
- enumerable: true,
27
- configurable: true,
28
- writable: true,
29
- value: ''
30
- });
31
- Object.defineProperty(this, "error", {
32
- enumerable: true,
33
- configurable: true,
34
- writable: true,
35
- value: false
36
- });
37
- Object.defineProperty(this, "loading", {
38
- enumerable: true,
39
- configurable: true,
40
- writable: true,
41
- value: false
42
- });
43
- Object.defineProperty(this, "handleKeyDown", {
44
- enumerable: true,
45
- configurable: true,
46
- writable: true,
47
- value: (event) => {
48
- if (event.key === 'Enter') {
49
- event.stopPropagation();
50
- }
51
- }
52
- });
53
- Object.defineProperty(this, "handleSearch", {
54
- enumerable: true,
55
- configurable: true,
56
- writable: true,
57
- value: (_0, data) => {
58
- runInAction(() => (this.search = data.value));
59
- this.searchOptions().catch();
60
- }
61
- });
62
- Object.defineProperty(this, "searchOptions", {
63
- enumerable: true,
64
- configurable: true,
65
- writable: true,
66
- value: async () => {
67
- runInAction(() => {
68
- this.loading = true;
69
- });
70
- try {
71
- const { data } = await this.props.dataFetcher({
72
- search: this.search,
73
- });
74
- runInAction(() => {
75
- this.shownOptions = data;
76
- this.error = false;
77
- this.loading = false;
78
- });
79
- }
80
- catch (_a) {
81
- runInAction(() => {
82
- this.error = true;
83
- this.loading = false;
84
- });
85
- }
86
- }
87
- });
88
- makeObservable(this);
89
- }
29
+ class SelectorAsync extends Component {
90
30
  componentDidMount() {
91
31
  this.searchOptions().catch();
92
32
  }
93
33
  render() {
94
34
  const selectedOptions = this.props.selected;
95
- const selected = new Set(selectedOptions.map(opt => opt.value));
35
+ const selected = new Set(selectedOptions.map((opt)=>opt.value));
96
36
  const ItemComponent = this.props.itemComponent;
97
- return (_jsxs(Fragment, { children: [_jsx(Input, { className: "m-x-half m-t-half m-b-2", placeholder: this.props.placeholder, onChange: this.handleSearch, onKeyDown: this.handleKeyDown, size: "xsmall", value: this.search }), _jsxs("div", { className: "p-x-half position-relative", onKeyDown: this.handleKeyDown, children: [!!selectedOptions.length && (_jsx("div", { className: "border-bottom m-y-half", children: selectedOptions.map(option => (_jsx(ItemComponent, { option: option, checked: true, renderer: this.props.renderer, onChange: this.props.onChange }, option.value))) })), this.error ? (_jsx(BodyText, { className: "c-red-500", children: "Unable to load options" })) : this.shownOptions.length ? (this.shownOptions
98
- .filter(opt => !selected.has(opt.value))
99
- .map(option => (_jsx(ItemComponent, { option: option, checked: false, renderer: this.props.renderer, onChange: this.props.onChange }, option.value)))) : this.loading ? (_jsx(BodyText, { children: "\u00A0" })) : (_jsx(BodyText, { children: "No options found" })), this.loading && (_jsx("div", { className: "position-absolute top-0 bottom-0 left-0 right-0 opacity-disabled bg-white d-f justify-content-center", children: _jsx(Spinner, { size: "tiny" }) }))] })] }));
37
+ return /*#__PURE__*/ _jsxs(Fragment, {
38
+ children: [
39
+ /*#__PURE__*/ _jsx(Input, {
40
+ className: "m-x-half m-t-half m-b-2",
41
+ placeholder: this.props.placeholder,
42
+ onChange: this.handleSearch,
43
+ onKeyDown: this.handleKeyDown,
44
+ size: "xsmall",
45
+ value: this.search
46
+ }),
47
+ /*#__PURE__*/ _jsxs("div", {
48
+ className: "p-x-half position-relative",
49
+ onKeyDown: this.handleKeyDown,
50
+ children: [
51
+ !!selectedOptions.length && /*#__PURE__*/ _jsx("div", {
52
+ className: "border-bottom m-y-half",
53
+ children: selectedOptions.map((option)=>/*#__PURE__*/ _jsx(ItemComponent, {
54
+ option: option,
55
+ checked: true,
56
+ renderer: this.props.renderer,
57
+ onChange: this.props.onChange
58
+ }, option.value))
59
+ }),
60
+ this.error ? /*#__PURE__*/ _jsx(BodyText, {
61
+ className: "c-red-500",
62
+ children: "Unable to load options"
63
+ }) : this.shownOptions.length ? this.shownOptions.filter((opt)=>!selected.has(opt.value)).map((option)=>/*#__PURE__*/ _jsx(ItemComponent, {
64
+ option: option,
65
+ checked: false,
66
+ renderer: this.props.renderer,
67
+ onChange: this.props.onChange
68
+ }, option.value)) : this.loading ? /*#__PURE__*/ _jsx(BodyText, {
69
+ children: " "
70
+ }) : /*#__PURE__*/ _jsx(BodyText, {
71
+ children: "No options found"
72
+ }),
73
+ this.loading && /*#__PURE__*/ _jsx("div", {
74
+ className: "position-absolute top-0 bottom-0 left-0 right-0 opacity-disabled bg-white d-f justify-content-center",
75
+ children: /*#__PURE__*/ _jsx(Spinner, {
76
+ size: "tiny"
77
+ })
78
+ })
79
+ ]
80
+ })
81
+ ]
82
+ });
100
83
  }
101
- };
102
- __decorate([
84
+ constructor(props){
85
+ super(props), _define_property(this, "shownOptions", []), _define_property(this, "search", ''), _define_property(this, "error", false), _define_property(this, "loading", false), _define_property(this, "handleKeyDown", (event)=>{
86
+ if (event.key === 'Enter') {
87
+ event.stopPropagation();
88
+ }
89
+ }), _define_property(this, "handleSearch", (_0, data)=>{
90
+ runInAction(()=>this.search = data.value);
91
+ this.searchOptions().catch();
92
+ }), _define_property(this, "searchOptions", async ()=>{
93
+ runInAction(()=>{
94
+ this.loading = true;
95
+ });
96
+ try {
97
+ const { data } = await this.props.dataFetcher({
98
+ search: this.search
99
+ });
100
+ runInAction(()=>{
101
+ this.shownOptions = data;
102
+ this.error = false;
103
+ this.loading = false;
104
+ });
105
+ } catch (e) {
106
+ runInAction(()=>{
107
+ this.error = true;
108
+ this.loading = false;
109
+ });
110
+ }
111
+ });
112
+ makeObservable(this);
113
+ }
114
+ }
115
+ _ts_decorate([
103
116
  observable,
104
- __metadata("design:type", Array)
117
+ _ts_metadata("design:type", Array)
105
118
  ], SelectorAsync.prototype, "shownOptions", void 0);
106
- __decorate([
107
- observable,
108
- __metadata("design:type", Object)
119
+ _ts_decorate([
120
+ observable
109
121
  ], SelectorAsync.prototype, "search", void 0);
110
- __decorate([
111
- observable,
112
- __metadata("design:type", Object)
122
+ _ts_decorate([
123
+ observable
113
124
  ], SelectorAsync.prototype, "error", void 0);
114
- __decorate([
115
- observable,
116
- __metadata("design:type", Object)
125
+ _ts_decorate([
126
+ observable
117
127
  ], SelectorAsync.prototype, "loading", void 0);
118
- SelectorAsync = __decorate([
128
+ SelectorAsync = _ts_decorate([
119
129
  observer,
120
- __metadata("design:paramtypes", [Object])
130
+ _ts_metadata("design:type", Function),
131
+ _ts_metadata("design:paramtypes", [
132
+ typeof SelectorProps === "undefined" ? Object : SelectorProps
133
+ ])
121
134
  ], SelectorAsync);
122
- const SelectorItemSingle = ({ option, renderer, checked, onChange }) => {
123
- var _a;
124
- return (_jsx(Radio, { label: (_a = renderer === null || renderer === void 0 ? void 0 : renderer(option)) !== null && _a !== void 0 ? _a : option.text, checked: checked, onChange: (_, event) => onChange(option, true, event), className: "m-b-1" }));
135
+ const SelectorItemSingle = ({ option, renderer, checked, onChange })=>{
136
+ var _renderer;
137
+ return /*#__PURE__*/ _jsx(Radio, {
138
+ label: (_renderer = renderer === null || renderer === void 0 ? void 0 : renderer(option)) !== null && _renderer !== void 0 ? _renderer : option.text,
139
+ checked: checked,
140
+ onChange: (_, event)=>onChange(option, true, event),
141
+ className: "m-b-1"
142
+ });
125
143
  };
126
- const SelectorItemMultiple = ({ option, renderer, checked, onChange }) => {
127
- var _a;
128
- return (_jsx(Checkbox, { label: (_a = renderer === null || renderer === void 0 ? void 0 : renderer(option)) !== null && _a !== void 0 ? _a : option.text, checked: checked, onChange: (_, checked, event) => onChange(option, checked, event), className: "m-b-1" }));
144
+ const SelectorItemMultiple = ({ option, renderer, checked, onChange })=>{
145
+ var _renderer;
146
+ return /*#__PURE__*/ _jsx(Checkbox, {
147
+ label: (_renderer = renderer === null || renderer === void 0 ? void 0 : renderer(option)) !== null && _renderer !== void 0 ? _renderer : option.text,
148
+ checked: checked,
149
+ onChange: (_, checked, event)=>onChange(option, checked, event),
150
+ className: "m-b-1"
151
+ });
129
152
  };
130
153
  /**
131
154
  * @deprecated use selectColumnMenuFilter instead
132
- */
133
- export function asyncSelectColumnMenuFilter({ dataFetcher, placeholder, multiple, renderItem, ...opts }) {
134
- const contains = (value, options) => options === null || options === void 0 ? void 0 : options.some(opt => opt.value === value);
135
- const equals = (value, option) => (option === null || option === void 0 ? void 0 : option.value) === value;
136
- const FilterCell = multiple
137
- ? ({ value, onChange }) => {
138
- const handleChange = (option, checked, event) => {
139
- const val = checked
140
- ? (value !== null && value !== void 0 ? value : []).concat(option)
141
- : (value !== null && value !== void 0 ? value : []).filter(opt => opt.value !== option.value);
142
- onChange({
143
- value: val.length ? val : undefined,
144
- operator: val.length ? contains : '',
145
- syntheticEvent: event,
146
- });
147
- };
148
- return (_jsx(SelectorAsync, { selected: value !== null && value !== void 0 ? value : [], itemComponent: SelectorItemMultiple, onChange: handleChange, placeholder: placeholder, renderer: renderItem, dataFetcher: dataFetcher }));
149
- }
150
- : ({ value, onChange }) => {
151
- const handleChange = (option, checked, event) => {
152
- onChange({
153
- value: option,
154
- operator: option ? equals : '',
155
- syntheticEvent: event,
156
- });
157
- };
158
- return (_jsx(SelectorAsync, { selected: value ? [value] : [], onChange: handleChange, itemComponent: SelectorItemSingle, placeholder: placeholder, renderer: renderItem, dataFetcher: dataFetcher }));
155
+ */ export function asyncSelectColumnMenuFilter({ dataFetcher, placeholder, multiple, renderItem, ...opts }) {
156
+ const contains = (value, options)=>options === null || options === void 0 ? void 0 : options.some((opt)=>opt.value === value);
157
+ const equals = (value, option)=>(option === null || option === void 0 ? void 0 : option.value) === value;
158
+ const FilterCell = multiple ? ({ value, onChange })=>{
159
+ const handleChange = (option, checked, event)=>{
160
+ const val = checked ? (value !== null && value !== void 0 ? value : []).concat(option) : (value !== null && value !== void 0 ? value : []).filter((opt)=>opt.value !== option.value);
161
+ onChange({
162
+ value: val.length ? val : undefined,
163
+ operator: val.length ? contains : '',
164
+ syntheticEvent: event
165
+ });
159
166
  };
167
+ return /*#__PURE__*/ _jsx(SelectorAsync, {
168
+ selected: value !== null && value !== void 0 ? value : [],
169
+ itemComponent: SelectorItemMultiple,
170
+ onChange: handleChange,
171
+ placeholder: placeholder,
172
+ renderer: renderItem,
173
+ dataFetcher: dataFetcher
174
+ });
175
+ } : ({ value, onChange })=>{
176
+ const handleChange = (option, checked, event)=>{
177
+ onChange({
178
+ value: option,
179
+ operator: option ? equals : '',
180
+ syntheticEvent: event
181
+ });
182
+ };
183
+ return /*#__PURE__*/ _jsx(SelectorAsync, {
184
+ selected: value ? [
185
+ value
186
+ ] : [],
187
+ onChange: handleChange,
188
+ itemComponent: SelectorItemSingle,
189
+ placeholder: placeholder,
190
+ renderer: renderItem,
191
+ dataFetcher: dataFetcher
192
+ });
193
+ };
160
194
  return renderCustomColumnMenuFilter(FilterCell, opts);
161
195
  }
196
+
162
197
  //# sourceMappingURL=async-select-filter.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"async-select-filter.js","sourceRoot":"","sources":["../../../src/filters/async-select/async-select-filter.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"sources":["../../../src/filters/async-select/async-select-filter.tsx"],"sourcesContent":["import { Component, SyntheticEvent, ReactNode, Fragment, KeyboardEvent, FC } from 'react';\n\nimport {\n Checkbox,\n TableFilterCellProps,\n Radio,\n Input,\n Spinner,\n BodyText,\n} from '@servicetitan/design-system';\nimport { IdType } from '@servicetitan/data-query';\n\nimport {\n CustomColumnMenuFilterSingleOpts,\n renderCustomColumnMenuFilter,\n} from '../column-menu-filters';\nimport { makeObservable, observable, runInAction } from 'mobx';\nimport { observer } from 'mobx-react';\n\nexport type AsyncSelectFilterDataFetcher<\n TV extends IdType = IdType,\n TO extends AsyncSelectItem<TV> = AsyncSelectItem<TV>,\n> = (opts: { search?: string }) => Promise<{ data: TO[] }>;\n\nexport interface AsyncSelectItem<TV extends IdType = IdType> {\n value: TV;\n text: string;\n}\n\ninterface SelectorProps<TID extends IdType, TO extends AsyncSelectItem<TID>> {\n placeholder?: string;\n selected: TO[];\n dataFetcher: AsyncSelectFilterDataFetcher<TID, TO>;\n itemComponent: FC<SelectorItemProps>;\n onChange(option: TO, checked: boolean, event: SyntheticEvent<HTMLInputElement>): void;\n renderer?(item: TO): ReactNode;\n}\n\ninterface SelectorItemProps {\n option: AsyncSelectItem;\n checked: boolean;\n onChange(\n option: AsyncSelectItem,\n checked: boolean,\n event: SyntheticEvent<HTMLInputElement>\n ): void;\n renderer?(item: AsyncSelectItem): ReactNode;\n}\n\n@observer\nclass SelectorAsync<TID extends IdType, TO extends AsyncSelectItem<TID>> extends Component<\n SelectorProps<TID, TO>\n> {\n @observable shownOptions: AsyncSelectItem<TID>[] = [];\n @observable search = '';\n @observable error = false;\n @observable loading = false;\n\n constructor(props: SelectorProps<TID, TO>) {\n super(props);\n makeObservable(this);\n }\n\n componentDidMount() {\n this.searchOptions().catch();\n }\n\n handleKeyDown = (event: KeyboardEvent<HTMLInputElement>) => {\n if (event.key === 'Enter') {\n event.stopPropagation();\n }\n };\n\n handleSearch = (_0: SyntheticEvent<HTMLInputElement>, data: { value: string }) => {\n runInAction(() => (this.search = data.value));\n this.searchOptions().catch();\n };\n\n searchOptions = async () => {\n runInAction(() => {\n this.loading = true;\n });\n\n try {\n const { data } = await this.props.dataFetcher({\n search: this.search,\n });\n\n runInAction(() => {\n this.shownOptions = data;\n this.error = false;\n this.loading = false;\n });\n } catch {\n runInAction(() => {\n this.error = true;\n this.loading = false;\n });\n }\n };\n\n render() {\n const selectedOptions = this.props.selected;\n const selected = new Set(selectedOptions.map(opt => opt.value));\n const ItemComponent = this.props.itemComponent;\n\n return (\n <Fragment>\n <Input\n className=\"m-x-half m-t-half m-b-2\"\n placeholder={this.props.placeholder}\n onChange={this.handleSearch}\n onKeyDown={this.handleKeyDown}\n size=\"xsmall\"\n value={this.search}\n />\n <div className=\"p-x-half position-relative\" onKeyDown={this.handleKeyDown}>\n {!!selectedOptions.length && (\n <div className=\"border-bottom m-y-half\">\n {selectedOptions.map(option => (\n <ItemComponent\n key={option.value}\n option={option}\n checked\n renderer={this.props.renderer}\n onChange={this.props.onChange}\n />\n ))}\n </div>\n )}\n {this.error ? (\n <BodyText className=\"c-red-500\">Unable to load options</BodyText>\n ) : this.shownOptions.length ? (\n this.shownOptions\n .filter(opt => !selected.has(opt.value))\n .map(option => (\n <ItemComponent\n key={option.value}\n option={option}\n checked={false}\n renderer={this.props.renderer}\n onChange={this.props.onChange}\n />\n ))\n ) : this.loading ? (\n <BodyText>&nbsp;</BodyText>\n ) : (\n <BodyText>No options found</BodyText>\n )}\n\n {this.loading && (\n <div className=\"position-absolute top-0 bottom-0 left-0 right-0 opacity-disabled bg-white d-f justify-content-center\">\n <Spinner size=\"tiny\" />\n </div>\n )}\n </div>\n </Fragment>\n );\n }\n}\n\nconst SelectorItemSingle: FC<SelectorItemProps> = ({ option, renderer, checked, onChange }) => (\n <Radio\n label={renderer?.(option) ?? option.text}\n checked={checked}\n onChange={(_, event) => onChange(option, true, event)}\n className=\"m-b-1\"\n />\n);\n\nconst SelectorItemMultiple: FC<SelectorItemProps> = ({ option, renderer, checked, onChange }) => (\n <Checkbox\n label={renderer?.(option) ?? option.text}\n checked={checked}\n onChange={(_, checked, event) => onChange(option, checked, event)}\n className=\"m-b-1\"\n />\n);\n\nexport interface AsyncSelectFilterOptions<TID extends IdType, TO extends AsyncSelectItem<TID>>\n extends CustomColumnMenuFilterSingleOpts {\n dataFetcher: AsyncSelectFilterDataFetcher<TID, TO>;\n placeholder?: string;\n multiple?: boolean;\n renderItem?: (item: TO) => ReactNode;\n}\n\ninterface TableFilterCellPropsTyped<T = any> extends Omit<TableFilterCellProps, 'value'> {\n value?: T;\n}\n\n/**\n * @deprecated use selectColumnMenuFilter instead\n */\nexport function asyncSelectColumnMenuFilter<TID extends IdType, TO extends AsyncSelectItem<TID>>({\n dataFetcher,\n placeholder,\n multiple,\n renderItem,\n ...opts\n}: AsyncSelectFilterOptions<TID, TO>) {\n const contains = (value: TID, options?: TO[]) => options?.some(opt => opt.value === value);\n const equals = (value: TID, option?: TO) => option?.value === value;\n\n const FilterCell = multiple\n ? ({ value, onChange }: TableFilterCellPropsTyped<TO[]>) => {\n const handleChange = (\n option: TO,\n checked: boolean,\n event: SyntheticEvent<HTMLInputElement>\n ) => {\n const val = checked\n ? (value ?? []).concat(option)\n : (value ?? []).filter(opt => opt.value !== option.value);\n\n onChange({\n value: val.length ? val : undefined,\n operator: val.length ? contains : '',\n syntheticEvent: event,\n });\n };\n\n return (\n <SelectorAsync\n selected={value ?? []}\n itemComponent={SelectorItemMultiple}\n onChange={handleChange}\n placeholder={placeholder}\n renderer={renderItem}\n dataFetcher={dataFetcher}\n />\n );\n }\n : ({ value, onChange }: TableFilterCellPropsTyped<TO>) => {\n const handleChange = (\n option: TO,\n checked: boolean,\n event: SyntheticEvent<HTMLInputElement>\n ) => {\n onChange({\n value: option,\n operator: option ? equals : '',\n syntheticEvent: event,\n });\n };\n\n return (\n <SelectorAsync\n selected={value ? [value] : []}\n onChange={handleChange}\n itemComponent={SelectorItemSingle}\n placeholder={placeholder}\n renderer={renderItem}\n dataFetcher={dataFetcher}\n />\n );\n };\n\n return renderCustomColumnMenuFilter(FilterCell, opts);\n}\n"],"names":["Component","Fragment","Checkbox","Radio","Input","Spinner","BodyText","renderCustomColumnMenuFilter","makeObservable","observable","runInAction","observer","SelectorAsync","componentDidMount","searchOptions","catch","render","selectedOptions","props","selected","Set","map","opt","value","ItemComponent","itemComponent","className","placeholder","onChange","handleSearch","onKeyDown","handleKeyDown","size","search","div","length","option","checked","renderer","error","shownOptions","filter","has","loading","constructor","event","key","stopPropagation","_0","data","dataFetcher","SelectorItemSingle","label","text","_","SelectorItemMultiple","asyncSelectColumnMenuFilter","multiple","renderItem","opts","contains","options","some","equals","FilterCell","handleChange","val","concat","undefined","operator","syntheticEvent"],"mappings":"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"}
@@ -1,19 +1,50 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { TableColumnMenuFilter, } from '@servicetitan/design-system';
2
+ import { TableColumnMenuFilter } from '@servicetitan/design-system';
3
3
  import { DropDownList } from '@progress/kendo-react-dropdowns';
4
- export const StandardColumnMenuFilter = (props) => (_jsx(TableColumnMenuFilter, { ...props, expanded: true }));
4
+ export const StandardColumnMenuFilter = (props)=>/*#__PURE__*/ _jsx(TableColumnMenuFilter, {
5
+ ...props,
6
+ expanded: true
7
+ });
5
8
  export function renderCustomColumnMenuFilter(FilterCell, doubleOrOptions) {
6
- const opts = typeof doubleOrOptions === 'boolean'
7
- ? { double: doubleOrOptions }
8
- : (doubleOrOptions !== null && doubleOrOptions !== void 0 ? doubleOrOptions : {});
9
- const FilterUI = ({ firstFilterProps, secondFilterProps, logicData, logicValue, onLogicChange, }) => {
9
+ const opts = typeof doubleOrOptions === 'boolean' ? {
10
+ double: doubleOrOptions
11
+ } : doubleOrOptions !== null && doubleOrOptions !== void 0 ? doubleOrOptions : {};
12
+ const FilterUI = ({ firstFilterProps, secondFilterProps, logicData, logicValue, onLogicChange })=>{
10
13
  const contentStyles = {};
11
14
  if (opts.contentMaxHeight) {
12
15
  contentStyles.maxHeight = opts.contentMaxHeight;
13
16
  contentStyles.overflowY = 'auto';
14
17
  }
15
- return (_jsxs("div", { className: opts.contentClassName, style: contentStyles, children: [_jsx(FilterCell, { ...firstFilterProps }), !!opts.double && (_jsxs("div", { className: opts.doubleContentClassName, children: [_jsx(DropDownList, { data: logicData, value: logicValue, onChange: onLogicChange, className: "k-filter-and m-b-1", textField: "text" }), _jsx(FilterCell, { ...secondFilterProps })] }))] }));
18
+ return /*#__PURE__*/ _jsxs("div", {
19
+ className: opts.contentClassName,
20
+ style: contentStyles,
21
+ children: [
22
+ /*#__PURE__*/ _jsx(FilterCell, {
23
+ ...firstFilterProps
24
+ }),
25
+ !!opts.double && /*#__PURE__*/ _jsxs("div", {
26
+ className: opts.doubleContentClassName,
27
+ children: [
28
+ /*#__PURE__*/ _jsx(DropDownList, {
29
+ data: logicData,
30
+ value: logicValue,
31
+ onChange: onLogicChange,
32
+ className: "k-filter-and m-b-1",
33
+ textField: "text"
34
+ }),
35
+ /*#__PURE__*/ _jsx(FilterCell, {
36
+ ...secondFilterProps
37
+ })
38
+ ]
39
+ })
40
+ ]
41
+ });
16
42
  };
17
- return (props) => (_jsx(TableColumnMenuFilter, { ...props, filterUI: FilterUI, expanded: true }));
43
+ return (props)=>/*#__PURE__*/ _jsx(TableColumnMenuFilter, {
44
+ ...props,
45
+ filterUI: FilterUI,
46
+ expanded: true
47
+ });
18
48
  }
49
+
19
50
  //# sourceMappingURL=column-menu-filters.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"column-menu-filters.js","sourceRoot":"","sources":["../../src/filters/column-menu-filters.tsx"],"names":[],"mappings":";AACA,OAAO,EACH,qBAAqB,GAGxB,MAAM,6BAA6B,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAE/D,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,KAA2B,EAAE,EAAE,CAAC,CACrE,KAAC,qBAAqB,OAAK,KAAK,EAAE,QAAQ,SAAG,CAChD,CAAC;AAcF,MAAM,UAAU,4BAA4B,CACxC,UAA+C,EAC/C,eAAsD;IAEtD,MAAM,IAAI,GACN,OAAO,eAAe,KAAK,SAAS;QAChC,CAAC,CAAC,EAAE,MAAM,EAAE,eAAe,EAAE;QAC7B,CAAC,CAAC,CAAC,eAAe,aAAf,eAAe,cAAf,eAAe,GAAI,EAAE,CAAC,CAAC;IAClC,MAAM,QAAQ,GAAqC,CAAC,EAChD,gBAAgB,EAChB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,aAAa,GAChB,EAAE,EAAE;QACD,MAAM,aAAa,GAAkB,EAAE,CAAC;QAExC,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC;YAChD,aAAa,CAAC,SAAS,GAAG,MAAM,CAAC;QACrC,CAAC;QAED,OAAO,CACH,eAAK,SAAS,EAAE,IAAI,CAAC,gBAAgB,EAAE,KAAK,EAAE,aAAa,aACvD,KAAC,UAAU,OAAK,gBAAgB,GAAI,EACnC,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,CACd,eAAK,SAAS,EAAE,IAAI,CAAC,sBAAsB,aACvC,KAAC,YAAY,IACT,IAAI,EAAE,SAAS,EACf,KAAK,EAAE,UAAU,EACjB,QAAQ,EAAE,aAAa,EACvB,SAAS,EAAC,oBAAoB,EAC9B,SAAS,EAAC,MAAM,GAClB,EACF,KAAC,UAAU,OAAK,iBAAiB,GAAI,IACnC,CACT,IACC,CACT,CAAC;IACN,CAAC,CAAC;IAEF,OAAO,CAAC,KAA2B,EAAE,EAAE,CAAC,CACpC,KAAC,qBAAqB,OAAK,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,SAAG,CACpE,CAAC;AACN,CAAC"}
1
+ {"version":3,"sources":["../../src/filters/column-menu-filters.tsx"],"sourcesContent":["import { ComponentType, CSSProperties, FC } from 'react';\nimport {\n TableColumnMenuFilter,\n TableColumnMenuProps,\n TableFilterCellProps,\n} from '@servicetitan/design-system';\nimport { TableColumnMenuFilterUIProps } from '..';\nimport { DropDownList } from '@progress/kendo-react-dropdowns';\n\nexport const StandardColumnMenuFilter = (props: TableColumnMenuProps) => (\n <TableColumnMenuFilter {...props} expanded />\n);\n\nexport interface CustomColumnMenuFilterSingleOpts {\n contentMaxHeight?: string;\n contentClassName?: string;\n}\nexport interface CustomColumnMenuFilterDoubleOpts {\n double?: boolean;\n doubleContentClassName?: string;\n}\n\nexport type CustomColumnMenuFilterOpts = CustomColumnMenuFilterSingleOpts &\n CustomColumnMenuFilterDoubleOpts;\n\nexport function renderCustomColumnMenuFilter(\n FilterCell: ComponentType<TableFilterCellProps>,\n doubleOrOptions?: boolean | CustomColumnMenuFilterOpts\n) {\n const opts: CustomColumnMenuFilterOpts =\n typeof doubleOrOptions === 'boolean'\n ? { double: doubleOrOptions }\n : (doubleOrOptions ?? {});\n const FilterUI: FC<TableColumnMenuFilterUIProps> = ({\n firstFilterProps,\n secondFilterProps,\n logicData,\n logicValue,\n onLogicChange,\n }) => {\n const contentStyles: CSSProperties = {};\n\n if (opts.contentMaxHeight) {\n contentStyles.maxHeight = opts.contentMaxHeight;\n contentStyles.overflowY = 'auto';\n }\n\n return (\n <div className={opts.contentClassName} style={contentStyles}>\n <FilterCell {...firstFilterProps} />\n {!!opts.double && (\n <div className={opts.doubleContentClassName}>\n <DropDownList\n data={logicData}\n value={logicValue}\n onChange={onLogicChange}\n className=\"k-filter-and m-b-1\"\n textField=\"text\"\n />\n <FilterCell {...secondFilterProps} />\n </div>\n )}\n </div>\n );\n };\n\n return (props: TableColumnMenuProps) => (\n <TableColumnMenuFilter {...props} filterUI={FilterUI} expanded />\n );\n}\n"],"names":["TableColumnMenuFilter","DropDownList","StandardColumnMenuFilter","props","expanded","renderCustomColumnMenuFilter","FilterCell","doubleOrOptions","opts","double","FilterUI","firstFilterProps","secondFilterProps","logicData","logicValue","onLogicChange","contentStyles","contentMaxHeight","maxHeight","overflowY","div","className","contentClassName","style","doubleContentClassName","data","value","onChange","textField","filterUI"],"mappings":";AACA,SACIA,qBAAqB,QAGlB,8BAA8B;AAErC,SAASC,YAAY,QAAQ,kCAAkC;AAE/D,OAAO,MAAMC,2BAA2B,CAACC,sBACrC,KAACH;QAAuB,GAAGG,KAAK;QAAEC,QAAQ;OAC5C;AAcF,OAAO,SAASC,6BACZC,UAA+C,EAC/CC,eAAsD;IAEtD,MAAMC,OACF,OAAOD,oBAAoB,YACrB;QAAEE,QAAQF;IAAgB,IACzBA,4BAAAA,6BAAAA,kBAAmB,CAAC;IAC/B,MAAMG,WAA6C,CAAC,EAChDC,gBAAgB,EAChBC,iBAAiB,EACjBC,SAAS,EACTC,UAAU,EACVC,aAAa,EAChB;QACG,MAAMC,gBAA+B,CAAC;QAEtC,IAAIR,KAAKS,gBAAgB,EAAE;YACvBD,cAAcE,SAAS,GAAGV,KAAKS,gBAAgB;YAC/CD,cAAcG,SAAS,GAAG;QAC9B;QAEA,qBACI,MAACC;YAAIC,WAAWb,KAAKc,gBAAgB;YAAEC,OAAOP;;8BAC1C,KAACV;oBAAY,GAAGK,gBAAgB;;gBAC/B,CAAC,CAACH,KAAKC,MAAM,kBACV,MAACW;oBAAIC,WAAWb,KAAKgB,sBAAsB;;sCACvC,KAACvB;4BACGwB,MAAMZ;4BACNa,OAAOZ;4BACPa,UAAUZ;4BACVM,WAAU;4BACVO,WAAU;;sCAEd,KAACtB;4BAAY,GAAGM,iBAAiB;;;;;;IAKrD;IAEA,OAAO,CAACT,sBACJ,KAACH;YAAuB,GAAGG,KAAK;YAAE0B,UAAUnB;YAAUN,QAAQ;;AAEtE"}
@@ -1,70 +1,93 @@
1
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
1
+ function _define_property(obj, key, value) {
2
+ if (key in obj) {
3
+ Object.defineProperty(obj, key, {
4
+ value: value,
5
+ enumerable: true,
6
+ configurable: true,
7
+ writable: true
8
+ });
9
+ } else {
10
+ obj[key] = value;
11
+ }
12
+ return obj;
13
+ }
14
+ function _ts_decorate(decorators, target, key, desc) {
2
15
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
16
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
17
+ else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
18
  return c > 3 && r && Object.defineProperty(target, key, r), r;
6
- };
7
- var __metadata = (this && this.__metadata) || function (k, v) {
19
+ }
20
+ function _ts_metadata(k, v) {
8
21
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
- };
22
+ }
10
23
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
24
  import { Component, Fragment } from 'react';
12
25
  import { observer } from 'mobx-react';
13
26
  import { observable, action, makeObservable } from 'mobx';
14
27
  import { DropDownList } from '@progress/kendo-react-dropdowns';
15
- import { DatePicker, TimePicker, } from '@progress/kendo-react-dateinputs';
16
- import { IsUnaryFilter, cellOperatorChange, } from '@progress/kendo-react-grid/dist/npm/filterCommon';
28
+ import { DatePicker, TimePicker } from '@progress/kendo-react-dateinputs';
29
+ import { IsUnaryFilter, cellOperatorChange } from '@progress/kendo-react-grid/dist/npm/filterCommon';
30
+ import { TableFilterCellProps } from '@servicetitan/design-system';
17
31
  import { renderCustomColumnMenuFilter } from '../column-menu-filters';
18
- let DateTimeFilterCell = class DateTimeFilterCell extends Component {
19
- constructor(props) {
20
- var _a;
21
- super(props);
22
- Object.defineProperty(this, "operator", {
23
- enumerable: true,
24
- configurable: true,
25
- writable: true,
26
- value: (_a = this.props.operators.find(o => o.operator === this.props.operator)) !== null && _a !== void 0 ? _a : this.props.operators[0]
27
- });
28
- Object.defineProperty(this, "handleOperatorChange", {
29
- enumerable: true,
30
- configurable: true,
31
- writable: true,
32
- value: (event) => {
33
- this.operator = event.target.value;
34
- cellOperatorChange(event, this.props.value, this.props.onChange);
35
- }
32
+ class DateTimeFilterCell extends Component {
33
+ render() {
34
+ return /*#__PURE__*/ _jsxs(Fragment, {
35
+ children: [
36
+ /*#__PURE__*/ _jsx(DropDownList, {
37
+ value: this.operator,
38
+ onChange: this.handleOperatorChange,
39
+ data: this.props.operators,
40
+ dataItemKey: "operator",
41
+ className: "m-b-1",
42
+ textField: "text"
43
+ }),
44
+ !IsUnaryFilter(this.operator.operator) && /*#__PURE__*/ _jsxs(Fragment, {
45
+ children: [
46
+ /*#__PURE__*/ _jsx(DatePicker, {
47
+ value: this.props.value,
48
+ onChange: this.handleChange,
49
+ className: "m-b-1"
50
+ }),
51
+ /*#__PURE__*/ _jsx(TimePicker, {
52
+ value: this.props.value,
53
+ onChange: this.handleChange,
54
+ className: "m-b-1"
55
+ })
56
+ ]
57
+ })
58
+ ]
36
59
  });
37
- Object.defineProperty(this, "handleChange", {
38
- enumerable: true,
39
- configurable: true,
40
- writable: true,
41
- value: (event) => {
42
- var _a;
43
- const value = event.value;
44
- this.props.onChange({
45
- value,
46
- operator: (_a = this.props.operator) !== null && _a !== void 0 ? _a : '',
47
- syntheticEvent: event.syntheticEvent,
48
- });
49
- }
60
+ }
61
+ constructor(props){
62
+ var _this_props_operators_find;
63
+ super(props), _define_property(this, "operator", (_this_props_operators_find = this.props.operators.find((o)=>o.operator === this.props.operator)) !== null && _this_props_operators_find !== void 0 ? _this_props_operators_find : this.props.operators[0]), _define_property(this, "handleOperatorChange", (event)=>{
64
+ this.operator = event.target.value;
65
+ cellOperatorChange(event, this.props.value, this.props.onChange);
66
+ }), _define_property(this, "handleChange", (event)=>{
67
+ const value = event.value;
68
+ var _this_props_operator;
69
+ this.props.onChange({
70
+ value,
71
+ operator: (_this_props_operator = this.props.operator) !== null && _this_props_operator !== void 0 ? _this_props_operator : '',
72
+ syntheticEvent: event.syntheticEvent
73
+ });
50
74
  });
51
75
  makeObservable(this);
52
76
  }
53
- render() {
54
- return (_jsxs(Fragment, { children: [_jsx(DropDownList, { value: this.operator, onChange: this.handleOperatorChange, data: this.props.operators, dataItemKey: "operator", className: "m-b-1", textField: "text" }), !IsUnaryFilter(this.operator.operator) && (_jsxs(Fragment, { children: [_jsx(DatePicker, { value: this.props.value, onChange: this.handleChange, className: "m-b-1" }), _jsx(TimePicker, { value: this.props.value, onChange: this.handleChange, className: "m-b-1" })] }))] }));
55
- }
56
- };
57
- __decorate([
58
- observable,
59
- __metadata("design:type", Object)
77
+ }
78
+ _ts_decorate([
79
+ observable
60
80
  ], DateTimeFilterCell.prototype, "operator", void 0);
61
- __decorate([
62
- action,
63
- __metadata("design:type", Object)
81
+ _ts_decorate([
82
+ action
64
83
  ], DateTimeFilterCell.prototype, "handleOperatorChange", void 0);
65
- DateTimeFilterCell = __decorate([
84
+ DateTimeFilterCell = _ts_decorate([
66
85
  observer,
67
- __metadata("design:paramtypes", [Object])
86
+ _ts_metadata("design:type", Function),
87
+ _ts_metadata("design:paramtypes", [
88
+ typeof TableFilterCellProps === "undefined" ? Object : TableFilterCellProps
89
+ ])
68
90
  ], DateTimeFilterCell);
69
91
  export const DateTimeColumnMenuFilter = renderCustomColumnMenuFilter(DateTimeFilterCell, true);
92
+
70
93
  //# sourceMappingURL=datetime-filter.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"datetime-filter.js","sourceRoot":"","sources":["../../../src/filters/datetime-filter/datetime-filter.tsx"],"names":[],"mappings":";;;;;;;;;;AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAE5C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AAE1D,OAAO,EAAE,YAAY,EAA2B,MAAM,iCAAiC,CAAC;AACxF,OAAO,EACH,UAAU,EAEV,UAAU,GAEb,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EACH,aAAa,EACb,kBAAkB,GACrB,MAAM,kDAAkD,CAAC;AAI1D,OAAO,EAAE,4BAA4B,EAAE,MAAM,wBAAwB,CAAC;AAEtE,IACM,kBAAkB,GADxB,MACM,kBAAmB,SAAQ,SAA+B;IAK5D,YAAY,KAA2B;;QACnC,KAAK,CAAC,KAAK,CAAC,CAAC;QALL;;;;mBACR,MAAA,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,mCAClE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;WAAC;QAQ5B;;;;mBAAuB,CAAC,KAA8B,EAAE,EAAE;gBACtD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;gBACnC,kBAAkB,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACrE,CAAC;WAAC;QAEF;;;;mBAAe,CAAC,KAAoD,EAAE,EAAE;;gBACpE,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;gBAE1B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;oBAChB,KAAK;oBACL,QAAQ,EAAE,MAAA,IAAI,CAAC,KAAK,CAAC,QAAQ,mCAAI,EAAE;oBACnC,cAAc,EAAE,KAAK,CAAC,cAAc;iBACvC,CAAC,CAAC;YACP,CAAC;WAAC;QAjBE,cAAc,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAkBD,MAAM;QACF,OAAO,CACH,MAAC,QAAQ,eACL,KAAC,YAAY,IACT,KAAK,EAAE,IAAI,CAAC,QAAQ,EACpB,QAAQ,EAAE,IAAI,CAAC,oBAAoB,EACnC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,EAC1B,WAAW,EAAC,UAAU,EACtB,SAAS,EAAC,OAAO,EACjB,SAAS,EAAC,MAAM,GAClB,EACD,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CACvC,MAAC,QAAQ,eACL,KAAC,UAAU,IACP,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EACvB,QAAQ,EAAE,IAAI,CAAC,YAAY,EAC3B,SAAS,EAAC,OAAO,GACnB,EACF,KAAC,UAAU,IACP,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EACvB,QAAQ,EAAE,IAAI,CAAC,YAAY,EAC3B,SAAS,EAAC,OAAO,GACnB,IACK,CACd,IACM,CACd,CAAC;IACN,CAAC;CACJ,CAAA;AArDe;IAAX,UAAU;;oDAEiB;AAQ5B;IADC,MAAM;;gEAIL;AAdA,kBAAkB;IADvB,QAAQ;;GACH,kBAAkB,CAsDvB;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG,4BAA4B,CAAC,kBAAkB,EAAE,IAAI,CAAC,CAAC"}
1
+ {"version":3,"sources":["../../../src/filters/datetime-filter/datetime-filter.tsx"],"sourcesContent":["import { Component, Fragment } from 'react';\n\nimport { observer } from 'mobx-react';\nimport { observable, action, makeObservable } from 'mobx';\n\nimport { DropDownList, DropDownListChangeEvent } from '@progress/kendo-react-dropdowns';\nimport {\n DatePicker,\n DatePickerChangeEvent,\n TimePicker,\n TimePickerChangeEvent,\n} from '@progress/kendo-react-dateinputs';\n\nimport {\n IsUnaryFilter,\n cellOperatorChange,\n} from '@progress/kendo-react-grid/dist/npm/filterCommon';\n\nimport { TableFilterCellProps } from '@servicetitan/design-system';\n\nimport { renderCustomColumnMenuFilter } from '../column-menu-filters';\n\n@observer\nclass DateTimeFilterCell extends Component<TableFilterCellProps> {\n @observable operator =\n this.props.operators.find(o => o.operator === this.props.operator) ??\n this.props.operators[0];\n\n constructor(props: TableFilterCellProps) {\n super(props);\n makeObservable(this);\n }\n\n @action\n handleOperatorChange = (event: DropDownListChangeEvent) => {\n this.operator = event.target.value;\n cellOperatorChange(event, this.props.value, this.props.onChange);\n };\n\n handleChange = (event: DatePickerChangeEvent | TimePickerChangeEvent) => {\n const value = event.value;\n\n this.props.onChange({\n value,\n operator: this.props.operator ?? '',\n syntheticEvent: event.syntheticEvent,\n });\n };\n\n render() {\n return (\n <Fragment>\n <DropDownList\n value={this.operator}\n onChange={this.handleOperatorChange}\n data={this.props.operators}\n dataItemKey=\"operator\"\n className=\"m-b-1\"\n textField=\"text\"\n />\n {!IsUnaryFilter(this.operator.operator) && (\n <Fragment>\n <DatePicker\n value={this.props.value}\n onChange={this.handleChange}\n className=\"m-b-1\"\n />\n <TimePicker\n value={this.props.value}\n onChange={this.handleChange}\n className=\"m-b-1\"\n />\n </Fragment>\n )}\n </Fragment>\n );\n }\n}\n\nexport const DateTimeColumnMenuFilter = renderCustomColumnMenuFilter(DateTimeFilterCell, true);\n"],"names":["Component","Fragment","observer","observable","action","makeObservable","DropDownList","DatePicker","TimePicker","IsUnaryFilter","cellOperatorChange","TableFilterCellProps","renderCustomColumnMenuFilter","DateTimeFilterCell","render","value","operator","onChange","handleOperatorChange","data","props","operators","dataItemKey","className","textField","handleChange","constructor","find","o","event","target","syntheticEvent","DateTimeColumnMenuFilter"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAAA,SAASA,SAAS,EAAEC,QAAQ,QAAQ,QAAQ;AAE5C,SAASC,QAAQ,QAAQ,aAAa;AACtC,SAASC,UAAU,EAAEC,MAAM,EAAEC,cAAc,QAAQ,OAAO;AAE1D,SAASC,YAAY,QAAiC,kCAAkC;AACxF,SACIC,UAAU,EAEVC,UAAU,QAEP,mCAAmC;AAE1C,SACIC,aAAa,EACbC,kBAAkB,QACf,mDAAmD;AAE1D,SAASC,oBAAoB,QAAQ,8BAA8B;AAEnE,SAASC,4BAA4B,QAAQ,yBAAyB;AAEtE,MACMC,2BAA2Bb;IA0B7Bc,SAAS;QACL,qBACI,MAACb;;8BACG,KAACK;oBACGS,OAAO,IAAI,CAACC,QAAQ;oBACpBC,UAAU,IAAI,CAACC,oBAAoB;oBACnCC,MAAM,IAAI,CAACC,KAAK,CAACC,SAAS;oBAC1BC,aAAY;oBACZC,WAAU;oBACVC,WAAU;;gBAEb,CAACf,cAAc,IAAI,CAACO,QAAQ,CAACA,QAAQ,mBAClC,MAACf;;sCACG,KAACM;4BACGQ,OAAO,IAAI,CAACK,KAAK,CAACL,KAAK;4BACvBE,UAAU,IAAI,CAACQ,YAAY;4BAC3BF,WAAU;;sCAEd,KAACf;4BACGO,OAAO,IAAI,CAACK,KAAK,CAACL,KAAK;4BACvBE,UAAU,IAAI,CAACQ,YAAY;4BAC3BF,WAAU;;;;;;IAMlC;IAhDAG,YAAYN,KAA2B,CAAE;YAHrC;QAIA,KAAK,CAACA,QALV,uBAAYJ,YACR,CAAA,6BAAA,IAAI,CAACI,KAAK,CAACC,SAAS,CAACM,IAAI,CAACC,CAAAA,IAAKA,EAAEZ,QAAQ,KAAK,IAAI,CAACI,KAAK,CAACJ,QAAQ,eAAjE,wCAAA,6BACA,IAAI,CAACI,KAAK,CAACC,SAAS,CAAC,EAAE,GAO3B,uBACAH,wBAAuB,CAACW;YACpB,IAAI,CAACb,QAAQ,GAAGa,MAAMC,MAAM,CAACf,KAAK;YAClCL,mBAAmBmB,OAAO,IAAI,CAACT,KAAK,CAACL,KAAK,EAAE,IAAI,CAACK,KAAK,CAACH,QAAQ;QACnE,IAEAQ,uBAAAA,gBAAe,CAACI;YACZ,MAAMd,QAAQc,MAAMd,KAAK;gBAIX;YAFd,IAAI,CAACK,KAAK,CAACH,QAAQ,CAAC;gBAChBF;gBACAC,UAAU,CAAA,uBAAA,IAAI,CAACI,KAAK,CAACJ,QAAQ,cAAnB,kCAAA,uBAAuB;gBACjCe,gBAAgBF,MAAME,cAAc;YACxC;QACJ;QAjBI1B,eAAe,IAAI;IACvB;AA8CJ;;;;;;;;;;;;;;AAEA,OAAO,MAAM2B,2BAA2BpB,6BAA6BC,oBAAoB,MAAM"}