mirror of
				https://gitlab.nic.cz/turris/reforis/foris-js.git
				synced 2025-11-03 23:00:31 +01:00 
			
		
		
		
	Add CopyInput bootstrap component
This commit is contained in:
		
							
								
								
									
										60
									
								
								src/bootstrap/CopyInput.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								src/bootstrap/CopyInput.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,60 @@
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (C) 2019-2022 CZ.NIC z.s.p.o. (https://www.nic.cz/)
 | 
			
		||||
 *
 | 
			
		||||
 * This is free software, licensed under the GNU General Public License v3.
 | 
			
		||||
 * See /LICENSE for more information.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
import React, { useState, useRef } from "react";
 | 
			
		||||
import PropTypes from "prop-types";
 | 
			
		||||
import { Input } from "./Input";
 | 
			
		||||
 | 
			
		||||
CopyInput.propTypes = {
 | 
			
		||||
    /** Field label. */
 | 
			
		||||
    label: PropTypes.string.isRequired,
 | 
			
		||||
    /** Field value. */
 | 
			
		||||
    value: PropTypes.string,
 | 
			
		||||
    /** Help text message. */
 | 
			
		||||
    helpText: PropTypes.string,
 | 
			
		||||
    /** Disable input field */
 | 
			
		||||
    disabled: PropTypes.bool,
 | 
			
		||||
    /** Readonly input field */
 | 
			
		||||
    readOnly: PropTypes.bool,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export function CopyInput({ value, ...props }) {
 | 
			
		||||
    const inputTextRef = useRef();
 | 
			
		||||
    const [isCopied, setIsCopied] = useState(false);
 | 
			
		||||
 | 
			
		||||
    const handleCopyClick = async () => {
 | 
			
		||||
        // Clipboard API works only in a secure (HTTPS) context.
 | 
			
		||||
        if (navigator.clipboard) {
 | 
			
		||||
            await navigator.clipboard.writeText(value);
 | 
			
		||||
        } else {
 | 
			
		||||
            // Fallback to the "classic" copy to clipboard implementation.
 | 
			
		||||
            inputTextRef.current.focus();
 | 
			
		||||
            inputTextRef.current.select();
 | 
			
		||||
            document.execCommand("copy");
 | 
			
		||||
            inputTextRef.current.blur();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        setIsCopied(true);
 | 
			
		||||
        setTimeout(() => {
 | 
			
		||||
            setIsCopied(false);
 | 
			
		||||
        }, 1500);
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    return (
 | 
			
		||||
        <Input type="text" value={value} ref={inputTextRef} {...props}>
 | 
			
		||||
            <div className="input-group-append">
 | 
			
		||||
                <button
 | 
			
		||||
                    className="btn btn-outline-secondary"
 | 
			
		||||
                    type="button"
 | 
			
		||||
                    onClick={handleCopyClick}
 | 
			
		||||
                >
 | 
			
		||||
                    <span>{isCopied ? _("Copied!") : _("Copy")}</span>
 | 
			
		||||
                </button>
 | 
			
		||||
            </div>
 | 
			
		||||
        </Input>
 | 
			
		||||
    );
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										17
									
								
								src/bootstrap/CopyInput.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								src/bootstrap/CopyInput.md
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,17 @@
 | 
			
		||||
CopyInput Bootstrap component contains input with a label, predefined sizes, and
 | 
			
		||||
structure for use in ForisForm and the "Copy" button (copy to clipboard). It can
 | 
			
		||||
be used with `readOnly` and `disabled` parameters, please see an example.
 | 
			
		||||
 | 
			
		||||
All additional `props` are passed to the `<input type="text">` HTML component.
 | 
			
		||||
 | 
			
		||||
```js
 | 
			
		||||
import React, { useState } from "react";
 | 
			
		||||
const [value, setValue] = useState("Text to appear in clipboard.");
 | 
			
		||||
 | 
			
		||||
<CopyInput
 | 
			
		||||
    label="Copy me"
 | 
			
		||||
    value={value}
 | 
			
		||||
    helpText="Read the small text!"
 | 
			
		||||
    readOnly
 | 
			
		||||
/>;
 | 
			
		||||
```
 | 
			
		||||
@@ -20,6 +20,7 @@ export { API_STATE } from "./api/utils";
 | 
			
		||||
export { Alert, ALERT_TYPES } from "./bootstrap/Alert";
 | 
			
		||||
export { Button } from "./bootstrap/Button";
 | 
			
		||||
export { CheckBox } from "./bootstrap/CheckBox";
 | 
			
		||||
export { CopyInput } from "./bootstrap/CopyInput";
 | 
			
		||||
export { DownloadButton } from "./bootstrap/DownloadButton";
 | 
			
		||||
export { DataTimeInput } from "./bootstrap/DataTimeInput";
 | 
			
		||||
export { EmailInput } from "./bootstrap/EmailInput";
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user