All files Filterdropdown.js

31.81% Statements 7/22
50% Branches 7/14
12.5% Functions 1/8
31.81% Lines 7/22

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142                        4x 4x                                                     1x                 1x   1x                                                                                                                                                                         4x   4x      
import {
  CalendarOutlined,
  RightOutlined,
  UserOutlined
} from '@ant-design/icons';
import { Button, Checkbox, Divider, Menu } from 'antd';
import React from 'react';
import dot from '../../assets/Table/dot.svg';
import Datesubmenu from '../Datesubmenu/Datesubmenu';
import Fromsubmenu from '../Fromsubmenu/Fromsubmenu';
import styles from './Filterdropdown.module.scss';
 
var finalChekedValues = [];
const Filterdropdown = ({
  frommenu,
  setFrommenu,
  datemenu,
  setDatemenu,
  handleCheckbox,
  handleFromname,
  handleDaterange,
  setFiltertoggle,
  setDisplayappliedfilter,
  checkedbox,
  setCheckedbox,
  fromname,
  daterange,
}) => {
  
  function onChange(checkedValues) {
    finalChekedValues = checkedValues;
    setCheckedbox(checkedValues);
  }
  /*****************************************************for apply btn**********************************************************************/
  function applyFilter() {
    setFiltertoggle(false);
    handleCheckbox(finalChekedValues);
    setDisplayappliedfilter(true);
  }
  /*************************************************For cancel button*****************************************************************/
  const onCancel = () => {
    handleFromname([]);
    handleCheckbox([]);
    handleDaterange('');
    setDisplayappliedfilter(false);
    setCheckedbox([]);
    setFiltertoggle(false);
  };
 
  const checkboxOptions = ['My@ Mentions', 'Has File Attached', 'Has a link'];
  
  return (
    <div className={styles.Filterdropdown}>
      {frommenu || datemenu ? (
        frommenu ? (
          <Fromsubmenu
            resetFrommenu={() => setFrommenu(false)}
            handleFromname={handleFromname}
          />
        ) : (
          <Datesubmenu
            resetDatemenu={() => setDatemenu(false)}
            handleDaterange={handleDaterange}
          />
        )
      ) : (
        <Menu className={styles.Filterdropdown__menu}>
          {/*****************************************From and Date range section***********************************************************************/}
          <Menu.Item
          key="1"
            className={
              fromname?.length != 0 ? styles.Filterdropdown__menu__selected : ''
            }
            icon={<UserOutlined />}
          >
            <span>
              From {fromname?.length != 0 ? <img src={dot} alt="dot" /> : ''}
            </span>
            <Button
              className={styles.Filterdropdown__menu__arrowBtn}
              ghost
              onClick={() => setFrommenu(true)}
            >
              <RightOutlined />
            </Button>
          </Menu.Item>
          <Divider className={styles.Filterdropdown__menu__separator} />
 
          <Menu.Item
          key='2'
            className={daterange ? styles.Filterdropdown__menu__selected : ' '}
            icon={<CalendarOutlined />}
          >
            <span>
              Date Range {daterange ? <img src={dot} alt="dot" /> : ''}
            </span>
            <Button
              className={styles.Filterdropdown__menu__arrowBtn}
              ghost
              onClick={() => setDatemenu(true)}
            >
              <RightOutlined />
            </Button>
          </Menu.Item>
          <Divider className={styles.Filterdropdown__menu__separator} />
 
          {/********************************************Checkbox Section*********************************************************************/}
          <Checkbox.Group
            options={checkboxOptions}
            value={checkedbox}
            onChange={onChange}
            className={styles.Filterdropdown__menu__checkboxContainer}
          ></Checkbox.Group>
          {/*************************************************Button section*************************************************************************/}
 
          <Divider className={styles.Filterdropdown__menu__separator} />
          <div className={styles.Filterdropdown__menu__btnSection}>
            <Button
              className={styles.Filterdropdown__menu__btnSection__cancel}
              onClick={onCancel}
            >
              Cancel
            </Button>
            <Button
              className={styles.Filterdropdown__menu__btnSection__apply}
              onClick={applyFilter}
            >
              Apply
            </Button>
          </div>
        </Menu>
      )}
    </div>
  );
};
 
Filterdropdown.propTypes = {};
 
Filterdropdown.defaultProps = {};
 
export default Filterdropdown;