Skip to content

xysfdx is a Rapid development tool for Salesforce SFDX Development. Support Docker, WSL, Dataloader! Metadata diff with server, retrieve standard sobject.

License

Notifications You must be signed in to change notification settings

exiahuang/xysfdx

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

xysfdx README

xysfdx is a Rapid development tool for Salesforce SFDX Development. Metadata diff with server, retrieve standard sobject.

Features

  • Less than 100k
  • Support Dataloader v40.0.0~v47.0.0 Export/ExportAll/Insert/Update/Upsert/Delete.
  • Support Docker to develope sfdx . Use exiasfdc/sfdx docker image, no need to config, just run it.
  • Support using WSL/git bash/Msys2/MingW64/MingW32 to develope sfdx .
  • Authenticated with oauth2.
  • Retrieve Metadata by select.
  • Metadata diff with server(any sfdc organization).
  • Retrieve standard sobject.
  • Open sfdc link easily.
  • Open console easily.
  • Option Features
    • support Username-Password OAuth Authentication .
    • auto run .apex file after save.
    • auto save to sfdc server
    • deploy to any sfdc organization
    • pretty code: pretty .cmp, .page, .component, .trigger, .cls file
    • support base git command.
    • support exiahuang/sfdc-cli.

Shortkey

shortkey: ctrl+shift+j

Requirements

Salesforce Cli

Usage

Create a project

force:project:create

xycode-sfdx-init-project

Retrieve metadata

force:source:retrieve:metadata

xycode-sfdx-retrieve-meta

Diff metadata

force:source:diff:metadata

You can diff with any sfdc organization.

diff source

xycode-sfdx-diff-meta

diff profile

xycode-sfdx-diff-profile-meta

Authentication

force:auth:web:login force:auth:web:login:setdefaultusername

Deploy metadata

  • force:source:deploy:metadata
  • force:source:deploy:current_file

Dataloader

  • support v40.0.0~v47.0.0
  • support CSV Export/ExportAll/Insert/Update/Upsert/Delete

xysfdx-dataloader

If you use docker, you can only select csv/sdl file in current workspace.

TIPS: How to create sdl file ? I always use SalesforceXyTools For Chrome to create it.

Option Features

How to config option features

You can also open the Settings editor from the Command Palette (Ctrl+Shift+P) with Preferences: Open Settings or use the keyboard shortcut (Ctrl+,).

search xysfdx

xysfdx-setting

Build-in Option Features

xysfdx.optionFeatures config:

  • use_advanced_command: show advanced command
  • auto_run_apex_anonymous: run .apex file after save it
  • auto_save_to_sfdc: auto deploy to .trigger, .cls, .component, .page file to sfdc
  • pretty_vf_page: pretty .cmp, .page, .component file
  • pretty_apex_anonymous: pretty .apex file
  • pretty_apex: pretty .trigger, .cls file

config:

{
    "xysfdx.optionFeatures": [
        // show advanced command
        //"use_advanced_command",

        // auto deploy to `.trigger`, `.cls`, `.component`, `.page` file to sfdc
        // "auto_save_to_sfdc",

        // pretty `.cmp`, `.page`, `.component` file
        // "pretty_vf_page",

        // pretty `.trigger`, `.cls` file
        // "pretty_apex",

        // run `.apex` file after save it, default active
        "auto_run_apex_anonymous",

        // pretty `.apex` file
        "pretty_apex_anonymous",
		
		// use git 
        "git",
		
		// use sfdc-cli, read more: https://github.com/exiahuang/sfdc-cli
        "xytools",
        "xytools.auto_save_to_server",
        "xytools.auto_run_apex_anonymous",
		
    ]
}

show advanced command

  • Advanced:force:source:deploy:current_file: Select Authenticated server and deploy file
  • Advanced:force:source:retrieve:current_file: Select Authenticated server and retrieve file

auto run apex anonymous code

auto_run_apex_anonymous

xycode-sfdx-run-apex-anonymous

auto save to sfdc server

auto_save_to_sfdc

xysfdx-auto-save-to-sfdc

pretty code

  • pretty_apex: pretty .cmp, .page, .component file
  • pretty_vf_page: pretty .trigger, .cls file
  • pretty_apex_anonymous : pretty .apex file

you need to install java and prettier and prettier-plugin-apex npm install --global prettier prettier-plugin-apex sudo apt install openjdk-8-jdk read more about prettier-plugin-apex

xysfdx-pretty_apex

use git

set git option features, then use the base git command.

git config json

use sfdc-cli

set xytools option features, then use the sfdc-cli command.

  • "xytools" : use the sfdc-cli command
  • "xytools.auto_save_to_server": after save apex/trigger/page/component, it will auto save to sfdc server.
  • "xytools.auto_run_apex_anonymous": run .apex file after save.

please do not use xytools.auto_save_to_server and auto_save_to_server in the same time please do not use xytools.auto_run_apex_anonymous and auto_run_apex_anonymous in the same time

read more about sfdc-cli:

For Docker user

vscode config

{
    "xysfdx.shellMode": "docker",
    "xysfdx.shellPath": "",
    "xysfdx.dockerContainer": "${lowercaseWorkspaceName}_sfdx_1",
    "xysfdx.dockerAppRoot": "/app/sfdx"
}

How to use docker ?

  1. pull images : docker: pull image exiasfdc/sfdx

xysfdx-docker-image

  1. create container : docker: create sfdx container

xysfdx-docker-container

  1. use docker shell : docker: attach docker shell

xysfdx-docker-bash

then , use the xysfdx to develope sfdx.

attention

  • can not use force:auth:web:login or force:auth:web:login:setdefaultusername
  • use xy:auth:username:login to auth

For Windows user

use wsl/git bash/Msys2 bash to develope sfdx.

Open cmd/wsl/bash

xysfdx-open-wsl.png

xysfdx-open-wsl

use wsl

open wslmode

{
    "xysfdx.shellMode": "wsl",
    "xysfdx.shellPath": "C:\\Windows\\System32\\bash.exe"
}

use msys2 bash

{
    "xysfdx.shellMode": "bash",
    "xysfdx.shellPath": "C:\\msys64\\usr\\bin\\bash.exe"
}

use git bash

{
    "xysfdx.shellMode": "bash",
    "xysfdx.shellPath": "C:\\Program Files\\Git\\usr\\bin\\bash.exe"
}

Enjoy it!

About

xysfdx is a Rapid development tool for Salesforce SFDX Development. Support Docker, WSL, Dataloader! Metadata diff with server, retrieve standard sobject.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published