@kaspernj/api-maker 1.0.2167 → 1.0.2169
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.
- package/build/bootstrap/card.js +3 -3
- package/build/bootstrap/checkboxes.js +3 -3
- package/build/draggable-sort/index.d.ts +1 -0
- package/build/draggable-sort/index.d.ts.map +1 -1
- package/build/draggable-sort/index.js +2 -1
- package/build/draggable-sort/item.d.ts +1 -0
- package/build/draggable-sort/item.d.ts.map +1 -1
- package/build/draggable-sort/item.js +12 -7
- package/build/inputs/attachment.js +2 -2
- package/build/inputs/input.js +2 -2
- package/build/router/route.d.ts.map +1 -1
- package/build/router/route.js +5 -6
- package/build/router/switch.d.ts.map +1 -1
- package/build/router/switch.js +4 -6
- package/build/super-admin/edit-page/edit-attribute-checkbox.js +2 -2
- package/build/super-admin/edit-page/edit-attribute-content.js +2 -2
- package/build/super-admin/index.js +4 -4
- package/build/super-admin/layout/header/index.js +5 -3
- package/build/super-admin/layout/index.js +5 -3
- package/build/super-admin/layout/menu/menu-item.js +7 -3
- package/build/super-admin/show-reflection-link.js +2 -2
- package/build/table/blocking-overlay.js +2 -2
- package/build/table/filters/filter-form.js +27 -27
- package/build/table/filters/index.d.ts.map +1 -1
- package/build/table/filters/index.js +23 -21
- package/build/table/filters/load-search-modal.d.ts.map +1 -1
- package/build/table/filters/load-search-modal.js +3 -5
- package/build/table/header-column.d.ts +4 -1
- package/build/table/header-column.d.ts.map +1 -1
- package/build/table/header-column.js +7 -6
- package/build/table/header-select.js +7 -3
- package/build/table/move-dragged-column-position.d.ts +40 -0
- package/build/table/move-dragged-column-position.d.ts.map +1 -0
- package/build/table/move-dragged-column-position.js +37 -0
- package/build/table/table.d.ts.map +1 -1
- package/build/table/table.js +38 -37
- package/build/table/worker-plugins-check-all-checkbox.js +7 -7
- package/build/table/worker-plugins-checkbox.js +3 -5
- package/build/updated-attribute.d.ts +12 -19
- package/build/updated-attribute.d.ts.map +1 -1
- package/build/updated-attribute.js +31 -21
- package/build/use-can-can.js +3 -3
- package/build/use-collection.d.ts.map +1 -1
- package/build/use-collection.js +13 -21
- package/build/use-current-user-context.js +3 -3
- package/build/use-model.d.ts.map +1 -1
- package/build/use-model.js +7 -4
- package/build/utils/button.js +7 -3
- package/build/utils/checkbox.js +3 -3
- package/build/utils/checkboxes.js +3 -3
- package/build/utils/default-style.d.ts +9 -1
- package/build/utils/default-style.d.ts.map +1 -1
- package/build/utils/default-style.js +33 -34
- package/build/utils/text-input.d.ts +27 -0
- package/build/utils/text-input.d.ts.map +1 -0
- package/build/utils/text-input.js +27 -0
- package/build/utils/with-default-style-slot.d.ts +28 -0
- package/build/utils/with-default-style-slot.d.ts.map +1 -0
- package/build/utils/with-default-style-slot.js +46 -0
- package/package.json +2 -2
|
@@ -70,26 +70,26 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
70
70
|
onAddFilterClicked = (e) => {
|
|
71
71
|
e.preventDefault();
|
|
72
72
|
const newFilterIndex = this.currentFilters().length;
|
|
73
|
-
this.
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
73
|
+
this.s.filter = {
|
|
74
|
+
filterIndex: newFilterIndex
|
|
75
|
+
};
|
|
76
|
+
};
|
|
77
|
+
onApplyClicked = () => {
|
|
78
|
+
this.s.filter = undefined;
|
|
78
79
|
};
|
|
79
|
-
onApplyClicked = () => this.setState({ filter: undefined });
|
|
80
80
|
onEditSearchPressed = ({ search }) => {
|
|
81
81
|
this.onRequestCloseLoadSearchModal();
|
|
82
|
-
this.
|
|
83
|
-
|
|
84
|
-
|
|
82
|
+
this.s.showSaveSearchModal = search;
|
|
83
|
+
};
|
|
84
|
+
onFilterClicked = (filter) => {
|
|
85
|
+
this.s.filter = filter;
|
|
86
|
+
};
|
|
87
|
+
onFilterFormRequestClose = () => {
|
|
88
|
+
this.s.filter = undefined;
|
|
85
89
|
};
|
|
86
|
-
onFilterClicked = (filter) => this.setState({ filter });
|
|
87
|
-
onFilterFormRequestClose = () => this.setState({ filter: undefined });
|
|
88
90
|
onLoadSearchClicked = (e) => {
|
|
89
91
|
e.preventDefault();
|
|
90
|
-
this.
|
|
91
|
-
showLoadSearchModal: true
|
|
92
|
-
});
|
|
92
|
+
this.s.showLoadSearchModal = true;
|
|
93
93
|
};
|
|
94
94
|
onRemoveClicked = ({ filterIndex }) => {
|
|
95
95
|
const { querySName } = digs(this.props, "querySName");
|
|
@@ -98,16 +98,18 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
98
98
|
const newParams = {};
|
|
99
99
|
newParams[querySName] = searchParams;
|
|
100
100
|
Params.changeParams(newParams);
|
|
101
|
-
this.
|
|
102
|
-
|
|
103
|
-
|
|
101
|
+
this.s.filter = undefined;
|
|
102
|
+
};
|
|
103
|
+
onRequestCloseLoadSearchModal = () => {
|
|
104
|
+
this.s.showLoadSearchModal = false;
|
|
105
|
+
};
|
|
106
|
+
onRequestCloseSaveSearchModal = () => {
|
|
107
|
+
this.s.showSaveSearchModal = undefined;
|
|
104
108
|
};
|
|
105
|
-
onRequestCloseLoadSearchModal = () => this.setState({ showLoadSearchModal: false });
|
|
106
|
-
onRequestCloseSaveSearchModal = () => this.setState({ showSaveSearchModal: undefined });
|
|
107
109
|
onSaveSearchClicked = (e) => {
|
|
108
110
|
e.preventDefault();
|
|
109
111
|
if (this.hasAnyFilters()) {
|
|
110
|
-
this.
|
|
112
|
+
this.s.showSaveSearchModal = new TableSearch();
|
|
111
113
|
}
|
|
112
114
|
else {
|
|
113
115
|
FlashNotifications.alert(this.t(".no_filters_has_been_set", { defaultValue: "No filters has been set" }));
|
|
@@ -115,4 +117,4 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
115
117
|
};
|
|
116
118
|
hasAnyFilters = () => Object.keys(this.currentFilters()).length > 0;
|
|
117
119
|
}));
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"/src/","sources":["table/filters/index.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable implicit-arrow-linebreak, import/no-unresolved, max-len, react/button-has-type, react/jsx-sort-props, react/no-array-index-key, sort-imports */\nimport {digg, digs} from \"diggerize\"\nimport Filter from \"./filter\"\nimport FilterForm from \"./filter-form\"\nimport {FlashNotifications} from \"flash-notifications\"\nimport LoadSearchModal from \"./load-search-modal\"\nimport SaveSearchModal from \"./save-search-modal\"\nimport Params from \"../../params.js\"\nimport PropTypes from \"prop-types\"\n// @ts-expect-error Runtime-resolved module\nimport {TableSearch} from \"models.js\"\nimport memo from \"set-state-compare/build/memo.js\"\nimport {ShapeComponent, shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport React from \"react\"\nimport useI18n from \"i18n-on-steroids/build/src/use-i18n.js\"\nimport useQueryParams from \"on-location-changed/build/use-query-params.js\"\nimport {View} from \"react-native\"\n\n/** @typedef {import(\"../../base-model.js\").default} BaseModel */\n/** @typedef {BaseModel & {id(): number | string, modelClassData(): {name: string}}} CurrentUserModel */\n/** @typedef {BaseModel & {id(): number | string, name(): string, queryParams(): object[], destroy(): Promise<void>}} TableSearchModel */\n/** @typedef {{filterIndex: number} & Record<string, object | string | number | boolean | null | undefined>} TableFilterDraft */\n\n/**\n * @typedef {object} Props\n * @property {CurrentUserModel} [currentUser]\n * @property {typeof import(\"../../base-model.js\").default} modelClass\n * @property {string} queryName\n * @property {string} querySName\n */\n/**\n * @typedef {object} State\n * @property {TableFilterDraft | undefined} filter\n * @property {boolean | undefined} showLoadSearchModal\n * @property {false | TableSearchModel | undefined} showSaveSearchModal\n */\nexport default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerTableFilters extends ShapeComponent {\n  static propTypes = {\n    currentUser: PropTypes.object,\n    modelClass: PropTypes.func.isRequired,\n    queryName: PropTypes.string.isRequired,\n    querySName: PropTypes.string.isRequired\n  }\n\n  state = {\n    filter: undefined,\n    showLoadSearchModal: undefined,\n    showSaveSearchModal: false\n  }\n\n  setup() {\n    const {t} = useI18n({namespace: \"js.api_maker.table.filters\"})\n\n    this.queryParams = useQueryParams()\n    this.t = t\n  }\n\n  render() {\n    const {modelClass, querySName} = digs(this.props, \"modelClass\", \"querySName\")\n    const {currentUser} = this.props\n    const {filter, showLoadSearchModal, showSaveSearchModal} = digs(this.state, \"filter\", \"showLoadSearchModal\", \"showSaveSearchModal\")\n    const currentFilters = this.currentFilters()\n\n    return (\n      <View dataSet={this.cache(\"rootViewDataSet\", {class: \"api-maker--table--filters\"})} style={this.cache(\"rootViewStyle\", {alignItems: \"flex-start\"})}>\n        {filter &&\n          <FilterForm\n            filter={filter}\n            key={`filter-${filter.filterIndex}`}\n            modelClass={modelClass}\n            onApplyClicked={this.tt.onApplyClicked}\n            onRequestClose={this.tt.onFilterFormRequestClose}\n            querySearchName={querySName}\n          />\n        }\n        {showLoadSearchModal &&\n          <LoadSearchModal\n            currentUser={currentUser}\n            modelClass={modelClass}\n            onEditSearchPressed={digg(this, \"onEditSearchPressed\")}\n            onRequestClose={digg(this, \"onRequestCloseLoadSearchModal\")}\n            querySearchName={querySName}\n          />\n        }\n        {showSaveSearchModal &&\n          <SaveSearchModal\n            currentFilters={digg(this, \"currentFilters\")}\n            currentUser={currentUser}\n            onRequestClose={digg(this, \"onRequestCloseSaveSearchModal\")}\n            search={showSaveSearchModal}\n          />\n        }\n        {currentFilters?.map((filterData, filterIndex) =>\n          <Filter\n            key={filterIndex}\n            filterIndex={filterIndex}\n            onClick={this.tt.onFilterClicked}\n            onRemoveClicked={this.tt.onRemoveClicked}\n            {...filterData}\n          />\n        )}\n        <View dataSet={this.cache(\"filterActionsDataSet\", {class: \"filter-actions\"})} style={this.cache(\"filterActionsStyle\", {flexDirection: \"row\", marginTop: 10})}>\n          <button className=\"add-new-filter-button\" onClick={this.tt.onAddFilterClicked}>\n            {this.t(\".add_new_filter\", {defaultValue: \"Add new filter\"})}\n          </button>\n          {currentUser &&\n            <>\n              <button className=\"save-search-button\" onClick={this.tt.onSaveSearchClicked} style={{marginLeft: 10}}>\n                {this.t(\".save_search\", {defaultValue: \"Save search\"})}\n              </button>\n              <button className=\"load-search-button\" onClick={this.tt.onLoadSearchClicked} style={{marginLeft: 10}}>\n                {this.t(\".load_search\", {defaultValue: \"Load search\"})}\n              </button>\n            </>\n          }\n        </View>\n      </View>\n    )\n  }\n\n  currentFilters = () => {\n    const {querySName} = digs(this.props, \"querySName\")\n    const currentFilters = this.queryParams[querySName] || []\n\n    return currentFilters.map((currentFilter) => JSON.parse(currentFilter))\n  }\n\n  onAddFilterClicked = (e) => {\n    e.preventDefault()\n\n    const newFilterIndex = this.currentFilters().length\n\n    this.setState({\n      filter: {\n        filterIndex: newFilterIndex\n      }\n    })\n  }\n\n  onApplyClicked = () => this.setState({filter: undefined})\n\n  onEditSearchPressed = ({search}) => {\n    this.onRequestCloseLoadSearchModal()\n    this.setState({\n      showSaveSearchModal: search\n    })\n  }\n\n  onFilterClicked = (filter) => this.setState({filter})\n  onFilterFormRequestClose = () => this.setState({filter: undefined})\n\n  onLoadSearchClicked = (e) => {\n    e.preventDefault()\n\n    this.setState({\n      showLoadSearchModal: true\n    })\n  }\n\n  onRemoveClicked = ({filterIndex}) => {\n    const {querySName} = digs(this.props, \"querySName\")\n    const searchParams = Params.parse()[querySName] || {}\n\n    delete searchParams[filterIndex]\n\n    const newParams = {}\n\n    newParams[querySName] = searchParams\n\n    Params.changeParams(newParams)\n\n    this.setState({\n      filter: undefined\n    })\n  }\n\n  onRequestCloseLoadSearchModal = () => this.setState({showLoadSearchModal: false})\n  onRequestCloseSaveSearchModal = () => this.setState({showSaveSearchModal: undefined})\n\n  onSaveSearchClicked = (e) => {\n    e.preventDefault()\n\n    if (this.hasAnyFilters()) {\n      this.setState({showSaveSearchModal: new TableSearch()})\n    } else {\n      FlashNotifications.alert(this.t(\".no_filters_has_been_set\", {defaultValue: \"No filters has been set\"}))\n    }\n  }\n\n  hasAnyFilters = () => Object.keys(this.currentFilters()).length > 0\n}))\n"]}
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"/src/","sources":["table/filters/index.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable implicit-arrow-linebreak, import/no-unresolved, max-len, react/button-has-type, react/jsx-sort-props, react/no-array-index-key, sort-imports */\nimport {digg, digs} from \"diggerize\"\nimport Filter from \"./filter\"\nimport FilterForm from \"./filter-form\"\nimport {FlashNotifications} from \"flash-notifications\"\nimport LoadSearchModal from \"./load-search-modal\"\nimport SaveSearchModal from \"./save-search-modal\"\nimport Params from \"../../params.js\"\nimport PropTypes from \"prop-types\"\n// @ts-expect-error Runtime-resolved module\nimport {TableSearch} from \"models.js\"\nimport memo from \"set-state-compare/build/memo.js\"\nimport {ShapeComponent, shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport React from \"react\"\nimport useI18n from \"i18n-on-steroids/build/src/use-i18n.js\"\nimport useQueryParams from \"on-location-changed/build/use-query-params.js\"\nimport {View} from \"react-native\"\n\n/** @typedef {import(\"../../base-model.js\").default} BaseModel */\n/** @typedef {BaseModel & {id(): number | string, modelClassData(): {name: string}}} CurrentUserModel */\n/** @typedef {BaseModel & {id(): number | string, name(): string, queryParams(): object[], destroy(): Promise<void>}} TableSearchModel */\n/** @typedef {{filterIndex: number} & Record<string, object | string | number | boolean | null | undefined>} TableFilterDraft */\n\n/**\n * @typedef {object} Props\n * @property {CurrentUserModel} [currentUser]\n * @property {typeof import(\"../../base-model.js\").default} modelClass\n * @property {string} queryName\n * @property {string} querySName\n */\n/**\n * @typedef {object} State\n * @property {TableFilterDraft | undefined} filter\n * @property {boolean | undefined} showLoadSearchModal\n * @property {false | TableSearchModel | undefined} showSaveSearchModal\n */\nexport default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerTableFilters extends ShapeComponent {\n  static propTypes = {\n    currentUser: PropTypes.object,\n    modelClass: PropTypes.func.isRequired,\n    queryName: PropTypes.string.isRequired,\n    querySName: PropTypes.string.isRequired\n  }\n\n  state = {\n    filter: undefined,\n    showLoadSearchModal: undefined,\n    showSaveSearchModal: false\n  }\n\n  setup() {\n    const {t} = useI18n({namespace: \"js.api_maker.table.filters\"})\n\n    this.queryParams = useQueryParams()\n    this.t = t\n  }\n\n  render() {\n    const {modelClass, querySName} = digs(this.props, \"modelClass\", \"querySName\")\n    const {currentUser} = this.props\n    const {filter, showLoadSearchModal, showSaveSearchModal} = digs(this.state, \"filter\", \"showLoadSearchModal\", \"showSaveSearchModal\")\n    const currentFilters = this.currentFilters()\n\n    return (\n      <View dataSet={this.cache(\"rootViewDataSet\", {class: \"api-maker--table--filters\"})} style={this.cache(\"rootViewStyle\", {alignItems: \"flex-start\"})}>\n        {filter &&\n          <FilterForm\n            filter={filter}\n            key={`filter-${filter.filterIndex}`}\n            modelClass={modelClass}\n            onApplyClicked={this.tt.onApplyClicked}\n            onRequestClose={this.tt.onFilterFormRequestClose}\n            querySearchName={querySName}\n          />\n        }\n        {showLoadSearchModal &&\n          <LoadSearchModal\n            currentUser={currentUser}\n            modelClass={modelClass}\n            onEditSearchPressed={digg(this, \"onEditSearchPressed\")}\n            onRequestClose={digg(this, \"onRequestCloseLoadSearchModal\")}\n            querySearchName={querySName}\n          />\n        }\n        {showSaveSearchModal &&\n          <SaveSearchModal\n            currentFilters={digg(this, \"currentFilters\")}\n            currentUser={currentUser}\n            onRequestClose={digg(this, \"onRequestCloseSaveSearchModal\")}\n            search={showSaveSearchModal}\n          />\n        }\n        {currentFilters?.map((filterData, filterIndex) =>\n          <Filter\n            key={filterIndex}\n            filterIndex={filterIndex}\n            onClick={this.tt.onFilterClicked}\n            onRemoveClicked={this.tt.onRemoveClicked}\n            {...filterData}\n          />\n        )}\n        <View dataSet={this.cache(\"filterActionsDataSet\", {class: \"filter-actions\"})} style={this.cache(\"filterActionsStyle\", {flexDirection: \"row\", marginTop: 10})}>\n          <button className=\"add-new-filter-button\" onClick={this.tt.onAddFilterClicked}>\n            {this.t(\".add_new_filter\", {defaultValue: \"Add new filter\"})}\n          </button>\n          {currentUser &&\n            <>\n              <button className=\"save-search-button\" onClick={this.tt.onSaveSearchClicked} style={{marginLeft: 10}}>\n                {this.t(\".save_search\", {defaultValue: \"Save search\"})}\n              </button>\n              <button className=\"load-search-button\" onClick={this.tt.onLoadSearchClicked} style={{marginLeft: 10}}>\n                {this.t(\".load_search\", {defaultValue: \"Load search\"})}\n              </button>\n            </>\n          }\n        </View>\n      </View>\n    )\n  }\n\n  currentFilters = () => {\n    const {querySName} = digs(this.props, \"querySName\")\n    const currentFilters = this.queryParams[querySName] || []\n\n    return currentFilters.map((currentFilter) => JSON.parse(currentFilter))\n  }\n\n  onAddFilterClicked = (e) => {\n    e.preventDefault()\n\n    const newFilterIndex = this.currentFilters().length\n\n    this.s.filter = {\n      filterIndex: newFilterIndex\n    }\n  }\n\n  onApplyClicked = () => {\n    this.s.filter = undefined\n  }\n\n  onEditSearchPressed = ({search}) => {\n    this.onRequestCloseLoadSearchModal()\n    this.s.showSaveSearchModal = search\n  }\n\n  onFilterClicked = (filter) => {\n    this.s.filter = filter\n  }\n\n  onFilterFormRequestClose = () => {\n    this.s.filter = undefined\n  }\n\n  onLoadSearchClicked = (e) => {\n    e.preventDefault()\n\n    this.s.showLoadSearchModal = true\n  }\n\n  onRemoveClicked = ({filterIndex}) => {\n    const {querySName} = digs(this.props, \"querySName\")\n    const searchParams = Params.parse()[querySName] || {}\n\n    delete searchParams[filterIndex]\n\n    const newParams = {}\n\n    newParams[querySName] = searchParams\n\n    Params.changeParams(newParams)\n\n    this.s.filter = undefined\n  }\n\n  onRequestCloseLoadSearchModal = () => {\n    this.s.showLoadSearchModal = false\n  }\n\n  onRequestCloseSaveSearchModal = () => {\n    this.s.showSaveSearchModal = undefined\n  }\n\n  onSaveSearchClicked = (e) => {\n    e.preventDefault()\n\n    if (this.hasAnyFilters()) {\n      this.s.showSaveSearchModal = new TableSearch()\n    } else {\n      FlashNotifications.alert(this.t(\".no_filters_has_been_set\", {defaultValue: \"No filters has been set\"}))\n    }\n  }\n\n  hasAnyFilters = () => Object.keys(this.currentFilters()).length > 0\n}))\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"load-search-modal.d.ts","sourceRoot":"/src/","sources":["table/filters/load-search-modal.jsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"load-search-modal.d.ts","sourceRoot":"/src/","sources":["table/filters/load-search-modal.jsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAsLuouB,CAAC;;;yBAA6O,CAAC;;;;;;;gBAAoc,CAAC;;;;;yBAAm7E,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BArKju0B,SAAS,GAAG;IAAC,EAAE,IAAI,MAAM,GAAG,MAAM,CAAC;IAAC,cAAc,IAAI;QAAC,IAAI,EAAE,MAAM,CAAA;KAAC,CAAA;CAAC;+BACrE,SAAS,GAAG;IAAC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAAC,EAAE,IAAI,MAAM,GAAG,MAAM,CAAC;IAAC,IAAI,IAAI,MAAM,CAAC;IAAC,WAAW,IAAI,MAAM,EAAE,CAAA;CAAC;;;;;YAOtG,WAAW;;8BAEX,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC;;gBA+ErB,MAAM;iBACN,gBAAgB;;;qBAGhB,MAAM;;;cAIN,WAAW,EAAE,GAAC,SAAS;;kBA/GR,OAAO"}
|
|
@@ -89,7 +89,7 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
89
89
|
const searches = await TableSearch
|
|
90
90
|
.ransack({ user_id_eq: currentUser.id(), user_type_eq: userType })
|
|
91
91
|
.toArray();
|
|
92
|
-
this.
|
|
92
|
+
this.s.searches = searches;
|
|
93
93
|
};
|
|
94
94
|
render() {
|
|
95
95
|
const { t } = this.tt;
|
|
@@ -106,9 +106,7 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
106
106
|
onRequestClose();
|
|
107
107
|
};
|
|
108
108
|
onSearchDeleted = ({ search }) => {
|
|
109
|
-
this.
|
|
110
|
-
searches: this.s.searches.filter((existingSearch) => existingSearch.id() != search.id())
|
|
111
|
-
});
|
|
109
|
+
this.s.searches = this.s.searches.filter((existingSearch) => existingSearch.id() != search.id());
|
|
112
110
|
};
|
|
113
111
|
}));
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"load-search-modal.js","sourceRoot":"/src/","sources":["table/filters/load-search-modal.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable import/no-unresolved, implicit-arrow-linebreak, no-alert */\n/* eslint-disable react/jsx-max-depth, react/jsx-no-literals, sort-imports */\nimport React, {useMemo} from \"react\"\nimport {Pressable, View} from \"react-native\"\nimport classNames from \"classnames\"\nimport {digg} from \"diggerize\"\nimport memo from \"set-state-compare/build/memo.js\"\nimport {ShapeComponent, shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport Params from \"../../params.js\"\n// @ts-expect-error Runtime-resolved module\nimport {TableSearch} from \"models.js\"\nimport Text from \"../../utils/text\"\nimport useI18n from \"i18n-on-steroids/build/src/use-i18n.js\"\nimport apiMakerConfig from \"../../config.js\"\n\n/** @typedef {import(\"../../base-model.js\").default} BaseModel */\n/** @typedef {BaseModel & {id(): number | string, modelClassData(): {name: string}}} CurrentUserModel */\n/** @typedef {BaseModel & {destroy(): Promise<void>, id(): number | string, name(): string, queryParams(): object[]}} TableSearchModel */\n\n/**\n * @typedef {object} SearchLinkProps\n * @property {Function} onClick\n * @property {Function} onDeleted\n * @property {Function} onEditPressed\n * @property {TableSearch} search\n */\n/** @typedef {Record<string, never>} SearchLinkState */\nconst SearchLink = memo(shapeComponent(/** @augments {ShapeComponent<SearchLinkProps, SearchLinkState>} */ class SearchLink extends ShapeComponent {\n  render() {\n    const {search} = this.props\n\n    return (\n      <View\n        dataSet={this.cache(\"rootViewStyle\", {class: \"search-row\", searchId: search.id()}, [search.id()])}\n        style={this.cache(\"rootViewStyleStyle\", {flexDirection: \"row\", width: \"100%\"})}\n      >\n        <Pressable\n          dataSet={this.cache(\"loadSearchLinkPressableDataSet\", {class: \"load-search-link\"})}\n          onPress={this.tt.onSearchClicked}\n          style={this.cache(\"loadSearchLinkPressableStyle\", {justifyContent: \"center\"})}\n        >\n          <Text>\n            {search.name()}\n          </Text>\n        </Pressable>\n        <View style={this.cache(\"actionsViewStyle\", {flexDirection: \"row\", marginLeft: \"auto\"})}>\n          <Pressable\n            dataSet={this.cache(\"editSearchButtonDataSet\", {class: \"edit-search-button\"})}\n            onPress={this.tt.onEditPressed}\n            style={this.cache(\"editSearchButtonStyle\", {\n              alignItems: \"center\",\n              justifyContent: \"center\",\n              width: 25,\n              height: 25,\n              backgroundColor: \"#fff\",\n              border: \"1px solid #007bff\",\n              borderRadius: 5,\n              color: \"#007bff\"\n            })}\n          >\n            <Text>\n              &#x270E;\n            </Text>\n          </Pressable>\n          <Pressable\n            dataSet={this.cache(\"deleteSearchButtonDataSet\", {class: \"delete-search-button\"})}\n            onPress={this.tt.onDeletePressed}\n            style={this.cache(\"deleteSearchButtonStyle\", {\n              alignItems: \"center\",\n              justifyContent: \"center\",\n              marginLeft: 5,\n              width: 25,\n              height: 25,\n              backgroundColor: \"#fff\",\n              border: \"1px solid #dc3545\",\n              borderRadius: 5,\n              color: \"#dc3545\"\n            })}\n          >\n            <Text>\n              &#x2715;\n            </Text>\n          </Pressable>\n        </View>\n      </View>\n    )\n  }\n\n  onDeletePressed = async () => {\n    if (!confirm(\"Are you sure?\")) {\n      return\n    }\n\n    const {search} = this.props\n\n    await search.destroy()\n    this.props.onDeleted({search})\n  }\n\n  onEditPressed = () => this.props.onEditPressed({search: this.props.search})\n  onSearchClicked = () => this.props.onClick({search: this.props.search})\n}))\n\n/**\n * @typedef {object} Props\n * @property {string} [className]\n * @property {CurrentUserModel} currentUser\n * @property {Function} onEditSearchPressed\n * @property {Function} onRequestClose\n * @property {string} querySearchName\n */\n/**\n * @typedef {object} State\n * @property {TableSearch[]|undefined} searches\n */\nexport default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerTableFiltersLoadSearchModal extends ShapeComponent {\n  state = {\n    searches: undefined\n  }\n\n  setup() {\n    const {t} = useI18n({namespace: \"js.api_maker.table.filters.load_search_modal\"})\n\n    this.t = t\n\n    useMemo(() => {\n      this.loadSearches()\n    }, [])\n  }\n\n  loadSearches = async () => {\n    const {currentUser} = this.props\n    const userType = digg(currentUser.modelClassData(), \"name\")\n    const searches = await TableSearch\n      .ransack({user_id_eq: currentUser.id(), user_type_eq: userType})\n      .toArray()\n\n    this.setState({searches})\n  }\n\n  render() {\n    const {t} = this.tt\n    const {className, currentUser, modelClass, onEditSearchPressed, onRequestClose, querySearchName, ...restProps} = this.props\n    const Modal = apiMakerConfig.getModal()\n\n    return (\n      <Modal className={classNames(\"api-maker--table--filters--load-search-modal\", className)} onRequestClose={onRequestClose} {...restProps}>\n        <View>\n          <Text>\n            {t(\".choose_a_search\", {defaultValue: \"Choose a search\"})}\n          </Text>\n        </View>\n        {this.s.searches?.map((search) =>\n          <SearchLink\n            key={search.id()}\n            onClick={this.tt.onSearchClicked}\n            onDeleted={this.tt.onSearchDeleted}\n            onEditPressed={onEditSearchPressed}\n            search={search}\n          />\n        )}\n      </Modal>\n    )\n  }\n\n  onSearchClicked = ({search}) => {\n    const {onRequestClose, querySearchName} = this.props\n    const queryParams = search.queryParams()\n    const newParams = {}\n\n    newParams[querySearchName] = queryParams.map((queryParam) => JSON.stringify(queryParam))\n\n    Params.changeParams(newParams)\n\n    onRequestClose()\n  }\n\n  onSearchDeleted = ({search}) => {\n    this.setState({\n      searches: this.s.searches.filter((existingSearch) => existingSearch.id() != search.id())\n    })\n  }\n}))\n"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"load-search-modal.js","sourceRoot":"/src/","sources":["table/filters/load-search-modal.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable import/no-unresolved, implicit-arrow-linebreak, no-alert */\n/* eslint-disable react/jsx-max-depth, react/jsx-no-literals, sort-imports */\nimport React, {useMemo} from \"react\"\nimport {Pressable, View} from \"react-native\"\nimport classNames from \"classnames\"\nimport {digg} from \"diggerize\"\nimport memo from \"set-state-compare/build/memo.js\"\nimport {ShapeComponent, shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport Params from \"../../params.js\"\n// @ts-expect-error Runtime-resolved module\nimport {TableSearch} from \"models.js\"\nimport Text from \"../../utils/text\"\nimport useI18n from \"i18n-on-steroids/build/src/use-i18n.js\"\nimport apiMakerConfig from \"../../config.js\"\n\n/** @typedef {import(\"../../base-model.js\").default} BaseModel */\n/** @typedef {BaseModel & {id(): number | string, modelClassData(): {name: string}}} CurrentUserModel */\n/** @typedef {BaseModel & {destroy(): Promise<void>, id(): number | string, name(): string, queryParams(): object[]}} TableSearchModel */\n\n/**\n * @typedef {object} SearchLinkProps\n * @property {Function} onClick\n * @property {Function} onDeleted\n * @property {Function} onEditPressed\n * @property {TableSearch} search\n */\n/** @typedef {Record<string, never>} SearchLinkState */\nconst SearchLink = memo(shapeComponent(/** @augments {ShapeComponent<SearchLinkProps, SearchLinkState>} */ class SearchLink extends ShapeComponent {\n  render() {\n    const {search} = this.props\n\n    return (\n      <View\n        dataSet={this.cache(\"rootViewStyle\", {class: \"search-row\", searchId: search.id()}, [search.id()])}\n        style={this.cache(\"rootViewStyleStyle\", {flexDirection: \"row\", width: \"100%\"})}\n      >\n        <Pressable\n          dataSet={this.cache(\"loadSearchLinkPressableDataSet\", {class: \"load-search-link\"})}\n          onPress={this.tt.onSearchClicked}\n          style={this.cache(\"loadSearchLinkPressableStyle\", {justifyContent: \"center\"})}\n        >\n          <Text>\n            {search.name()}\n          </Text>\n        </Pressable>\n        <View style={this.cache(\"actionsViewStyle\", {flexDirection: \"row\", marginLeft: \"auto\"})}>\n          <Pressable\n            dataSet={this.cache(\"editSearchButtonDataSet\", {class: \"edit-search-button\"})}\n            onPress={this.tt.onEditPressed}\n            style={this.cache(\"editSearchButtonStyle\", {\n              alignItems: \"center\",\n              justifyContent: \"center\",\n              width: 25,\n              height: 25,\n              backgroundColor: \"#fff\",\n              border: \"1px solid #007bff\",\n              borderRadius: 5,\n              color: \"#007bff\"\n            })}\n          >\n            <Text>\n              &#x270E;\n            </Text>\n          </Pressable>\n          <Pressable\n            dataSet={this.cache(\"deleteSearchButtonDataSet\", {class: \"delete-search-button\"})}\n            onPress={this.tt.onDeletePressed}\n            style={this.cache(\"deleteSearchButtonStyle\", {\n              alignItems: \"center\",\n              justifyContent: \"center\",\n              marginLeft: 5,\n              width: 25,\n              height: 25,\n              backgroundColor: \"#fff\",\n              border: \"1px solid #dc3545\",\n              borderRadius: 5,\n              color: \"#dc3545\"\n            })}\n          >\n            <Text>\n              &#x2715;\n            </Text>\n          </Pressable>\n        </View>\n      </View>\n    )\n  }\n\n  onDeletePressed = async () => {\n    if (!confirm(\"Are you sure?\")) {\n      return\n    }\n\n    const {search} = this.props\n\n    await search.destroy()\n    this.props.onDeleted({search})\n  }\n\n  onEditPressed = () => this.props.onEditPressed({search: this.props.search})\n  onSearchClicked = () => this.props.onClick({search: this.props.search})\n}))\n\n/**\n * @typedef {object} Props\n * @property {string} [className]\n * @property {CurrentUserModel} currentUser\n * @property {Function} onEditSearchPressed\n * @property {Function} onRequestClose\n * @property {string} querySearchName\n */\n/**\n * @typedef {object} State\n * @property {TableSearch[]|undefined} searches\n */\nexport default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerTableFiltersLoadSearchModal extends ShapeComponent {\n  state = {\n    searches: undefined\n  }\n\n  setup() {\n    const {t} = useI18n({namespace: \"js.api_maker.table.filters.load_search_modal\"})\n\n    this.t = t\n\n    useMemo(() => {\n      this.loadSearches()\n    }, [])\n  }\n\n  loadSearches = async () => {\n    const {currentUser} = this.props\n    const userType = digg(currentUser.modelClassData(), \"name\")\n    const searches = await TableSearch\n      .ransack({user_id_eq: currentUser.id(), user_type_eq: userType})\n      .toArray()\n\n    this.s.searches = searches\n  }\n\n  render() {\n    const {t} = this.tt\n    const {className, currentUser, modelClass, onEditSearchPressed, onRequestClose, querySearchName, ...restProps} = this.props\n    const Modal = apiMakerConfig.getModal()\n\n    return (\n      <Modal className={classNames(\"api-maker--table--filters--load-search-modal\", className)} onRequestClose={onRequestClose} {...restProps}>\n        <View>\n          <Text>\n            {t(\".choose_a_search\", {defaultValue: \"Choose a search\"})}\n          </Text>\n        </View>\n        {this.s.searches?.map((search) =>\n          <SearchLink\n            key={search.id()}\n            onClick={this.tt.onSearchClicked}\n            onDeleted={this.tt.onSearchDeleted}\n            onEditPressed={onEditSearchPressed}\n            search={search}\n          />\n        )}\n      </Modal>\n    )\n  }\n\n  onSearchClicked = ({search}) => {\n    const {onRequestClose, querySearchName} = this.props\n    const queryParams = search.queryParams()\n    const newParams = {}\n\n    newParams[querySearchName] = queryParams.map((queryParam) => JSON.stringify(queryParam))\n\n    Params.changeParams(newParams)\n\n    onRequestClose()\n  }\n\n  onSearchDeleted = ({search}) => {\n    this.s.searches = this.s.searches.filter((existingSearch) => existingSearch.id() != search.id())\n  }\n}))\n"]}
|
|
@@ -18,7 +18,10 @@ export type HeaderTableLike = {
|
|
|
18
18
|
headerProps: (column: TableColumnDefinition) => {
|
|
19
19
|
style?: object;
|
|
20
20
|
};
|
|
21
|
-
|
|
21
|
+
s: {
|
|
22
|
+
lastUpdate: Date;
|
|
23
|
+
resizing: boolean;
|
|
24
|
+
};
|
|
22
25
|
tt: {
|
|
23
26
|
styleForHeader(args: {
|
|
24
27
|
style: object;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"header-column.d.ts","sourceRoot":"/src/","sources":["table/header-column.jsx"],"names":[],"mappings":";;0BAiBc;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAC;oCACpB;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAC;iCACpB;IAAC,UAAU,IAAI,MAAM,CAAC;IAAC,OAAO,IAAI,MAAM,CAAC;IAAC,MAAM,CAAC,IAAI,EAAE;QAAC,KAAK,EAAE,MAAM,CAAA;KAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;CAAC;;8BAGvF,CAAC,MAAM,EAAE,qBAAqB,KAAK,MAAM,EAAE;iBAC3C,CAAC,MAAM,EAAE,qBAAqB,KAAK;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAC;
|
|
1
|
+
{"version":3,"file":"header-column.d.ts","sourceRoot":"/src/","sources":["table/header-column.jsx"],"names":[],"mappings":";;0BAiBc;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAC;oCACpB;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAC;iCACpB;IAAC,UAAU,IAAI,MAAM,CAAC;IAAC,OAAO,IAAI,MAAM,CAAC;IAAC,MAAM,CAAC,IAAI,EAAE;QAAC,KAAK,EAAE,MAAM,CAAA;KAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;CAAC;;8BAGvF,CAAC,MAAM,EAAE,qBAAqB,KAAK,MAAM,EAAE;iBAC3C,CAAC,MAAM,EAAE,qBAAqB,KAAK;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAC;OACnD;QAAC,UAAU,EAAE,IAAI,CAAC;QAAC,QAAQ,EAAE,OAAO,CAAA;KAAC;QACrC;QAAC,cAAc,CAAC,IAAI,EAAE;YAAC,KAAK,EAAE,MAAM,CAAA;SAAC,GAAG,MAAM,CAAA;KAAC;;gCAE/C;IAAC,MAAM,CAAC,EAAE,YAAY,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,UAAU,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAC;;YAIzH,OAAO;mBACP,QAAQ,CAAC,KAAK;oBACd,QAAQ,CAAC,KAAK;YACd,qBAAqB;cACrB,OAAO;WACP,eAAe;wBACf,kBAAkB;gBAClB,WAAW;YACX,MAAM;;;cAIN,OAAO;;kBAzCQ,OAAO;yBAMC,cAAc;mBAKhC,UAAU"}
|
|
@@ -21,7 +21,7 @@ const dataSets = {};
|
|
|
21
21
|
* @typedef {object} HeaderTableLike
|
|
22
22
|
* @property {(column: TableColumnDefinition) => string[]} headerClassNameForColumn
|
|
23
23
|
* @property {(column: TableColumnDefinition) => {style?: object}} headerProps
|
|
24
|
-
* @property {
|
|
24
|
+
* @property {{lastUpdate: Date, resizing: boolean}} s
|
|
25
25
|
* @property {{styleForHeader(args: {style: object}): object}} tt
|
|
26
26
|
*/
|
|
27
27
|
/** @typedef {{cursor?: "col-resize", height?: "100%", position: "absolute", right: number, top: number, width: number, zIndex: number}} ResizeHandleStyle */
|
|
@@ -64,8 +64,8 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
64
64
|
this.resizePanResponder = useMemo(() => PanResponder.create({
|
|
65
65
|
onStartShouldSetPanResponder: (_e) => {
|
|
66
66
|
this.originalWidth = this.currentWidth;
|
|
67
|
-
this.
|
|
68
|
-
this.p.table.
|
|
67
|
+
this.s.resizing = true;
|
|
68
|
+
this.p.table.s.resizing = true;
|
|
69
69
|
return true;
|
|
70
70
|
},
|
|
71
71
|
onPanResponderMove: (_e, gestate) => {
|
|
@@ -81,8 +81,9 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
81
81
|
}), []);
|
|
82
82
|
}
|
|
83
83
|
onResizeEnd = async () => {
|
|
84
|
-
this.p.table.
|
|
85
|
-
this.
|
|
84
|
+
this.p.table.s.lastUpdate = new Date();
|
|
85
|
+
this.p.table.s.resizing = false;
|
|
86
|
+
this.s.resizing = false;
|
|
86
87
|
const width = this.p.widths.getWidthOfColumn(this.p.tableSettingColumn.identifier());
|
|
87
88
|
await this.p.tableSettingColumn.update({ width });
|
|
88
89
|
};
|
|
@@ -122,4 +123,4 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
122
123
|
this.currentWidth = width;
|
|
123
124
|
};
|
|
124
125
|
}));
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-column.js","sourceRoot":"/src/","sources":["table/header-column.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable import/no-unresolved, no-return-assign, sort-imports */\nimport React, {useMemo} from \"react\"\nimport classNames from \"classnames\"\nimport Header from \"./components/header\"\nimport HeaderColumnContent from \"./header-column-content\"\nimport Icon from \"../utils/icon\"\nimport memo from \"set-state-compare/build/memo.js\"\nimport {Animated, PanResponder} from \"react-native\"\nimport PropTypes from \"prop-types\"\nimport propTypesExact from \"prop-types-exact\"\nimport {ShapeComponent, shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport {useBreakpoint} from \"responsive-breakpoints\"\nimport Widths from \"./widths\"\n\nconst dataSets = {}\n\n/** @typedef {{className?: string}} DataSetLike */\n/** @typedef {{attribute?: string}} TableColumnDefinition */\n/** @typedef {{identifier(): string, sortKey(): string, update(args: {width: number}): Promise<void>}} TableSettingColumn */\n/**\n * @typedef {object} HeaderTableLike\n * @property {(column: TableColumnDefinition) => string[]} headerClassNameForColumn\n * @property {(column: TableColumnDefinition) => {style?: object}} headerProps\n * @property {(args: object) => void} setState\n * @property {{styleForHeader(args: {style: object}): object}} tt\n */\n/** @typedef {{cursor?: \"col-resize\", height?: \"100%\", position: \"absolute\", right: number, top: number, width: number, zIndex: number}} ResizeHandleStyle */\n\n/**\n * @typedef {object} Props\n * @property {boolean} active\n * @property {Animated.Value} animatedWidth\n * @property {Animated.Value} animatedZIndex\n * @property {TableColumnDefinition} column\n * @property {boolean} resizing\n * @property {HeaderTableLike} table\n * @property {TableSettingColumn} tableSettingColumn\n * @property {DataSetLike} touchProps\n * @property {Widths} widths\n */\n/**\n * @typedef {object} State\n * @property {boolean} resizing\n */\nexport default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerTableHeaderColumn extends ShapeComponent {\n  static propTypes = propTypesExact({\n    active: PropTypes.bool.isRequired,\n    animatedWidth: PropTypes.instanceOf(Animated.Value).isRequired,\n    animatedZIndex: PropTypes.instanceOf(Animated.Value).isRequired,\n    column: PropTypes.object.isRequired,\n    resizing: PropTypes.bool.isRequired,\n    table: PropTypes.object.isRequired,\n    tableSettingColumn: PropTypes.object.isRequired,\n    touchProps: PropTypes.object.isRequired,\n    widths: PropTypes.instanceOf(Widths).isRequired\n  })\n\n  state = {\n    resizing: false\n  }\n\n  setup() {\n    const {name: breakpoint, mdUp, smDown} = useBreakpoint()\n\n    this.breakpoint = breakpoint\n    this.mdUp = mdUp\n    this.smDown = smDown\n\n    this.resizePanResponder = useMemo(\n      () => PanResponder.create({\n        onStartShouldSetPanResponder: (_e) => {\n          this.originalWidth = this.currentWidth\n          this.setState({resizing: true})\n          this.p.table.setState({resizing: true})\n\n          return true\n        },\n        onPanResponderMove: (_e, gestate) => {\n          const newWidth = this.tt.originalWidth + gestate.dx\n\n          this.p.widths.setWidthOfColumn({\n            identifier: this.p.tableSettingColumn.identifier(),\n            width: newWidth\n          })\n        },\n        onPanResponderRelease: this.tt.onResizeEnd,\n        onPanResponderTerminate: this.tt.onResizeEnd,\n        onPanResponderTerminationRequest: () => false // Don't let another PanResponder steal focus and stop resizing until release\n      }),\n      []\n    )\n  }\n\n  onResizeEnd = async () => {\n    this.p.table.setState({lastUpdate: new Date(), resizing: false})\n    this.setState({resizing: false})\n\n    const width = this.p.widths.getWidthOfColumn(this.p.tableSettingColumn.identifier())\n\n    await this.p.tableSettingColumn.update({width})\n  }\n\n  render() {\n    const {mdUp} = this.tt\n    const {active, animatedWidth, column, resizing, table, tableSettingColumn, touchProps} = this.p\n    const {styleForHeader} = table.tt\n    const headerProps = table.headerProps(column)\n    const {style, ...restColumnProps} = headerProps\n    const headerIdentifier = tableSettingColumn.identifier()\n    const actualStyle = useMemo(\n      () => {\n        // eslint-disable-next-line prefer-object-spread\n        const actualStyle = Object.assign(\n          {\n            cursor: resizing ? \"col-resize\" : undefined,\n            width: mdUp ? animatedWidth : \"100%\",\n            height: mdUp ? \"100%\" : undefined\n          },\n          style\n        )\n\n        return actualStyle\n      },\n      [active, animatedWidth, mdUp, resizing, style]\n    )\n\n    return (\n      <Header\n        dataSet={dataSets[`header-${headerIdentifier}`] ||= {\n          className: classNames(...table.headerClassNameForColumn(column)),\n          identifier: headerIdentifier\n        }}\n        onLayout={this.tt.onLayout}\n        style={styleForHeader({style: actualStyle})}\n        {...restColumnProps}\n      >\n        {mdUp &&\n          <Icon name=\"bars\" style={this.cache(\"barsIconStyle\", {marginRight: 3, fontSize: 12})} {...touchProps} />\n        }\n        <HeaderColumnContent column={column} table={table} tableSettingColumn={tableSettingColumn} />\n        {mdUp &&\n          <Animated.View\n            style={/** @type {object} */ (this.cache(\"resizeColumnViewStyle\", {\n              position: \"absolute\",\n              top: 0,\n              right: 0,\n              width: 10,\n              height: \"100%\",\n              cursor: \"col-resize\",\n              zIndex: 9999\n            }))}\n            {...this.tt.resizePanResponder.panHandlers}\n          />\n        }\n      </Header>\n    )\n  }\n\n  onLayout = (e) => {\n    const {width} = e.nativeEvent.layout\n\n    this.currentWidth = width\n  }\n}))\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-column.js","sourceRoot":"/src/","sources":["table/header-column.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable import/no-unresolved, no-return-assign, sort-imports */\nimport React, {useMemo} from \"react\"\nimport classNames from \"classnames\"\nimport Header from \"./components/header\"\nimport HeaderColumnContent from \"./header-column-content\"\nimport Icon from \"../utils/icon\"\nimport memo from \"set-state-compare/build/memo.js\"\nimport {Animated, PanResponder} from \"react-native\"\nimport PropTypes from \"prop-types\"\nimport propTypesExact from \"prop-types-exact\"\nimport {ShapeComponent, shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport {useBreakpoint} from \"responsive-breakpoints\"\nimport Widths from \"./widths\"\n\nconst dataSets = {}\n\n/** @typedef {{className?: string}} DataSetLike */\n/** @typedef {{attribute?: string}} TableColumnDefinition */\n/** @typedef {{identifier(): string, sortKey(): string, update(args: {width: number}): Promise<void>}} TableSettingColumn */\n/**\n * @typedef {object} HeaderTableLike\n * @property {(column: TableColumnDefinition) => string[]} headerClassNameForColumn\n * @property {(column: TableColumnDefinition) => {style?: object}} headerProps\n * @property {{lastUpdate: Date, resizing: boolean}} s\n * @property {{styleForHeader(args: {style: object}): object}} tt\n */\n/** @typedef {{cursor?: \"col-resize\", height?: \"100%\", position: \"absolute\", right: number, top: number, width: number, zIndex: number}} ResizeHandleStyle */\n\n/**\n * @typedef {object} Props\n * @property {boolean} active\n * @property {Animated.Value} animatedWidth\n * @property {Animated.Value} animatedZIndex\n * @property {TableColumnDefinition} column\n * @property {boolean} resizing\n * @property {HeaderTableLike} table\n * @property {TableSettingColumn} tableSettingColumn\n * @property {DataSetLike} touchProps\n * @property {Widths} widths\n */\n/**\n * @typedef {object} State\n * @property {boolean} resizing\n */\nexport default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerTableHeaderColumn extends ShapeComponent {\n  static propTypes = propTypesExact({\n    active: PropTypes.bool.isRequired,\n    animatedWidth: PropTypes.instanceOf(Animated.Value).isRequired,\n    animatedZIndex: PropTypes.instanceOf(Animated.Value).isRequired,\n    column: PropTypes.object.isRequired,\n    resizing: PropTypes.bool.isRequired,\n    table: PropTypes.object.isRequired,\n    tableSettingColumn: PropTypes.object.isRequired,\n    touchProps: PropTypes.object.isRequired,\n    widths: PropTypes.instanceOf(Widths).isRequired\n  })\n\n  state = {\n    resizing: false\n  }\n\n  setup() {\n    const {name: breakpoint, mdUp, smDown} = useBreakpoint()\n\n    this.breakpoint = breakpoint\n    this.mdUp = mdUp\n    this.smDown = smDown\n\n    this.resizePanResponder = useMemo(\n      () => PanResponder.create({\n        onStartShouldSetPanResponder: (_e) => {\n          this.originalWidth = this.currentWidth\n          this.s.resizing = true\n          this.p.table.s.resizing = true\n\n          return true\n        },\n        onPanResponderMove: (_e, gestate) => {\n          const newWidth = this.tt.originalWidth + gestate.dx\n\n          this.p.widths.setWidthOfColumn({\n            identifier: this.p.tableSettingColumn.identifier(),\n            width: newWidth\n          })\n        },\n        onPanResponderRelease: this.tt.onResizeEnd,\n        onPanResponderTerminate: this.tt.onResizeEnd,\n        onPanResponderTerminationRequest: () => false // Don't let another PanResponder steal focus and stop resizing until release\n      }),\n      []\n    )\n  }\n\n  onResizeEnd = async () => {\n    this.p.table.s.lastUpdate = new Date()\n    this.p.table.s.resizing = false\n    this.s.resizing = false\n\n    const width = this.p.widths.getWidthOfColumn(this.p.tableSettingColumn.identifier())\n\n    await this.p.tableSettingColumn.update({width})\n  }\n\n  render() {\n    const {mdUp} = this.tt\n    const {active, animatedWidth, column, resizing, table, tableSettingColumn, touchProps} = this.p\n    const {styleForHeader} = table.tt\n    const headerProps = table.headerProps(column)\n    const {style, ...restColumnProps} = headerProps\n    const headerIdentifier = tableSettingColumn.identifier()\n    const actualStyle = useMemo(\n      () => {\n        // eslint-disable-next-line prefer-object-spread\n        const actualStyle = Object.assign(\n          {\n            cursor: resizing ? \"col-resize\" : undefined,\n            width: mdUp ? animatedWidth : \"100%\",\n            height: mdUp ? \"100%\" : undefined\n          },\n          style\n        )\n\n        return actualStyle\n      },\n      [active, animatedWidth, mdUp, resizing, style]\n    )\n\n    return (\n      <Header\n        dataSet={dataSets[`header-${headerIdentifier}`] ||= {\n          className: classNames(...table.headerClassNameForColumn(column)),\n          identifier: headerIdentifier\n        }}\n        onLayout={this.tt.onLayout}\n        style={styleForHeader({style: actualStyle})}\n        {...restColumnProps}\n      >\n        {mdUp &&\n          <Icon name=\"bars\" style={this.cache(\"barsIconStyle\", {marginRight: 3, fontSize: 12})} {...touchProps} />\n        }\n        <HeaderColumnContent column={column} table={table} tableSettingColumn={tableSettingColumn} />\n        {mdUp &&\n          <Animated.View\n            style={/** @type {object} */ (this.cache(\"resizeColumnViewStyle\", {\n              position: \"absolute\",\n              top: 0,\n              right: 0,\n              width: 10,\n              height: \"100%\",\n              cursor: \"col-resize\",\n              zIndex: 9999\n            }))}\n            {...this.tt.resizePanResponder.panHandlers}\n          />\n        }\n      </Header>\n    )\n  }\n\n  onLayout = (e) => {\n    const {width} = e.nativeEvent.layout\n\n    this.currentWidth = width\n  }\n}))\n"]}
|
|
@@ -59,7 +59,11 @@ export default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>}
|
|
|
59
59
|
t(".sorted_by_column_reversed", { column: columnLabel, defaultValue: "Sorted by %{column} reversed" }), !sortedByPreparedColumn &&
|
|
60
60
|
t(".not_sorted", { defaultValue: "Not sorted" })] }) })] }));
|
|
61
61
|
}
|
|
62
|
-
onModalRequestClose = () =>
|
|
63
|
-
|
|
62
|
+
onModalRequestClose = () => {
|
|
63
|
+
this.s.modalOpen = false;
|
|
64
|
+
};
|
|
65
|
+
onSortedByPress = () => {
|
|
66
|
+
this.s.modalOpen = true;
|
|
67
|
+
};
|
|
64
68
|
}));
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-select.js","sourceRoot":"/src/","sources":["table/header-select.jsx"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n/* eslint-disable implicit-arrow-linebreak, react/jsx-sort-props, sort-imports */\nimport {Pressable, View} from \"react-native\"\nimport Collection from \"../collection.js\"\nimport HeaderColumnContent from \"./header-column-content\"\nimport memo from \"set-state-compare/build/memo.js\"\nimport Modal from \"../utils/modal\"\nimport PropTypes from \"prop-types\"\nimport propTypesExact from \"prop-types-exact\"\nimport React from \"react\"\nimport {ShapeComponent, shapeComponent} from \"set-state-compare/build/shape-component.js\"\nimport Text from \"../utils/text\"\nimport useI18n from \"i18n-on-steroids/build/src/use-i18n.js\"\nimport useSorting from \"./use-sorting.js\"\n\n/**\n * @typedef {object} PreparedColumn\n * @property {object} column\n * @property {{identifier(): string, sortKey(): string}} tableSettingColumn\n */\n\n/**\n * @typedef {object} Props\n * @property {PreparedColumn[]} preparedColumns\n * @property {Collection} query\n * @property {{headerLabelForColumn(column: object): string}} [table]\n */\n/**\n * @typedef {object} State\n * @property {boolean} modalOpen\n */\nexport default memo(shapeComponent(/** @augments {ShapeComponent<Props, State>} */ class ApiMakerTableHeaderSelect extends ShapeComponent {\n  static propTypes = propTypesExact({\n    preparedColumns: PropTypes.array.isRequired,\n    query: PropTypes.instanceOf(Collection).isRequired,\n    table: PropTypes.object\n  })\n\n  state = {\n    modalOpen: false\n  }\n\n  setup() {\n    const {t} = useI18n({namespace: \"js.api_maker.table.header_select\"})\n    const {preparedColumns, query} = this.p\n    const {qParams, searchKey, sortAttribute, sortMode} = useSorting({query})\n\n    this.qParams = qParams\n    this.searchKey = searchKey\n    this.sortAttribute = sortAttribute\n    this.sortMode = sortMode\n    this.t = t\n    this.sortedByPreparedColumn = preparedColumns.find((preparedColumn) => preparedColumn.tableSettingColumn.sortKey() == sortAttribute)\n  }\n\n  render() {\n    const {sortedByPreparedColumn, sortMode, t} = this.tt\n    const {table} = this.p\n    const column = sortedByPreparedColumn?.column\n    const columnLabel = column && table.headerLabelForColumn(column)\n\n    return (\n      <View dataSet={this.cache(\"rootViewDataSet\", {component: \"api-maker/table/header-select\"})}>\n        {this.s.modalOpen &&\n          <Modal dataSet={this.cache(\"modalDataSet\", {class: \"table-header-select-modal\"})} onRequestClose={this.tt.onModalRequestClose} transparent>\n            {this.p.preparedColumns.map(({column, tableSettingColumn}) =>\n              <View\n                key={tableSettingColumn.identifier()}\n                style={this.cache(\"headerColumnContentViewStyle\", {marginVertical: 5})}\n              >\n                <HeaderColumnContent\n                  column={column}\n                  table={table}\n                  tableSettingColumn={tableSettingColumn}\n                  sortLinkProps={this.cache(\"sortLinkProps\", {usePressable: true})}\n                />\n              </View>\n            )}\n          </Modal>\n        }\n        <Pressable onPress={this.tt.onSortedByPress}>\n          <Text>\n            {sortedByPreparedColumn && sortMode == \"asc\" &&\n              t(\".sorted_by_column\", {column: columnLabel, defaultValue: \"Sorted by %{column}\"})\n            }\n            {sortedByPreparedColumn && sortMode == \"desc\" &&\n              t(\".sorted_by_column_reversed\", {column: columnLabel, defaultValue: \"Sorted by %{column} reversed\"})\n            }\n            {!sortedByPreparedColumn &&\n              t(\".not_sorted\", {defaultValue: \"Not sorted\"})\n            }\n          </Text>\n        </Pressable>\n      </View>\n    )\n  }\n\n  onModalRequestClose = () => {\n    this.s.modalOpen = false\n  }\n\n  onSortedByPress = () => {\n    this.s.modalOpen = true\n  }\n}))\n"]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @callback AnimateDraggedColumn
|
|
3
|
+
* @param {object} animatedPosition
|
|
4
|
+
* @param {object} animationArgs
|
|
5
|
+
* @returns {{start: () => void}}
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* @typedef {{setValue(value: {x?: number, y?: number}): void}} AnimatedPositionLike
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* @typedef {object} MoveDraggedColumnPositionArgs
|
|
12
|
+
* @property {object} item
|
|
13
|
+
* @property {object} [animationArgs]
|
|
14
|
+
* @property {AnimateDraggedColumn} [timing]
|
|
15
|
+
* @property {number} [x]
|
|
16
|
+
* @property {number} [y]
|
|
17
|
+
*/
|
|
18
|
+
/**
|
|
19
|
+
* Move the dragged table column using the item's current animated position.
|
|
20
|
+
* @param {MoveDraggedColumnPositionArgs} args
|
|
21
|
+
* @returns {void}
|
|
22
|
+
*/
|
|
23
|
+
export default function moveDraggedColumnPosition({ animationArgs, item, timing, x, y }: MoveDraggedColumnPositionArgs): void;
|
|
24
|
+
export type AnimateDraggedColumn = (animatedPosition: object, animationArgs: object) => {
|
|
25
|
+
start: () => void;
|
|
26
|
+
};
|
|
27
|
+
export type AnimatedPositionLike = {
|
|
28
|
+
setValue(value: {
|
|
29
|
+
x?: number;
|
|
30
|
+
y?: number;
|
|
31
|
+
}): void;
|
|
32
|
+
};
|
|
33
|
+
export type MoveDraggedColumnPositionArgs = {
|
|
34
|
+
item: object;
|
|
35
|
+
animationArgs?: object;
|
|
36
|
+
timing?: AnimateDraggedColumn;
|
|
37
|
+
x?: number;
|
|
38
|
+
y?: number;
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=move-dragged-column-position.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"move-dragged-column-position.d.ts","sourceRoot":"/src/","sources":["table/move-dragged-column-position.js"],"names":[],"mappings":"AAEA;;;;;GAKG;AAEH;;GAEG;AAEH;;;;;;;GAOG;AAEH;;;;GAIG;AACH,yFAHW,6BAA6B,GAC3B,IAAI,CAchB;sDAnCU,MAAM,iBACN,MAAM,KACJ;IAAC,KAAK,EAAE,MAAM,IAAI,CAAA;CAAC;mCAInB;IAAC,QAAQ,CAAC,KAAK,EAAE;QAAC,CAAC,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,CAAC,EAAE,MAAM,CAAA;KAAC,GAAG,IAAI,CAAA;CAAC;;UAKhD,MAAM;oBACN,MAAM;aACN,oBAAoB;QACpB,MAAM;QACN,MAAM"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
// @ts-check
|
|
2
|
+
/**
|
|
3
|
+
* @callback AnimateDraggedColumn
|
|
4
|
+
* @param {object} animatedPosition
|
|
5
|
+
* @param {object} animationArgs
|
|
6
|
+
* @returns {{start: () => void}}
|
|
7
|
+
*/
|
|
8
|
+
/**
|
|
9
|
+
* @typedef {{setValue(value: {x?: number, y?: number}): void}} AnimatedPositionLike
|
|
10
|
+
*/
|
|
11
|
+
/**
|
|
12
|
+
* @typedef {object} MoveDraggedColumnPositionArgs
|
|
13
|
+
* @property {object} item
|
|
14
|
+
* @property {object} [animationArgs]
|
|
15
|
+
* @property {AnimateDraggedColumn} [timing]
|
|
16
|
+
* @property {number} [x]
|
|
17
|
+
* @property {number} [y]
|
|
18
|
+
*/
|
|
19
|
+
/**
|
|
20
|
+
* Move the dragged table column using the item's current animated position.
|
|
21
|
+
* @param {MoveDraggedColumnPositionArgs} args
|
|
22
|
+
* @returns {void}
|
|
23
|
+
*/
|
|
24
|
+
export default function moveDraggedColumnPosition({ animationArgs, item, timing, x, y }) {
|
|
25
|
+
const { animatedPosition } = /** @type {{animatedPosition?: AnimatedPositionLike}} */ (item);
|
|
26
|
+
if (!animatedPosition)
|
|
27
|
+
throw new Error("Expected dragged table column to have an animated position");
|
|
28
|
+
if (animationArgs) {
|
|
29
|
+
if (!timing)
|
|
30
|
+
throw new Error("Expected a timing animation function");
|
|
31
|
+
timing(animatedPosition, animationArgs).start();
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
animatedPosition.setValue({ x, y });
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW92ZS1kcmFnZ2VkLWNvbHVtbi1wb3NpdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIvc3JjLyIsInNvdXJjZXMiOlsidGFibGUvbW92ZS1kcmFnZ2VkLWNvbHVtbi1wb3NpdGlvbi5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxZQUFZO0FBRVo7Ozs7O0dBS0c7QUFFSDs7R0FFRztBQUVIOzs7Ozs7O0dBT0c7QUFFSDs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE9BQU8sVUFBVSx5QkFBeUIsQ0FBQyxFQUFDLGFBQWEsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUM7SUFDbkYsTUFBTSxFQUFDLGdCQUFnQixFQUFDLEdBQUcsd0RBQXdELENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUUxRixJQUFJLENBQUMsZ0JBQWdCO1FBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyw0REFBNEQsQ0FBQyxDQUFBO0lBRXBHLElBQUksYUFBYSxFQUFFLENBQUM7UUFDbEIsSUFBSSxDQUFDLE1BQU07WUFBRSxNQUFNLElBQUksS0FBSyxDQUFDLHNDQUFzQyxDQUFDLENBQUE7UUFFcEUsTUFBTSxDQUFDLGdCQUFnQixFQUFFLGFBQWEsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFBO0lBQ2pELENBQUM7U0FBTSxDQUFDO1FBQ04sZ0JBQWdCLENBQUMsUUFBUSxDQUFDLEVBQUMsQ0FBQyxFQUFFLENBQUMsRUFBQyxDQUFDLENBQUE7SUFDbkMsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAdHMtY2hlY2tcblxuLyoqXG4gKiBAY2FsbGJhY2sgQW5pbWF0ZURyYWdnZWRDb2x1bW5cbiAqIEBwYXJhbSB7b2JqZWN0fSBhbmltYXRlZFBvc2l0aW9uXG4gKiBAcGFyYW0ge29iamVjdH0gYW5pbWF0aW9uQXJnc1xuICogQHJldHVybnMge3tzdGFydDogKCkgPT4gdm9pZH19XG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7e3NldFZhbHVlKHZhbHVlOiB7eD86IG51bWJlciwgeT86IG51bWJlcn0pOiB2b2lkfX0gQW5pbWF0ZWRQb3NpdGlvbkxpa2VcbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IE1vdmVEcmFnZ2VkQ29sdW1uUG9zaXRpb25BcmdzXG4gKiBAcHJvcGVydHkge29iamVjdH0gaXRlbVxuICogQHByb3BlcnR5IHtvYmplY3R9IFthbmltYXRpb25BcmdzXVxuICogQHByb3BlcnR5IHtBbmltYXRlRHJhZ2dlZENvbHVtbn0gW3RpbWluZ11cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBbeF1cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBbeV1cbiAqL1xuXG4vKipcbiAqIE1vdmUgdGhlIGRyYWdnZWQgdGFibGUgY29sdW1uIHVzaW5nIHRoZSBpdGVtJ3MgY3VycmVudCBhbmltYXRlZCBwb3NpdGlvbi5cbiAqIEBwYXJhbSB7TW92ZURyYWdnZWRDb2x1bW5Qb3NpdGlvbkFyZ3N9IGFyZ3NcbiAqIEByZXR1cm5zIHt2b2lkfVxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBtb3ZlRHJhZ2dlZENvbHVtblBvc2l0aW9uKHthbmltYXRpb25BcmdzLCBpdGVtLCB0aW1pbmcsIHgsIHl9KSB7XG4gIGNvbnN0IHthbmltYXRlZFBvc2l0aW9ufSA9IC8qKiBAdHlwZSB7e2FuaW1hdGVkUG9zaXRpb24/OiBBbmltYXRlZFBvc2l0aW9uTGlrZX19ICovIChpdGVtKVxuXG4gIGlmICghYW5pbWF0ZWRQb3NpdGlvbikgdGhyb3cgbmV3IEVycm9yKFwiRXhwZWN0ZWQgZHJhZ2dlZCB0YWJsZSBjb2x1bW4gdG8gaGF2ZSBhbiBhbmltYXRlZCBwb3NpdGlvblwiKVxuXG4gIGlmIChhbmltYXRpb25BcmdzKSB7XG4gICAgaWYgKCF0aW1pbmcpIHRocm93IG5ldyBFcnJvcihcIkV4cGVjdGVkIGEgdGltaW5nIGFuaW1hdGlvbiBmdW5jdGlvblwiKVxuXG4gICAgdGltaW5nKGFuaW1hdGVkUG9zaXRpb24sIGFuaW1hdGlvbkFyZ3MpLnN0YXJ0KClcbiAgfSBlbHNlIHtcbiAgICBhbmltYXRlZFBvc2l0aW9uLnNldFZhbHVlKHt4LCB5fSlcbiAgfVxufVxuIl19
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"table.d.ts","sourceRoot":"/src/","sources":["table/table.jsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"table.d.ts","sourceRoot":"/src/","sources":["table/table.jsx"],"names":[],"mappings":"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"}
|