Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/wp-conte.../plugins/leadin/scripts/shared/Common
File: AsyncSelect.tsx
import React, { useRef, useState, useEffect } from 'react';
[0] Fix | Delete
import { styled } from '@linaria/react';
[1] Fix | Delete
import {
[2] Fix | Delete
CALYPSO,
[3] Fix | Delete
CALYPSO_LIGHT,
[4] Fix | Delete
CALYPSO_MEDIUM,
[5] Fix | Delete
OBSIDIAN,
[6] Fix | Delete
} from '../UIComponents/colors';
[7] Fix | Delete
import UISpinner from '../UIComponents/UISpinner';
[8] Fix | Delete
import LoadState, { LoadStateType } from '../enums/loadState';
[9] Fix | Delete
[10] Fix | Delete
const Container = styled.div`
[11] Fix | Delete
color: ${OBSIDIAN};
[12] Fix | Delete
font-family: 'Lexend Deca', Helvetica, Arial, sans-serif;
[13] Fix | Delete
font-size: 14px;
[14] Fix | Delete
position: relative;
[15] Fix | Delete
`;
[16] Fix | Delete
[17] Fix | Delete
interface IControlContainerProps {
[18] Fix | Delete
focused: boolean;
[19] Fix | Delete
}
[20] Fix | Delete
[21] Fix | Delete
const ControlContainer = styled.div<IControlContainerProps>`
[22] Fix | Delete
align-items: center;
[23] Fix | Delete
background-color: hsl(0, 0%, 100%);
[24] Fix | Delete
border-color: hsl(0, 0%, 80%);
[25] Fix | Delete
border-radius: 4px;
[26] Fix | Delete
border-style: solid;
[27] Fix | Delete
border-width: ${props => (props.focused ? '0' : '1px')};
[28] Fix | Delete
cursor: default;
[29] Fix | Delete
display: flex;
[30] Fix | Delete
flex-wrap: wrap;
[31] Fix | Delete
justify-content: space-between;
[32] Fix | Delete
min-height: 38px;
[33] Fix | Delete
outline: 0 !important;
[34] Fix | Delete
position: relative;
[35] Fix | Delete
transition: all 100ms;
[36] Fix | Delete
box-sizing: border-box;
[37] Fix | Delete
box-shadow: ${props =>
[38] Fix | Delete
props.focused ? `0 0 0 2px ${CALYPSO_MEDIUM}` : 'none'};
[39] Fix | Delete
&:hover {
[40] Fix | Delete
border-color: hsl(0, 0%, 70%);
[41] Fix | Delete
}
[42] Fix | Delete
`;
[43] Fix | Delete
[44] Fix | Delete
const ValueContainer = styled.div`
[45] Fix | Delete
align-items: center;
[46] Fix | Delete
display: flex;
[47] Fix | Delete
flex: 1;
[48] Fix | Delete
flex-wrap: wrap;
[49] Fix | Delete
padding: 2px 8px;
[50] Fix | Delete
position: relative;
[51] Fix | Delete
overflow: hidden;
[52] Fix | Delete
box-sizing: border-box;
[53] Fix | Delete
`;
[54] Fix | Delete
[55] Fix | Delete
const Placeholder = styled.div`
[56] Fix | Delete
color: hsl(0, 0%, 50%);
[57] Fix | Delete
margin-left: 2px;
[58] Fix | Delete
margin-right: 2px;
[59] Fix | Delete
position: absolute;
[60] Fix | Delete
top: 50%;
[61] Fix | Delete
transform: translateY(-50%);
[62] Fix | Delete
box-sizing: border-box;
[63] Fix | Delete
font-size: 16px;
[64] Fix | Delete
`;
[65] Fix | Delete
[66] Fix | Delete
const SingleValue = styled.div`
[67] Fix | Delete
color: hsl(0, 0%, 20%);
[68] Fix | Delete
margin-left: 2px;
[69] Fix | Delete
margin-right: 2px;
[70] Fix | Delete
max-width: calc(100% - 8px);
[71] Fix | Delete
overflow: hidden;
[72] Fix | Delete
position: absolute;
[73] Fix | Delete
text-overflow: ellipsis;
[74] Fix | Delete
white-space: nowrap;
[75] Fix | Delete
top: 50%;
[76] Fix | Delete
transform: translateY(-50%);
[77] Fix | Delete
box-sizing: border-box;
[78] Fix | Delete
`;
[79] Fix | Delete
[80] Fix | Delete
const IndicatorContainer = styled.div`
[81] Fix | Delete
align-items: center;
[82] Fix | Delete
align-self: stretch;
[83] Fix | Delete
display: flex;
[84] Fix | Delete
flex-shrink: 0;
[85] Fix | Delete
box-sizing: border-box;
[86] Fix | Delete
`;
[87] Fix | Delete
[88] Fix | Delete
const DropdownIndicator = styled.div`
[89] Fix | Delete
border-top: 8px solid ${CALYPSO};
[90] Fix | Delete
border-left: 6px solid transparent;
[91] Fix | Delete
border-right: 6px solid transparent;
[92] Fix | Delete
width: 0px;
[93] Fix | Delete
height: 0px;
[94] Fix | Delete
margin: 10px;
[95] Fix | Delete
`;
[96] Fix | Delete
[97] Fix | Delete
const InputContainer = styled.div`
[98] Fix | Delete
margin: 2px;
[99] Fix | Delete
padding-bottom: 2px;
[100] Fix | Delete
padding-top: 2px;
[101] Fix | Delete
visibility: visible;
[102] Fix | Delete
color: hsl(0, 0%, 20%);
[103] Fix | Delete
box-sizing: border-box;
[104] Fix | Delete
`;
[105] Fix | Delete
[106] Fix | Delete
const Input = styled.input`
[107] Fix | Delete
box-sizing: content-box;
[108] Fix | Delete
background: rgba(0, 0, 0, 0) none repeat scroll 0px center;
[109] Fix | Delete
border: 0px none;
[110] Fix | Delete
font-size: inherit;
[111] Fix | Delete
opacity: 1;
[112] Fix | Delete
outline: currentcolor none 0px;
[113] Fix | Delete
padding: 0px;
[114] Fix | Delete
color: inherit;
[115] Fix | Delete
font-family: inherit;
[116] Fix | Delete
`;
[117] Fix | Delete
[118] Fix | Delete
const InputShadow = styled.div`
[119] Fix | Delete
position: absolute;
[120] Fix | Delete
opacity: 0;
[121] Fix | Delete
font-size: inherit;
[122] Fix | Delete
`;
[123] Fix | Delete
[124] Fix | Delete
const MenuContainer = styled.div`
[125] Fix | Delete
position: absolute;
[126] Fix | Delete
top: 100%;
[127] Fix | Delete
background-color: #fff;
[128] Fix | Delete
border-radius: 4px;
[129] Fix | Delete
margin-bottom: 8px;
[130] Fix | Delete
margin-top: 8px;
[131] Fix | Delete
z-index: 9999;
[132] Fix | Delete
box-shadow: 0 0 0 1px hsla(0, 0%, 0%, 0.1), 0 4px 11px hsla(0, 0%, 0%, 0.1);
[133] Fix | Delete
width: 100%;
[134] Fix | Delete
`;
[135] Fix | Delete
[136] Fix | Delete
const MenuList = styled.div`
[137] Fix | Delete
max-height: 300px;
[138] Fix | Delete
overflow-y: auto;
[139] Fix | Delete
padding-bottom: 4px;
[140] Fix | Delete
padding-top: 4px;
[141] Fix | Delete
position: relative;
[142] Fix | Delete
`;
[143] Fix | Delete
[144] Fix | Delete
const MenuGroup = styled.div`
[145] Fix | Delete
padding-bottom: 8px;
[146] Fix | Delete
padding-top: 8px;
[147] Fix | Delete
`;
[148] Fix | Delete
[149] Fix | Delete
const MenuGroupHeader = styled.div`
[150] Fix | Delete
color: #999;
[151] Fix | Delete
cursor: default;
[152] Fix | Delete
font-size: 75%;
[153] Fix | Delete
font-weight: 500;
[154] Fix | Delete
margin-bottom: 0.25em;
[155] Fix | Delete
text-transform: uppercase;
[156] Fix | Delete
padding-left: 12px;
[157] Fix | Delete
padding-left: 12px;
[158] Fix | Delete
`;
[159] Fix | Delete
[160] Fix | Delete
interface IMenuItemProps {
[161] Fix | Delete
selected: boolean;
[162] Fix | Delete
}
[163] Fix | Delete
[164] Fix | Delete
const MenuItem = styled.div<IMenuItemProps>`
[165] Fix | Delete
display: block;
[166] Fix | Delete
background-color: ${props =>
[167] Fix | Delete
props.selected ? CALYPSO_MEDIUM : 'transparent'};
[168] Fix | Delete
color: ${props => (props.selected ? '#fff' : 'inherit')};
[169] Fix | Delete
cursor: default;
[170] Fix | Delete
font-size: inherit;
[171] Fix | Delete
width: 100%;
[172] Fix | Delete
padding: 8px 12px;
[173] Fix | Delete
&:hover {
[174] Fix | Delete
background-color: ${props =>
[175] Fix | Delete
props.selected ? CALYPSO_MEDIUM : CALYPSO_LIGHT};
[176] Fix | Delete
}
[177] Fix | Delete
`;
[178] Fix | Delete
[179] Fix | Delete
interface IAsyncSelectProps {
[180] Fix | Delete
placeholder: string;
[181] Fix | Delete
value: any;
[182] Fix | Delete
loadOptions?: Function;
[183] Fix | Delete
defaultOptions?: any[];
[184] Fix | Delete
onChange: Function;
[185] Fix | Delete
}
[186] Fix | Delete
[187] Fix | Delete
export default function AsyncSelect({
[188] Fix | Delete
placeholder,
[189] Fix | Delete
value,
[190] Fix | Delete
loadOptions,
[191] Fix | Delete
onChange,
[192] Fix | Delete
defaultOptions,
[193] Fix | Delete
}: IAsyncSelectProps) {
[194] Fix | Delete
const inputEl = useRef<HTMLInputElement>(null);
[195] Fix | Delete
const inputShadowEl = useRef<HTMLDivElement>(null);
[196] Fix | Delete
const [isFocused, setFocus] = useState(false);
[197] Fix | Delete
const [loadState, setLoadState] = useState<LoadStateType>(
[198] Fix | Delete
LoadState.NotLoaded
[199] Fix | Delete
);
[200] Fix | Delete
const [localValue, setLocalValue] = useState('');
[201] Fix | Delete
const [options, setOptions] = useState(defaultOptions);
[202] Fix | Delete
[203] Fix | Delete
const inputSize = `${
[204] Fix | Delete
inputShadowEl.current ? inputShadowEl.current.clientWidth + 10 : 2
[205] Fix | Delete
}px`;
[206] Fix | Delete
[207] Fix | Delete
useEffect(() => {
[208] Fix | Delete
if (loadOptions && loadState === LoadState.NotLoaded) {
[209] Fix | Delete
loadOptions('', (result: any) => {
[210] Fix | Delete
setOptions(result);
[211] Fix | Delete
setLoadState(LoadState.Idle);
[212] Fix | Delete
});
[213] Fix | Delete
}
[214] Fix | Delete
}, [loadOptions, loadState]);
[215] Fix | Delete
[216] Fix | Delete
const renderItems = (items: any[] = [], parentKey?: number) => {
[217] Fix | Delete
return items.map((item, index) => {
[218] Fix | Delete
if (item.options) {
[219] Fix | Delete
return (
[220] Fix | Delete
<MenuGroup key={`async-select-item-${index}`}>
[221] Fix | Delete
<MenuGroupHeader id={`${index}-heading`}>
[222] Fix | Delete
{item.label}
[223] Fix | Delete
</MenuGroupHeader>
[224] Fix | Delete
<div>{renderItems(item.options, index)}</div>
[225] Fix | Delete
</MenuGroup>
[226] Fix | Delete
);
[227] Fix | Delete
} else {
[228] Fix | Delete
const key = `async-select-item-${
[229] Fix | Delete
parentKey !== undefined ? `${parentKey}-${index}` : index
[230] Fix | Delete
}`;
[231] Fix | Delete
return (
[232] Fix | Delete
<MenuItem
[233] Fix | Delete
key={key}
[234] Fix | Delete
id={key}
[235] Fix | Delete
selected={value && item.value === value.value}
[236] Fix | Delete
onClick={() => {
[237] Fix | Delete
onChange(item);
[238] Fix | Delete
setFocus(false);
[239] Fix | Delete
}}
[240] Fix | Delete
>
[241] Fix | Delete
{item.label}
[242] Fix | Delete
</MenuItem>
[243] Fix | Delete
);
[244] Fix | Delete
}
[245] Fix | Delete
});
[246] Fix | Delete
};
[247] Fix | Delete
[248] Fix | Delete
return (
[249] Fix | Delete
<Container>
[250] Fix | Delete
<ControlContainer
[251] Fix | Delete
id="leadin-async-selector"
[252] Fix | Delete
focused={isFocused}
[253] Fix | Delete
onClick={() => {
[254] Fix | Delete
if (isFocused) {
[255] Fix | Delete
if (inputEl.current) {
[256] Fix | Delete
inputEl.current.blur();
[257] Fix | Delete
}
[258] Fix | Delete
setFocus(false);
[259] Fix | Delete
setLocalValue('');
[260] Fix | Delete
} else {
[261] Fix | Delete
if (inputEl.current) {
[262] Fix | Delete
inputEl.current.focus();
[263] Fix | Delete
}
[264] Fix | Delete
setFocus(true);
[265] Fix | Delete
}
[266] Fix | Delete
}}
[267] Fix | Delete
>
[268] Fix | Delete
<ValueContainer>
[269] Fix | Delete
{localValue === '' &&
[270] Fix | Delete
(!value ? (
[271] Fix | Delete
<Placeholder>{placeholder}</Placeholder>
[272] Fix | Delete
) : (
[273] Fix | Delete
<SingleValue>{value.label}</SingleValue>
[274] Fix | Delete
))}
[275] Fix | Delete
<InputContainer>
[276] Fix | Delete
<Input
[277] Fix | Delete
ref={inputEl}
[278] Fix | Delete
onFocus={() => {
[279] Fix | Delete
setFocus(true);
[280] Fix | Delete
}}
[281] Fix | Delete
onChange={e => {
[282] Fix | Delete
setLocalValue(e.target.value);
[283] Fix | Delete
setLoadState(LoadState.Loading);
[284] Fix | Delete
loadOptions &&
[285] Fix | Delete
loadOptions(e.target.value, (result: any) => {
[286] Fix | Delete
setOptions(result);
[287] Fix | Delete
setLoadState(LoadState.Idle);
[288] Fix | Delete
});
[289] Fix | Delete
}}
[290] Fix | Delete
value={localValue}
[291] Fix | Delete
width={inputSize}
[292] Fix | Delete
id="asycn-select-input"
[293] Fix | Delete
/>
[294] Fix | Delete
<InputShadow ref={inputShadowEl}>{localValue}</InputShadow>
[295] Fix | Delete
</InputContainer>
[296] Fix | Delete
</ValueContainer>
[297] Fix | Delete
<IndicatorContainer>
[298] Fix | Delete
{loadState === LoadState.Loading && <UISpinner />}
[299] Fix | Delete
<DropdownIndicator />
[300] Fix | Delete
</IndicatorContainer>
[301] Fix | Delete
</ControlContainer>
[302] Fix | Delete
{isFocused && (
[303] Fix | Delete
<MenuContainer>
[304] Fix | Delete
<MenuList>{renderItems(options)}</MenuList>
[305] Fix | Delete
</MenuContainer>
[306] Fix | Delete
)}
[307] Fix | Delete
</Container>
[308] Fix | Delete
);
[309] Fix | Delete
}
[310] Fix | Delete
[311] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function