domain-search

4.1.0 • Public • Published

Domain Search

Build Status devDependencies Status

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.
  • If using independently of WordPress (i.e. on your own custom storefront or site):
    • npm i
    • Update the global rstore variable in public/index.html with your pl_id. You will need to replace all occurrences of the value 1592, otherwise all cart actions will be applied to that pl_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!

  1. Install it and use it in your project.
  2. Log bugs, issues, and questions on Github.
  3. 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.

/domain-search/

    Package Sidebar

    Install

    npm i domain-search

    Weekly Downloads

    3

    Version

    4.1.0

    License

    MIT

    Unpacked Size

    170 kB

    Total Files

    4

    Last publish

    Collaborators

    • bfocht
    • cberesford
    • connorjburton
    • shuai-zh