Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Esri/arcgis-js-cli
CLI to build a template application and widgets using the ArcGIS API for JavaScript
https://github.com/Esri/arcgis-js-cli
arcgis-js-api cli flow javascript
Last synced: 2 months ago
JSON representation
CLI to build a template application and widgets using the ArcGIS API for JavaScript
- Host: GitHub
- URL: https://github.com/Esri/arcgis-js-cli
- Owner: Esri
- License: apache-2.0
- Archived: true
- Created: 2018-05-09T19:36:37.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-02-02T21:45:25.000Z (11 months ago)
- Last Synced: 2024-10-30T01:39:46.283Z (2 months ago)
- Topics: arcgis-js-api, cli, flow, javascript
- Language: TypeScript
- Size: 1.52 MB
- Stars: 140
- Watchers: 25
- Forks: 31
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# @arcgis/cli (Deprecated)
| :warning: This repository has been archived |
| :--------------------------------------------|
| **This package is no longer supported. Use at your own risk.** |This CLI will allow you to quickly scaffold various applications for the [ArcGIS Maps SDK JavaScript](https://developers.arcgis.com/javascript/).
> NOTE: It is highly recommended that you use [Vite](https://vitejs.dev/) directly to build your apps. We also provide a number of [application samples](https://github.com/Esri/jsapi-resources/tree/master/esm-samples) that you can use. The 4.25 release of this CLI will most likely be the last release. There are other tools already suited for using existing repositories for applications, such as [degit](https://github.com/Rich-Harris/degit).
## 4.25 Breaking Changes
There is no longer a webpack template provided for this CLI. The only application template uses [Vite](https://vitejs.dev/). You can find webpack application sample [here](https://github.com/Esri/jsapi-resources/tree/master/esm-samples/webpack).
## Usage
### Prerequisites
You will need node v8+.
* _NOTE FOR WINDOWS USERS_ - You may need to install the [Windows-Build-Tools](https://github.com/felixrieseberg/windows-build-tools) to compile npm modules for this project. `npm install --global --production windows-build-tools`
### Installation
From NPM
`npm install -g @arcgis/cli`
In a terminal, run:
`arcgis --help`
This will output the following:
```sh
Usage: arcgis [dest] -tCommands:
arcgis create [dest] Create a new application.
arcgis init [type] Initialize a new application in current directory
arcgis widget [type] Create a new Widget.
arcgis styles Run commands to work with a custom CSS
theme
```## Quick Start
> template application
```sh
arcgis create jsapi-app
```## Sample Apps
* [ArcGIS Basic App](https://jsapi-basic-416.surge.sh/)
## Features
### Create a new application
```sh
$ arcgis create [dest]Create a new application.
Options:
--version Show version number [boolean]
--name, -n directory and package name for the new app
--dest Directory to create the application in [default: ]
--type, -t A project template [choices: "jsapi"] [default: "jsapi"]
-h, --help Show help [boolean]```
### Initialize a new application in current directory
```sh
$ arcgis init [type]Initialize a new application in current directory
Options:
--version Show version number [boolean]
--type, -t A project template [choices: "jsapi"] [default: "jsapi"]
-h, --help Show help [boolean]
```### Create a new widget
You can scaffold a standalone widget for use in your application. Widgets are saved into a `tmp` folder.
```sh
$ arcgis widget [type]Create a new Widget.
Options:
--version Show version number [boolean]
--name, -n Name of new widget
--type, -t A widget template [choices: "jsapi", "exb"] [default: "jsapi"]
-h, --help Show help [boolean]
```#### Experience Builder Widgets
The CLI can be used to scaffold custom widgets for the [ArcGIS Experience Builder Developer Edition](https://www.esri.com/en-us/arcgis/products/arcgis-experience-builder/overview).
You will want to run the CLI in the extracted root directory of your Experience Builder installation.
```sh
arcgis widget my-widget -t exb
```This will install your widget in the Experience Builder folder structure as follows.
```
\client\your-extensions\widgets\MyWidget\
```
### Author a custom themeCreate a new CSS theme.
```sh
$ arcgis stylesRun subcommands to work with a custom CSS theme
Commands:
arcgis styles create [theme] Create a custom theme
arcgis styles preview [theme] Launch theme-preview test page
arcgis styles eject [theme] Eject a built theme ready for deployment
arcgis styles list List existing themes in the current project
arcgis styles clean Removes any local scaffolding. This should be
used when no more theme authoring is to be done
in the working directory.
arcgis styles scaffold Sets up project scaffolding. This is done
automatically when creating a theme for the
first time.
```#### Create a new theme
```sh
$ arcgis styles create [theme]Create a custom theme
Positionals:
theme the name of the theme to create [string] [default: "my-custom-theme"]Options:
--version Show version number [boolean]
-e, --with-examples when specified, the created theme will include examples
from the SDK [boolean]
-b, --with-base when specified, the created theme will include base files
for local overrides (advanced) [boolean]
-f, --force overwrites a theme if it already exists [boolean]
-h, --help Show help [boolean]
```#### Preview a theme
```sh
$ arcgis styles preview [theme]Launch theme-preview test page
Positionals:
theme the name of the theme to preview (this is only needed if there is more
than one theme in the workspace) [string] [default: "my-custom-theme"]Options:
--version Show version number [boolean]
-p, --port port to use for the preview page [number]
-h, --help Show help [boolean]
```
#### Eject a theme```sh
$ arcgis styles eject [theme]Eject a built theme ready for deployment
Positionals:
theme the name of the theme to eject (this is only needed if there is more
than one theme in the workspace) [string] [default: "my-custom-theme"]Options:
--version Show version number [boolean]
-h, --help Show help [boolean]
```#### List themes
```sh
$ arcgis styles listList existing themes in the current project
Options:
--version Show version number [boolean]
-h, --help Show help [boolean]
```#### Clean themes workspace
```sh
$ arcgis styles cleanRemoves any local scaffolding. This should be used when no more theme authoring
is to be done in the working directory.Options:
--version Show version number [boolean]
-f, --force required to clean any local scaffolding used by this utility
[boolean]
-h, --help Show help [boolean]
```#### Scaffold styling workspace
```sh
$ arcgis styles scaffoldSets up project scaffolding. This is done automatically when creating a theme
for the first time.Options:
--version Show version number [boolean]
-f, --force forces creation of project scaffolding [boolean]
-h, --help Show help [boolean]
```## Licensing
Copyright 2022 EsriLicensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
A copy of the license is available in the repository's [LICENSE](./LICENSE) file