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 { Alert, ALERT_TYPES } from "./bootstrap/Alert";
 | 
				
			||||||
export { Button } from "./bootstrap/Button";
 | 
					export { Button } from "./bootstrap/Button";
 | 
				
			||||||
export { CheckBox } from "./bootstrap/CheckBox";
 | 
					export { CheckBox } from "./bootstrap/CheckBox";
 | 
				
			||||||
 | 
					export { CopyInput } from "./bootstrap/CopyInput";
 | 
				
			||||||
export { DownloadButton } from "./bootstrap/DownloadButton";
 | 
					export { DownloadButton } from "./bootstrap/DownloadButton";
 | 
				
			||||||
export { DataTimeInput } from "./bootstrap/DataTimeInput";
 | 
					export { DataTimeInput } from "./bootstrap/DataTimeInput";
 | 
				
			||||||
export { EmailInput } from "./bootstrap/EmailInput";
 | 
					export { EmailInput } from "./bootstrap/EmailInput";
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user