Domain Search
This is a simple react-based domain search widget used for designing and building custom GoDaddy reseller storefronts, as seen in our WordPress Storefront Plugin.
In order to sell domains and make commission on your own custom storefront, you will need an active GoDaddy Reseller Plan. However, this package can be used in "demo mode", which provides full cart and purchase paths for the Domains Priced Right brand.
This project was bootstrapped with Create React App. Please visit their GitHub repo for additional context and advanced usage.
Demo
You can view a demo of the domain search component at https://godaddy.github.io/domain-search/.
Getting Started
- Make sure you have an active GoDaddy Reseller Plan, otherwise you will not be able to make commissions on any domain sales from your site.
- If using with the WordPress Storefront Plugin:
- Add
[rstore_domain_search]
to any post or page that you would like this to appear in.
- Add
- If using independently of WordPress (i.e. on your own custom storefront or site):
npm i
- Update the global
rstore
variable inpublic/index.html
with yourpl_id
. You will need to replace all occurrences of the value1592
, otherwise all cart actions will be applied to thatpl_id
instead of yours. -
npm start
- the app will run on port 3000 by default. Open http://localhost:3000 to view it in the browser. - Please visit https://www.secureserver.net/api/explore/ for the official Storefront API documentation.
Usage
- Add the following HTML to the page that you want the domain search component to appear on. The compiled JS is located in
dist/index.js
.
<div class="rstore-domain-search" data-plid="1592">Domain Search</div>
Optional parameter to change number of results returned in the search
data-page_size="5"
The domain search component is internationalizable. To change any of the strings, provide the following data attributes in the div
data-text_placeholder="Find your perfect domain name"
data-text_search="Search"
data-text_available="Congrats, {domain_name} is available!"
data-text_not_available="Sorry, {domain_name} is taken."
data-text_cart="Continue to Cart"
data-text_select="Select"
data-text_selected="Selected"
data-new_tab=true
data-text_available
and data-text_not_available
fields support text substitution, {domain_name} in the provided text will be replaced by the actual domain name searched.
Example Usage
<div
class="rstore-domain-search"
data-plid="1592"
data-text_placeholder="Find your perfect domain name"
data-text_search="Search"
data-text_available="Congrats, {domain_name} is available!"
data-text_not_available="Sorry, {domain_name} is taken."
data-text_cart="Continue to Cart"
data-text_select="Select"
data-text_selected="Selected"
data-new_tab="true"
>
Domain Search
</div>
Browser Requirements
Requires modern browsers. If you support older browsers (e.g. IE < 11), consider adding a polyfill script to the <head>
block.
<script src="https://cdn.polyfill.io/v2/polyfill.min.js"></script>
Available Scripts
npm start
Runs the app in the development mode. Open http://localhost:3000 to view it in the browser.
The page will reload if you make edits. You will also see any linting errors in the console.
npm test
Launches the test runner in the interactive watch mode.
Run npm test -- --coverage
to generate a code coverage report.
npm run build
Builds the app for production to the build
folder. The compiled JavaScript will also be made available in dist/index.js
.
It correctly bundles React in production mode and optimizes the build for the best performance.
The build is minified and the filenames include the hashes. Your app is ready to be deployed!
npm run eject
Note: this is a one-way operation. Once you eject, you can’t go back!
If you aren’t satisfied with the build tool and configuration choices, you can eject at any time. This command will remove the single build dependency from your project.
Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except eject will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own.
You don’t have to ever use eject. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However, we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it.
Contributing
This app is open source! That means we want your contributions!
- Install it and use it in your project.
- Log bugs, issues, and questions on Github.
- Create pull-requests and help us make it better!
Changelog
-
v4.1.0
- Add open in new tab option
-
v3.1.0
- Prevent page navigation when domains are selected
-
v3.0.0
- Update dependencies
- Update api calls
- Update CSS for responsive layout
- Add domain disclaimers
-
v2.1.6
- Update api endpoint
-
v2.1.4
- Add continue to cart button
- Update UX
-
v2.1.3
- Include full domain on taken search results
-
v2.1.0
- Upgrade to React 16
-
v2.0.0
- Initial Release
Contributors
License
This project is licensed under the MIT License. See LICENSE for more details.