2022-12-29 11:48:24 +00:00
|
|
|
import React, { useState } from 'react';
|
2023-01-04 07:58:55 +00:00
|
|
|
import cx from 'classnames';
|
2022-12-29 11:48:24 +00:00
|
|
|
import Select from '@/_ui/Select';
|
|
|
|
|
import { components } from 'react-select';
|
|
|
|
|
import { EditVersion } from './EditVersionModal';
|
|
|
|
|
import { CreateVersion } from './CreateVersionModal';
|
2023-01-04 12:11:40 +00:00
|
|
|
import { ConfirmDialog } from '@/_components';
|
2022-12-29 11:48:24 +00:00
|
|
|
|
|
|
|
|
const Menu = (props) => {
|
|
|
|
|
return (
|
|
|
|
|
<components.Menu {...props}>
|
|
|
|
|
<div>
|
|
|
|
|
<div
|
|
|
|
|
className="cursor-pointer"
|
|
|
|
|
style={{ padding: '8px 12px' }}
|
|
|
|
|
onClick={() => props.selectProps.setShowEditAppVersion(true)}
|
|
|
|
|
>
|
|
|
|
|
<div className="row">
|
|
|
|
|
<div className="col-10">{props?.selectProps?.value?.appVersionName}</div>
|
|
|
|
|
<div className="col-1">
|
|
|
|
|
<svg
|
|
|
|
|
className="icon"
|
|
|
|
|
width="28"
|
|
|
|
|
height="28"
|
|
|
|
|
viewBox="0 0 28 28"
|
|
|
|
|
fill="none"
|
|
|
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
|
|
|
>
|
|
|
|
|
<rect width="28" height="28" rx="6" fill="#F0F4FF" />
|
|
|
|
|
<path
|
|
|
|
|
fillRule="evenodd"
|
|
|
|
|
clipRule="evenodd"
|
|
|
|
|
d="M16.7467 8.69582C17.0858 8.35696 17.5456 8.1666 18.025 8.1666C18.5046 8.1666 18.9646 8.35713 19.3037 8.69627C19.6429 9.03541 19.8334 9.49538 19.8334 9.975C19.8334 10.4545 19.643 10.9143 19.304 11.2534C19.3039 11.2535 19.3041 11.2533 19.304 11.2534L18.5667 11.9934C18.5462 12.0236 18.5226 12.0524 18.4958 12.0791C18.4695 12.1054 18.4414 12.1287 18.4118 12.1489L14.4132 16.1617C14.3038 16.2716 14.1551 16.3333 14 16.3333H12.25C11.9278 16.3333 11.6667 16.0722 11.6667 15.75V14C11.6667 13.8449 11.7284 13.6962 11.8383 13.5868L15.8511 9.58823C15.8713 9.55862 15.8946 9.53046 15.9209 9.50419C15.9476 9.4774 15.9764 9.45376 16.0066 9.43327L16.7463 8.69627C16.7464 8.69612 16.7466 8.69597 16.7467 8.69582ZM16.3399 10.7482L12.8333 14.2422V15.1667H13.7578L17.2518 11.6601L16.3399 10.7482ZM18.0753 10.8337L17.1663 9.9247L17.5712 9.52123C17.6916 9.40088 17.8548 9.33327 18.025 9.33327C18.1952 9.33327 18.3584 9.40088 18.4788 9.52123C18.5991 9.64158 18.6667 9.8048 18.6667 9.975C18.6667 10.1452 18.5991 10.3084 18.4788 10.4288L18.0753 10.8337ZM9.26256 11.0126C9.59075 10.6844 10.0359 10.5 10.5 10.5H11.0833C11.4055 10.5 11.6667 10.7612 11.6667 11.0833C11.6667 11.4055 11.4055 11.6667 11.0833 11.6667H10.5C10.3453 11.6667 10.1969 11.7281 10.0875 11.8375C9.97812 11.9469 9.91667 12.0953 9.91667 12.25V17.5C9.91667 17.6547 9.97812 17.8031 10.0875 17.9125C10.1969 18.0219 10.3453 18.0833 10.5 18.0833H15.75C15.9047 18.0833 16.0531 18.0219 16.1625 17.9125C16.2719 17.8031 16.3333 17.6547 16.3333 17.5V16.9167C16.3333 16.5945 16.5945 16.3333 16.9167 16.3333C17.2388 16.3333 17.5 16.5945 17.5 16.9167V17.5C17.5 17.9641 17.3156 18.4092 16.9874 18.7374C16.6592 19.0656 16.2141 19.25 15.75 19.25H10.5C10.0359 19.25 9.59075 19.0656 9.26256 18.7374C8.93437 18.4092 8.75 17.9641 8.75 17.5V12.25C8.75 11.7859 8.93437 11.3408 9.26256 11.0126Z"
|
|
|
|
|
fill="#3E63DD"
|
|
|
|
|
/>
|
|
|
|
|
</svg>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<hr className="m-0" />
|
|
|
|
|
<div>{props.children}</div>
|
|
|
|
|
<div
|
|
|
|
|
className="cursor-pointer"
|
|
|
|
|
style={{ padding: '8px 12px', color: '#3E63DD' }}
|
2023-01-05 09:06:39 +00:00
|
|
|
onClick={() => props.selectProps.setShowCreateAppVersion(true)}
|
2022-12-29 11:48:24 +00:00
|
|
|
>
|
|
|
|
|
<svg
|
|
|
|
|
className="icon me-1"
|
|
|
|
|
width="34"
|
|
|
|
|
height="34"
|
|
|
|
|
viewBox="0 0 34 34"
|
|
|
|
|
fill="none"
|
|
|
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
|
|
|
>
|
|
|
|
|
<rect width="34" height="34" rx="6" fill="#F0F4FF" />
|
|
|
|
|
<path
|
|
|
|
|
fillRule="evenodd"
|
|
|
|
|
clipRule="evenodd"
|
|
|
|
|
d="M17 11C17.4142 11 17.75 11.3358 17.75 11.75V16.25H22.25C22.6642 16.25 23 16.5858 23 17C23 17.4142 22.6642 17.75 22.25 17.75H17.75V22.25C17.75 22.6642 17.4142 23 17 23C16.5858 23 16.25 22.6642 16.25 22.25V17.75H11.75C11.3358 17.75 11 17.4142 11 17C11 16.5858 11.3358 16.25 11.75 16.25H16.25V11.75C16.25 11.3358 16.5858 11 17 11Z"
|
|
|
|
|
fill="#3E63DD"
|
|
|
|
|
/>
|
|
|
|
|
</svg>
|
|
|
|
|
Create new version
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</components.Menu>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
2023-02-02 15:28:06 +00:00
|
|
|
const SingleValue = ({ selectProps }) => {
|
2022-12-29 11:48:24 +00:00
|
|
|
return (
|
2023-02-02 09:11:25 +00:00
|
|
|
<div className="d-inline-flex align-items-center" data-cy="app-version-label">
|
2022-12-29 11:48:24 +00:00
|
|
|
<svg className="me-2" width="35" height="21" viewBox="0 0 35 21" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
|
|
|
<path
|
|
|
|
|
fillRule="evenodd"
|
|
|
|
|
clipRule="evenodd"
|
|
|
|
|
d="M4.44531 6.13737C4.12315 6.13737 3.86198 6.39854 3.86198 6.7207C3.86198 7.04287 4.12315 7.30404 4.44531 7.30404C4.76748 7.30404 5.02865 7.04287 5.02865 6.7207C5.02865 6.39854 4.76748 6.13737 4.44531 6.13737ZM2.69531 6.7207C2.69531 5.7542 3.47881 4.9707 4.44531 4.9707C5.41181 4.9707 6.19531 5.7542 6.19531 6.7207C6.19531 7.48266 5.70834 8.13089 5.02865 8.37112V12.0703C5.52589 12.246 5.91998 12.6401 6.09573 13.1374H9.11198C9.26669 13.1374 9.41506 13.0759 9.52446 12.9665C9.63385 12.8571 9.69531 12.7087 9.69531 12.554V11.0457L8.94112 11.7998C8.71332 12.0277 8.34397 12.0277 8.11617 11.7998C7.88836 11.572 7.88836 11.2027 8.11617 10.9749L9.86617 9.22489C10.094 8.99709 10.4633 8.99709 10.6911 9.22489L12.4411 10.9749C12.6689 11.2027 12.6689 11.572 12.4411 11.7998C12.2133 12.0277 11.844 12.0277 11.6162 11.7998L10.862 11.0457V12.554C10.862 13.0182 10.6776 13.4633 10.3494 13.7915C10.0212 14.1197 9.57611 14.304 9.11198 14.304H6.09573C5.8555 14.9837 5.20727 15.4707 4.44531 15.4707C3.47881 15.4707 2.69531 14.6872 2.69531 13.7207C2.69531 12.9587 3.18228 12.3105 3.86198 12.0703V8.37112C3.18228 8.13089 2.69531 7.48266 2.69531 6.7207ZM10.2786 6.13737C9.95648 6.13737 9.69531 6.39854 9.69531 6.7207C9.69531 7.04287 9.95648 7.30404 10.2786 7.30404C10.6008 7.30404 10.862 7.04287 10.862 6.7207C10.862 6.39854 10.6008 6.13737 10.2786 6.13737ZM8.52865 6.7207C8.52865 5.7542 9.31215 4.9707 10.2786 4.9707C11.2451 4.9707 12.0286 5.7542 12.0286 6.7207C12.0286 7.6872 11.2451 8.4707 10.2786 8.4707C9.31215 8.4707 8.52865 7.6872 8.52865 6.7207ZM4.44531 13.1374C4.12315 13.1374 3.86198 13.3985 3.86198 13.7207C3.86198 14.0429 4.12315 14.304 4.44531 14.304C4.76748 14.304 5.02865 14.0429 5.02865 13.7207C5.02865 13.3985 4.76748 13.1374 4.44531 13.1374Z"
|
|
|
|
|
fill="#E93D82"
|
|
|
|
|
/>
|
|
|
|
|
<path
|
|
|
|
|
d="M20.1074 12.9258L22.6211 5.68945H23.8457L20.6875 14.2207H19.8145L20.1074 12.9258ZM17.7578 5.68945L20.248 12.9258L20.5586 14.2207H19.6855L16.5332 5.68945H17.7578ZM27.2031 14.3379C26.7617 14.3379 26.3613 14.2637 26.002 14.1152C25.6465 13.9629 25.3398 13.75 25.082 13.4766C24.8281 13.2031 24.6328 12.8789 24.4961 12.5039C24.3594 12.1289 24.291 11.7188 24.291 11.2734V11.0273C24.291 10.5117 24.3672 10.0527 24.5195 9.65039C24.6719 9.24414 24.8789 8.90039 25.1406 8.61914C25.4023 8.33789 25.6992 8.125 26.0312 7.98047C26.3633 7.83594 26.707 7.76367 27.0625 7.76367C27.5156 7.76367 27.9062 7.8418 28.2344 7.99805C28.5664 8.1543 28.8379 8.37305 29.0488 8.6543C29.2598 8.93164 29.416 9.25977 29.5176 9.63867C29.6191 10.0137 29.6699 10.4238 29.6699 10.8691V11.3555H24.9355V10.4707H28.5859V10.3887C28.5703 10.1074 28.5117 9.83398 28.4102 9.56836C28.3125 9.30273 28.1562 9.08398 27.9414 8.91211C27.7266 8.74023 27.4336 8.6543 27.0625 8.6543C26.8164 8.6543 26.5898 8.70703 26.3828 8.8125C26.1758 8.91406 25.998 9.06641 25.8496 9.26953C25.7012 9.47266 25.5859 9.7207 25.5039 10.0137C25.4219 10.3066 25.3809 10.6445 25.3809 11.0273V11.2734C25.3809 11.5742 25.4219 11.8574 25.5039 12.123C25.5898 12.3848 25.7129 12.6152 25.873 12.8145C26.0371 13.0137 26.2344 13.1699 26.4648 13.2832C26.6992 13.3965 26.9648 13.4531 27.2617 13.4531C27.6445 13.4531 27.9688 13.375 28.2344 13.2188C28.5 13.0625 28.7324 12.8535 28.9316 12.5918L29.5879 13.1133C29.4512 13.3203 29.2773 13.5176 29.0664 13.7051C28.8555 13.8926 28.5957 14.0449 28.2871 14.1621C27.9824 14.2793 27.6211 14.3379 27.2031 14.3379ZM32.0195 8.87695V14.2207H30.9355V7.88086H31.9902L32.0195 8.87695ZM34 7.8457L33.9941 8.85352C33.9043 8.83398 33.8184 8.82227 33.7363 8.81836C33.6582 8.81055 33.5684 8.80664 33.4668 8.80664C33.2168 8.80664 32.9961 8.8457 32.8047 8.92383C32.6133 9.00195 32.4512 9.11133 32.3184 9.25195C32.1855 9.39258 32.0801 9.56055 32.002 9.75586C31.9277 9.94727 31.8789 10.1582 31.8555 10.3887L31.5508 10.5645C31.5508 10.1816 31.5879 9.82227 31.6621 9.48633C31.7402 9.15039 31.8594 8.85352 32.0195 8.5957C32.1797 8.33398 32.3828 8.13086 32.6289 7.98633C32.8789 7.83789 33.1758 7.76367 33.5195 7.76367C33.5977 7.76367 33.6875 7.77344 33.7891 7.79297C33.8906 7.80859 33.9609 7.82617 34 7.8457Z"
|
|
|
|
|
fill="#E03177"
|
|
|
|
|
/>
|
|
|
|
|
</svg>
|
2023-02-02 09:11:25 +00:00
|
|
|
<div
|
|
|
|
|
className={cx('app-version-name', { 'color-light-green': selectProps.value.isReleasedVersion })}
|
|
|
|
|
data-cy={`${selectProps.value?.appVersionName}-current-version-text`}
|
|
|
|
|
>
|
2023-01-04 07:58:55 +00:00
|
|
|
{selectProps.value?.appVersionName}
|
|
|
|
|
</div>
|
2022-12-29 11:48:24 +00:00
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export const CustomSelect = ({ ...props }) => {
|
|
|
|
|
const [showEditAppVersion, setShowEditAppVersion] = useState(false);
|
|
|
|
|
const [showCreateAppVersion, setShowCreateAppVersion] = useState(false);
|
2023-01-04 12:11:40 +00:00
|
|
|
|
|
|
|
|
const { deleteVersion, deleteAppVersion, resetDeleteModal } = props;
|
|
|
|
|
|
2022-12-29 11:48:24 +00:00
|
|
|
return (
|
|
|
|
|
<>
|
|
|
|
|
<CreateVersion
|
|
|
|
|
{...props}
|
|
|
|
|
showCreateAppVersion={showCreateAppVersion}
|
|
|
|
|
setShowCreateAppVersion={setShowCreateAppVersion}
|
|
|
|
|
/>
|
|
|
|
|
<EditVersion {...props} showEditAppVersion={showEditAppVersion} setShowEditAppVersion={setShowEditAppVersion} />
|
2023-01-04 12:11:40 +00:00
|
|
|
<ConfirmDialog
|
|
|
|
|
show={deleteVersion.showModal}
|
|
|
|
|
message={`Are you sure you want to delete this version - ${deleteVersion.versionName}`}
|
|
|
|
|
onConfirm={() => deleteAppVersion(deleteVersion.versionId, deleteVersion.versionName)}
|
|
|
|
|
onCancel={resetDeleteModal}
|
|
|
|
|
/>
|
2022-12-29 11:48:24 +00:00
|
|
|
<Select
|
|
|
|
|
width={'100%'}
|
|
|
|
|
classNamePrefix="custom-version-selector"
|
2023-02-02 09:11:25 +00:00
|
|
|
data-cy={`test-version-selector`}
|
2022-12-29 11:48:24 +00:00
|
|
|
hasSearch={false}
|
|
|
|
|
components={{ Menu, SingleValue }}
|
|
|
|
|
setShowEditAppVersion={setShowEditAppVersion}
|
|
|
|
|
setShowCreateAppVersion={setShowCreateAppVersion}
|
|
|
|
|
styles={{ border: 0 }}
|
|
|
|
|
{...props}
|
|
|
|
|
/>
|
|
|
|
|
</>
|
|
|
|
|
);
|
|
|
|
|
};
|