adui
Version:
<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>
131 lines (110 loc) • 14.3 kB
JavaScript
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
import * as React from "react";
import { mount } from "enzyme";
import Table from "..";
window.ResizeObserver = window.ResizeObserver || jest.fn().mockImplementation(function () {
return {
disconnect: jest.fn(),
observe: jest.fn(),
unobserve: jest.fn()
};
});
var Column = Table.Column;
var SortMounter = function (_React$Component) {
_inherits(SortMounter, _React$Component);
var _super = _createSuper(SortMounter);
function SortMounter() {
var _this;
_classCallCheck(this, SortMounter);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
_this.state = {
sortOrder: undefined
};
return _this;
}
_createClass(SortMounter, [{
key: "render",
value: function render() {
var _this2 = this;
var sortOrder = this.state.sortOrder;
return React.createElement(Table, {
dataSource: [{
order: "order"
}]
}, React.createElement(Column, {
title: "\u6392\u5E8F",
dataIndex: "order",
sortOrder: sortOrder,
onSort: function onSort(argSortOrder) {
return _this2.setState({
sortOrder: argSortOrder
});
}
}));
}
}]);
return SortMounter;
}(React.Component);
describe("排序功能", function () {
it("是否能够内部驱动", function () {
var onSort = jest.fn();
var wrapper = mount(React.createElement(Table, {
dataSource: [{
order: "order"
}]
}, React.createElement(Column, {
title: "\u6392\u5E8F",
dataIndex: "order",
onSort: onSort
})));
expect(wrapper).toMatchSnapshot();
var th = wrapper.find("[role='columnheader']").at(0);
th.simulate("click");
expect(onSort).toHaveBeenCalledWith("desc");
th.simulate("click");
expect(onSort).toHaveBeenCalledWith("asc");
th.simulate("click");
expect(onSort).toHaveBeenCalledWith("");
});
it("是否能够外部控制", function () {
var wrapper = mount(React.createElement(SortMounter, null));
var th = wrapper.find("[role='columnheader']").at(0);
th.simulate("click");
expect(wrapper.find(".adui-table-sort").at(0).props()["data-sort"]).toBe("desc");
th.simulate("click");
expect(wrapper.find(".adui-table-sort").at(0).props()["data-sort"]).toBe("asc");
th.simulate("click");
expect(wrapper.find(".adui-table-sort").at(0).props()["data-sort"]).toBe("");
});
it("是否支持键盘操作", function () {
var onSort = jest.fn();
var wrapper = mount(React.createElement(Table, {
dataSource: [{
order: "order"
}]
}, React.createElement(Column, {
title: "\u6392\u5E8F",
dataIndex: "order",
onSort: onSort
})));
wrapper.find("[role='columnheader']").at(0).simulate("keyPress", {
key: "Enter",
keyCode: 13
});
expect(onSort).toHaveBeenCalled();
});
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","mount","Table","window","ResizeObserver","jest","fn","mockImplementation","disconnect","observe","unobserve","Column","SortMounter","state","sortOrder","undefined","order","argSortOrder","setState","Component","describe","it","onSort","wrapper","expect","toMatchSnapshot","th","find","at","simulate","toHaveBeenCalledWith","props","toBe","key","keyCode","toHaveBeenCalled"],"sources":["../../../components/table/__tests__/sort.test.tsx"],"sourcesContent":["import * as React from \"react\"\nimport { mount } from \"enzyme\"\nimport Table from \"..\"\n\nwindow.ResizeObserver =\n  window.ResizeObserver ||\n  jest.fn().mockImplementation(() => ({\n    disconnect: jest.fn(),\n    observe: jest.fn(),\n    unobserve: jest.fn(),\n  }))\n\nconst { Column } = Table\n\nclass SortMounter extends React.Component {\n  state = {\n    sortOrder: undefined,\n  }\n\n  render() {\n    const { sortOrder } = this.state\n    return (\n      <Table\n        dataSource={[\n          {\n            order: \"order\",\n          },\n        ]}\n      >\n        <Column\n          title=\"排序\"\n          dataIndex=\"order\"\n          sortOrder={sortOrder}\n          onSort={(argSortOrder) => this.setState({ sortOrder: argSortOrder })}\n        />\n      </Table>\n    )\n  }\n}\n\ndescribe(\"排序功能\", () => {\n  it(\"是否能够内部驱动\", () => {\n    const onSort = jest.fn()\n    const wrapper = mount(\n      <Table\n        dataSource={[\n          {\n            order: \"order\",\n          },\n        ]}\n      >\n        <Column title=\"排序\" dataIndex=\"order\" onSort={onSort} />\n      </Table>\n    )\n    expect(wrapper).toMatchSnapshot()\n    const th = wrapper.find(\"[role='columnheader']\").at(0)\n    th.simulate(\"click\")\n    expect(onSort).toHaveBeenCalledWith(\"desc\")\n    th.simulate(\"click\")\n    expect(onSort).toHaveBeenCalledWith(\"asc\")\n    th.simulate(\"click\")\n    expect(onSort).toHaveBeenCalledWith(\"\")\n  })\n\n  // it(\"onSort Prop 是否能验证 function\", () => {\n  //   const stub = sinon.stub(console, 'error')\n  //   const wrapper = render(\n  //     <Table>\n  //       <Table.Column\n  //         title=\"title\"\n  //         onSort=\"string\"\n  //       />\n  //     </Table>\n  //   )\n  //   expect(stub.callCount).toBe(1)\n  //   stub.restore()\n  // })\n\n  it(\"是否能够外部控制\", () => {\n    const wrapper = mount(<SortMounter />)\n    const th = wrapper.find(\"[role='columnheader']\").at(0)\n    th.simulate(\"click\")\n    expect(wrapper.find(\".adui-table-sort\").at(0).props()[\"data-sort\"]).toBe(\n      \"desc\"\n    )\n    th.simulate(\"click\")\n    expect(wrapper.find(\".adui-table-sort\").at(0).props()[\"data-sort\"]).toBe(\n      \"asc\"\n    )\n    th.simulate(\"click\")\n    expect(wrapper.find(\".adui-table-sort\").at(0).props()[\"data-sort\"]).toBe(\"\")\n  })\n\n  it(\"是否支持键盘操作\", () => {\n    const onSort = jest.fn()\n    const wrapper = mount(\n      <Table\n        dataSource={[\n          {\n            order: \"order\",\n          },\n        ]}\n      >\n        <Column title=\"排序\" dataIndex=\"order\" onSort={onSort} />\n      </Table>\n    )\n    wrapper\n      .find(\"[role='columnheader']\")\n      .at(0)\n      .simulate(\"keyPress\", { key: \"Enter\", keyCode: 13 })\n    expect(onSort).toHaveBeenCalled()\n  })\n})\n"],"mappings":"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"}