{"id":66039,"date":"2024-06-10T19:47:52","date_gmt":"2024-06-10T16:17:52","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/master-detail-react-datagrid-with-charts-15a3\/"},"modified":"2024-06-10T19:47:52","modified_gmt":"2024-06-10T16:17:52","slug":"master-detail-react-datagrid-with-charts-15a3","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/master-detail-react-datagrid-with-charts-15a3\/","title":{"rendered":"Master-Detail React DataGrid \u0628\u0627 \u0646\u0645\u0648\u062f\u0627\u0631\u0647\u0627"},"content":{"rendered":"<div data-article-id=\"1883379\" id=\"article-body\">\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0645 \u0628\u0647 \u0634\u0645\u0627 \u0646\u0634\u0627\u0646 \u062f\u0647\u0645 \u06a9\u0647 \u0686\u0642\u062f\u0631 \u0622\u0633\u0627\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0627\u0632 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u062c\u0632\u0626\u06cc\u0627\u062a \u0627\u0635\u0644\u06cc \u062f\u0631 Infinite Table React DataGrid \u0628\u0631\u0627\u06cc \u062c\u0627\u0628\u0647\u200c\u062c\u0627\u06cc\u06cc \u0628\u06cc\u0646 \u062c\u062f\u0648\u0644 \u0648 \u0646\u0645\u0627\u06cc \u0646\u0645\u0648\u062f\u0627\u0631 \u062f\u0631 \u062c\u0632\u0626\u06cc\u0627\u062a \u0631\u062f\u06cc\u0641 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p><iframe src=\"https:\/\/codesandbox.io\/embed\/gg7h4f\" style=\"width:100%; height:calc(300px + 8vw); border:0; border-radius: 4px; overflow:hidden;\" allow=\"geolocation; microphone; camera; midi; vr; accelerometer; gyroscope; payment; ambient-light-sensor; encrypted-media; usb\" loading=\"lazy\" sandbox=\"allow-modals allow-forms allow-popups allow-scripts allow-same-origin\"><br \/>\n<\/iframe>\n<\/p>\n<p>\u062f\u0631 \u0645\u0648\u0644\u0641\u0647 RowDetail \u062c\u062f\u0648\u0644 \u0628\u06cc \u0646\u0647\u0627\u06cc\u062a\u060c a \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code><datasource\/><\/code>\u060c \u06a9\u0647 \u0628\u0647 \u0646\u0648\u0628\u0647 \u062e\u0648\u062f \u0647\u0631 \u06cc\u06a9 \u0631\u0627 \u0631\u0646\u062f\u0631 \u0645\u06cc \u06a9\u0646\u062f <code><infinitetable\/><\/code> \u062c\u0632\u0621 \u06cc\u0627 \u0646\u0645\u0648\u062f\u0627\u0631<\/p>\n<p>\u0631\u0627 <code><datasource\/><\/code> \u062f\u0631 InfiniteTable \u0628\u0633\u06cc\u0627\u0631 \u0642\u062f\u0631\u062a\u0645\u0646\u062f \u0627\u0633\u062a \u0648 \u062a\u0645\u0627\u0645 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0634\u0628\u06a9\u0647 \u0631\u0627 \u067e\u0631\u062f\u0627\u0632\u0634 \u0645\u06cc \u06a9\u0646\u062f.  \u0647\u0645\u0647 \u06af\u0631\u0648\u0647 \u0628\u0646\u062f\u06cc \u0631\u062f\u06cc\u0641\u060c \u0645\u0631\u062a\u0628 \u0633\u0627\u0632\u06cc\u060c \u0641\u06cc\u0644\u062a\u0631 \u06a9\u0631\u062f\u0646\u060c \u062a\u062c\u0645\u0639\u060c \u0645\u062d\u0648\u0631\u06cc \u062f\u0631 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f <code><datasource\/><\/code> &#8211; \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0622\u0646 \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u0633\u062a\u0642\u0644 \u06cc\u0627 \u0628\u0627 InfiniteTable \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f &#8211; \u06a9\u0627\u0645\u0644\u0627\u064b \u0628\u0647 \u0634\u0645\u0627 \u0628\u0633\u062a\u06af\u06cc \u062f\u0627\u0631\u062f.<\/p>\n<p>\u062f\u0631 \u0639\u0645\u0644\u060c \u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code><datasource\/><\/code> \u0628\u0631\u0627\u06cc \u067e\u0631\u062f\u0627\u0632\u0634 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0634\u0645\u0627 \u0648 \u0633\u067e\u0633 \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc \u0622\u0646 \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0646\u0645\u0648\u062f\u0627\u0631 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u062f <code>ag-charts-react<\/code>.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight tsx\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">detailGroupBy<\/span><span class=\"p\">:<\/span> <span class=\"nx\">DataSourcePropGroupBy<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">Developer<\/span><span class=\"o\">&gt;<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[{<\/span> <span class=\"na\">field<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">stack<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">}];<\/span>\n<span class=\"kd\">const<\/span> <span class=\"nx\">detailAggregationReducers<\/span><span class=\"p\">:<\/span> <span class=\"nx\">DataSourcePropAggregationReducers<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">Developer<\/span><span class=\"o\">&gt;<\/span> <span class=\"o\">=<\/span>\n  <span class=\"p\">{<\/span>\n    <span class=\"na\">salary<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\n      <span class=\"na\">field<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">salary<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\n      <span class=\"na\">initialValue<\/span><span class=\"p\">:<\/span> <span class=\"mi\">0<\/span><span class=\"p\">,<\/span>\n      <span class=\"na\">reducer<\/span><span class=\"p\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">acc<\/span><span class=\"p\">,<\/span> <span class=\"nx\">value<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"nx\">acc<\/span> <span class=\"o\">+<\/span> <span class=\"nx\">value<\/span><span class=\"p\">,<\/span>\n      <span class=\"na\">done<\/span><span class=\"p\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">value<\/span><span class=\"p\">,<\/span> <span class=\"nx\">arr<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"nb\">Math<\/span><span class=\"p\">.<\/span><span class=\"nf\">round<\/span><span class=\"p\">(<\/span><span class=\"nx\">arr<\/span><span class=\"p\">.<\/span><span class=\"nx\">length<\/span> <span class=\"p\">?<\/span> <span class=\"nx\">value<\/span> <span class=\"o\">\/<\/span> <span class=\"nx\">arr<\/span><span class=\"p\">.<\/span><span class=\"nx\">length<\/span> <span class=\"p\">:<\/span> <span class=\"mi\">0<\/span><span class=\"p\">),<\/span>\n    <span class=\"p\">},<\/span>\n  <span class=\"p\">};<\/span>\n\n<span class=\"kd\">function<\/span> <span class=\"nf\">RowDetail<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\n  <span class=\"kd\">const<\/span> <span class=\"nx\">rowInfo<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">useMasterRowInfo<\/span><span class=\"o\">&lt;<\/span><span class=\"nx\">City<\/span><span class=\"o\">&gt;<\/span><span class=\"p\">()<\/span><span class=\"o\">!<\/span><span class=\"p\">;<\/span>\n  <span class=\"kd\">const<\/span> <span class=\"p\">[<\/span><span class=\"nx\">showChart<\/span><span class=\"p\">,<\/span> <span class=\"nx\">setShowChart<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">React<\/span><span class=\"p\">.<\/span><span class=\"nf\">useState<\/span><span class=\"p\">(<\/span><span class=\"nx\">rowInfo<\/span><span class=\"p\">.<\/span><span class=\"nx\">id<\/span> <span class=\"o\">%<\/span> <span class=\"mi\">2<\/span> <span class=\"o\">==<\/span> <span class=\"mi\">1<\/span><span class=\"p\">);<\/span>\n\n  <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\n    <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">style<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"p\">{...}<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\n      <span class=\"p\">&lt;<\/span><span class=\"nt\">button<\/span> <span class=\"na\">onClick<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"nf\">setShowChart<\/span><span class=\"p\">((<\/span><span class=\"nx\">showChart<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"o\">!<\/span><span class=\"nx\">showChart<\/span><span class=\"p\">)<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\n        Click to see <span class=\"si\">{<\/span><span class=\"nx\">showChart<\/span> <span class=\"p\">?<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">grid<\/span><span class=\"dl\">\"<\/span> <span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">chart<\/span><span class=\"dl\">\"<\/span><span class=\"si\">}<\/span>\n      <span class=\"p\"\/><span class=\"nt\">button<\/span><span class=\"p\">&gt;<\/span>\n\n      <span class=\"si\">{<\/span><span class=\"cm\">\/**\n       * In this example, we leverage the DataSource aggregation and grouping feature to\n       * calculate the average salary by stack for the selected city.\n       *\/<\/span><span class=\"si\">}<\/span>\n      <span class=\"p\">&lt;<\/span><span class=\"nc\">DataSource<\/span><span class=\"p\">&lt;<\/span><span class=\"nx\">Developer<\/span><span class=\"o\">&gt;<\/span>\n        <span class=\"nx\">data<\/span><span class=\"o\">=<\/span><span class=\"p\">{<\/span><span class=\"nx\">detailDataSource<\/span><span class=\"p\">}<\/span>\n        <span class=\"nx\">primaryKey<\/span><span class=\"o\">=<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">id<\/span><span class=\"dl\">\"<\/span>\n        <span class=\"nx\">groupBy<\/span><span class=\"o\">=<\/span><span class=\"p\">{<\/span><span class=\"nx\">detailGroupBy<\/span><span class=\"p\">}<\/span>\n        <span class=\"nx\">aggregationReducers<\/span><span class=\"o\">=<\/span><span class=\"p\">{<\/span><span class=\"nx\">detailAggregationReducers<\/span><span class=\"p\">}<\/span>\n      <span class=\"o\">&gt;<\/span>\n        <span class=\"p\">{<\/span><span class=\"cm\">\/**\n         * Notice here we're not rendering an InfiniteTable component\n         * but rather we use a render function to access the aggregated data.\n         *\/<\/span><span class=\"p\">}<\/span>\n        <span class=\"p\">{(<\/span><span class=\"nx\">params<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\n          <span class=\"c1\">\/\/ here we decide if we need to show the chart or the grid<\/span>\n          <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">showChart<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n            <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\n              <span class=\"p\">&lt;<\/span><span class=\"nc\">InfiniteTable<\/span>\n                <span class=\"na\">columns<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"nx\">detailColumns<\/span><span class=\"si\">}<\/span>\n                <span class=\"na\">domProps<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"p\">{<\/span>\n                  <span class=\"na\">style<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span> <span class=\"na\">paddingTop<\/span><span class=\"p\">:<\/span> <span class=\"mi\">30<\/span> <span class=\"p\">},<\/span>\n                <span class=\"p\">}<\/span><span class=\"si\">}<\/span>\n              <span class=\"p\">\/&gt;<\/span>\n            <span class=\"p\">);<\/span>\n          <span class=\"p\">}<\/span>\n\n          <span class=\"c1\">\/\/ the dataArray has all the aggregations and groupings done for us, <\/span>\n          <span class=\"c1\">\/\/ so we need to retrieve the correct rows and pass it to the charting library<\/span>\n          <span class=\"kd\">const<\/span> <span class=\"nx\">groups<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">params<\/span><span class=\"p\">.<\/span><span class=\"nx\">dataArray<\/span><span class=\"p\">.<\/span><span class=\"nf\">filter<\/span><span class=\"p\">((<\/span><span class=\"nx\">rowInfo<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"nx\">rowInfo<\/span><span class=\"p\">.<\/span><span class=\"nx\">isGroupRow<\/span><span class=\"p\">);<\/span>\n          <span class=\"kd\">const<\/span> <span class=\"nx\">groupData<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">groups<\/span><span class=\"p\">.<\/span><span class=\"nf\">map<\/span><span class=\"p\">((<\/span><span class=\"nx\">group<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">({<\/span> <span class=\"na\">stack<\/span><span class=\"p\">:<\/span> <span class=\"nx\">group<\/span><span class=\"p\">.<\/span><span class=\"nx\">data<\/span><span class=\"p\">?.<\/span><span class=\"nx\">stack<\/span><span class=\"p\">,<\/span> <span class=\"na\">avgSalary<\/span><span class=\"p\">:<\/span> <span class=\"nx\">group<\/span><span class=\"p\">.<\/span><span class=\"nx\">reducerData<\/span><span class=\"p\">?.<\/span><span class=\"nx\">salary<\/span> <span class=\"p\">}));<\/span>\n\n          <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\n            <span class=\"p\">&lt;<\/span><span class=\"nc\">AgChartsReact<\/span>\n              <span class=\"na\">options<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"p\">{<\/span>\n                <span class=\"na\">autoSize<\/span><span class=\"p\">:<\/span> <span class=\"kc\">true<\/span><span class=\"p\">,<\/span>\n                <span class=\"na\">title<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\n                  <span class=\"na\">text<\/span><span class=\"p\">:<\/span> <span class=\"s2\">`Avg salary by stack in <\/span><span class=\"p\">${<\/span><span class=\"nx\">rowInfo<\/span><span class=\"p\">.<\/span><span class=\"nx\">data<\/span><span class=\"p\">?.<\/span><span class=\"nx\">name<\/span><span class=\"p\">}<\/span><span class=\"s2\">, <\/span><span class=\"p\">${<\/span><span class=\"nx\">rowInfo<\/span><span class=\"p\">.<\/span><span class=\"nx\">data<\/span><span class=\"p\">?.<\/span><span class=\"nx\">country<\/span><span class=\"p\">}<\/span><span class=\"s2\">`<\/span><span class=\"p\">,<\/span>\n                <span class=\"p\">},<\/span>\n                <span class=\"na\">data<\/span><span class=\"p\">:<\/span> <span class=\"nx\">groupData<\/span><span class=\"p\">,<\/span>\n                <span class=\"na\">series<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span>\n                  <span class=\"p\">{<\/span>\n                    <span class=\"na\">type<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">bar<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\n                    <span class=\"na\">xKey<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">stack<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\n                    <span class=\"na\">yKey<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">avgSalary<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\n                    <span class=\"na\">yName<\/span><span class=\"p\">:<\/span> <span class=\"dl\">\"<\/span><span class=\"s2\">Average Salary<\/span><span class=\"dl\">\"<\/span><span class=\"p\">,<\/span>\n                  <span class=\"p\">},<\/span>\n                <span class=\"p\">],<\/span>\n              <span class=\"p\">}<\/span><span class=\"si\">}<\/span>\n            <span class=\"p\">\/&gt;<\/span>\n          <span class=\"p\">);<\/span>\n        <span class=\"p\">}}<\/span>\n      <span class=\"p\">&lt;<\/span><span class=\"err\">\/<\/span><span class=\"na\">DataSource<\/span><span class=\"p\">&gt;<\/span>\n    <span class=\"p\"\/><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\n  <span class=\"p\">);<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0646\u0633\u062e\u0647 \u06cc \u0646\u0645\u0627\u06cc\u0634\u06cc \u0628\u0627\u0644\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>ag-charts-react<\/code> \u0628\u0633\u062a\u0647 \u0628\u0631\u0627\u06cc \u0627\u0631\u0627\u0626\u0647 \u0646\u0645\u0648\u062f\u0627\u0631\u0647\u0627<\/p>\n<p>\u062f\u0631\u0628\u0627\u0631\u0647 \u0631\u0646\u062f\u0631 \u06a9\u0631\u062f\u0646 \u0645\u062d\u062a\u0648\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u062f\u0631 \u062a\u0646\u0638\u06cc\u0645 \u062c\u0632\u0626\u06cc\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f.<\/p>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0645 \u0628\u0647 \u0634\u0645\u0627 \u0646\u0634\u0627\u0646 \u062f\u0647\u0645 \u06a9\u0647 \u0686\u0642\u062f\u0631 \u0622\u0633\u0627\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0627\u0632 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u062c\u0632\u0626\u06cc\u0627\u062a \u0627\u0635\u0644\u06cc \u062f\u0631 Infinite Table React DataGrid \u0628\u0631\u0627\u06cc \u062c\u0627\u0628\u0647\u200c\u062c\u0627\u06cc\u06cc \u0628\u06cc\u0646 \u062c\u062f\u0648\u0644 \u0648 \u0646\u0645\u0627\u06cc \u0646\u0645\u0648\u062f\u0627\u0631 \u062f\u0631 \u062c\u0632\u0626\u06cc\u0627\u062a \u0631\u062f\u06cc\u0641 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f. \u062f\u0631 \u0645\u0648\u0644\u0641\u0647 RowDetail \u062c\u062f\u0648\u0644 \u0628\u06cc \u0646\u0647\u0627\u06cc\u062a\u060c a \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u060c \u06a9\u0647 \u0628\u0647 \u0646\u0648\u0628\u0647 \u062e\u0648\u062f \u0647\u0631 \u06cc\u06a9 \u0631\u0627 \u0631\u0646\u062f\u0631 \u0645\u06cc &hellip;<\/p>\n","protected":false},"author":2,"featured_media":66040,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-66039","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-dev"],"_links":{"self":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/66039","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/comments?post=66039"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/66039\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media\/66040"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=66039"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=66039"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=66039"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}