+
+
+
+
{ this.captcha = el; } }
+ sitekey="6LeZV7oUAAAAALiIfCUnnrlXE0fYrcyvM9JHVN72"
+ onChange={this.onChange} />
+
+
{ this._messageContainer = elm; }}>
+
+
+
+ this.buttonClicked()} />
+
+ );
+ }
+
+ public buttonClicked(): void {
+ if(this.captcha.getValue())
+ {
+
+ ReactDom.unmountComponentAtNode(this._messageContainer);
+ const element2 = React.createElement(
+ MessageBar,
+ {
+ messageBarType:MessageBarType.success,
+ isMultiline:false,
+ dismissButtonAriaLabel:"Close"
+ },
+ "You data has been saved sucessfully"
+ );
+ //const camContainer = document.getElementById("camContainer")
+ ReactDom.render(element2, this._messageContainer);
+ }
+
+ else{
+ const element2 = React.createElement(
+ MessageBar,
+ {
+ messageBarType:MessageBarType.error,
+ isMultiline:false,
+ dismissButtonAriaLabel:"Close"
+ },
+ "Please select captcha."
+ );
+ //const camContainer = document.getElementById("camContainer")
+ ReactDom.render(element2, this._messageContainer);
+ }
+ }
+
+ public onChange(value){
+ console.log("Captcha value:", value);
+ }
+}
diff --git a/samples/react-recaptcha/src/webparts/recaptcha/loc/en-us.js b/samples/react-recaptcha/src/webparts/recaptcha/loc/en-us.js
new file mode 100644
index 000000000..89f98bc1e
--- /dev/null
+++ b/samples/react-recaptcha/src/webparts/recaptcha/loc/en-us.js
@@ -0,0 +1,7 @@
+define([], function() {
+ return {
+ "PropertyPaneDescription": "Description",
+ "BasicGroupName": "Group Name",
+ "DescriptionFieldLabel": "Description Field"
+ }
+});
\ No newline at end of file
diff --git a/samples/react-recaptcha/src/webparts/recaptcha/loc/mystrings.d.ts b/samples/react-recaptcha/src/webparts/recaptcha/loc/mystrings.d.ts
new file mode 100644
index 000000000..54328069e
--- /dev/null
+++ b/samples/react-recaptcha/src/webparts/recaptcha/loc/mystrings.d.ts
@@ -0,0 +1,10 @@
+declare interface IRecaptchaWebPartStrings {
+ PropertyPaneDescription: string;
+ BasicGroupName: string;
+ DescriptionFieldLabel: string;
+}
+
+declare module 'RecaptchaWebPartStrings' {
+ const strings: IRecaptchaWebPartStrings;
+ export = strings;
+}
diff --git a/samples/react-recaptcha/teams/200835ce-2963-400e-ae18-f556484c5fba_color.png b/samples/react-recaptcha/teams/200835ce-2963-400e-ae18-f556484c5fba_color.png
new file mode 100644
index 000000000..a8d279707
Binary files /dev/null and b/samples/react-recaptcha/teams/200835ce-2963-400e-ae18-f556484c5fba_color.png differ
diff --git a/samples/react-recaptcha/teams/200835ce-2963-400e-ae18-f556484c5fba_outline.png b/samples/react-recaptcha/teams/200835ce-2963-400e-ae18-f556484c5fba_outline.png
new file mode 100644
index 000000000..6df4a038d
Binary files /dev/null and b/samples/react-recaptcha/teams/200835ce-2963-400e-ae18-f556484c5fba_outline.png differ
diff --git a/samples/react-recaptcha/tsconfig.json b/samples/react-recaptcha/tsconfig.json
new file mode 100644
index 000000000..131c5bb80
--- /dev/null
+++ b/samples/react-recaptcha/tsconfig.json
@@ -0,0 +1,38 @@
+{
+ "extends": "./node_modules/@microsoft/rush-stack-compiler-2.9/includes/tsconfig-web.json",
+ "compilerOptions": {
+ "target": "es5",
+ "forceConsistentCasingInFileNames": true,
+ "module": "esnext",
+ "moduleResolution": "node",
+ "jsx": "react",
+ "declaration": true,
+ "sourceMap": true,
+ "experimentalDecorators": true,
+ "skipLibCheck": true,
+ "outDir": "lib",
+ "inlineSources": false,
+ "strictNullChecks": false,
+ "noUnusedLocals": false,
+ "typeRoots": [
+ "./node_modules/@types",
+ "./node_modules/@microsoft"
+ ],
+ "types": [
+ "es6-promise",
+ "webpack-env"
+ ],
+ "lib": [
+ "es5",
+ "dom",
+ "es2015.collection"
+ ]
+ },
+ "include": [
+ "src/**/*.ts"
+ ],
+ "exclude": [
+ "node_modules",
+ "lib"
+ ]
+}
diff --git a/samples/react-recaptcha/tslint.json b/samples/react-recaptcha/tslint.json
new file mode 100644
index 000000000..23fa2aa43
--- /dev/null
+++ b/samples/react-recaptcha/tslint.json
@@ -0,0 +1,30 @@
+{
+ "extends": "@microsoft/sp-tslint-rules/base-tslint.json",
+ "rules": {
+ "class-name": false,
+ "export-name": false,
+ "forin": false,
+ "label-position": false,
+ "member-access": true,
+ "no-arg": false,
+ "no-console": false,
+ "no-construct": false,
+ "no-duplicate-variable": true,
+ "no-eval": false,
+ "no-function-expression": true,
+ "no-internal-module": true,
+ "no-shadowed-variable": true,
+ "no-switch-case-fall-through": true,
+ "no-unnecessary-semicolons": true,
+ "no-unused-expression": true,
+ "no-use-before-declare": true,
+ "no-with-statement": true,
+ "semicolon": true,
+ "trailing-comma": false,
+ "typedef": false,
+ "typedef-whitespace": false,
+ "use-named-parameter": true,
+ "variable-name": false,
+ "whitespace": false
+ }
+}
\ No newline at end of file