less FormBuilder风格

form-builder.less
.FormBuilder {

    .Inputfield:last-child {
        margin-bottom: 0;
    }

    .InputfieldForm .Inputfield {
        margin: 0 0 @global-margin 0 !important;
    }

}

less CSS / LESS颜色渐变

icon-gradient.less
/**
 *  Gradient color mixin
 *  Works great with text & icons fonts
*/
.gradient-color-mixin(@color, @color-2, @deg: 90deg) {
    color: transparent;
    background-image: -webkit-linear-gradient(@deg, @color-2 0%, @color 100%);
    background-image: -moz-linear-gradient(@deg, @color-2 0%, @color 100%);
    background-image: linear-gradient(@deg, @color-2 0%, @color 100%);
    -webkit-background-clip: text;
    -moz-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    -moz-text-fill-color: transparent;
    text-fill-color: transparent;
}

less CSS / LESS Gradient Hover

CSS Gradient hover less mixin

css-gradient-hover.less
// Gradient Hover Mixin
.gradient-hover-mixin(@bg-dark, @bg-light, @direction: left) {

    background: -webkit-linear-gradient(@direction, @bg-light 0%,@bg-dark 50%,@bg-light 100%);
    background-size: 300%,1px;
    background-position: 0%;
    transition: all .5s;

    &:hover {
        background-position: 100%;
        transition: all .5s;
    }

}

// Example
.my-class {
	.gradient-hover-mixin(@my-bg-1, @my-bg-2);
}

less 篝火

篝火

campfire-3december-day-9.markdown
Campfire 

less 少功能

functions.less
/* Functions */
.border-radius(@pixels: 3px){
   -webkit-border-radius: @pixels;
   -moz-border-radius: @pixels;
   border-radius: @pixels;
}

.transition(@speed: 0.3s; @effect: ease){
   -webkit-transition: all @speed @effect;
   -moz-transition: all @speed @effect;
   -ms-transition: all @speed @effect;
   -o-transition: all @speed @effect;
   transition: all @speed @effect;
}

.rotate(@deg: 45deg){
	-moz-transform: rotate(@deg);
	-webkit-transform: rotate(@deg);
	-o-transform: rotate(@deg);
	-ms-transform: rotate(@deg);
	transform: rotate(@deg);
}

.flexbox(@vertical: center; @horizontal: center){
   display: -ms-flex;
   display: -webkit-flex;
   display: flex;
   -ms-align-items: @vertical;
   -webkit-align-items: @vertical;
   align-items: @vertical;
   -ms-justify-content: @horizontal;
   -webkit-justify-content: @horizontal;
   justify-content: @horizontal;
}

.fontAwesome(@content){
	.fa-icon;
	.fas;
	content: @content;
}

.fontAwesome_brand(@content){
	.fa-icon;
	.fab;
	content: @content;
}

.scale(@x: 2){
	-moz-transform: scale(@x);
	-webkit-transform: scale(@x);
	-o-transform: scale(@x);
	-ms-transform: scale(@x);
	transform: scale(@x);
}

.noselect(@value: none) {
	-webkit-touch-callout: @value;
	-webkit-user-select: @value;
	-khtml-user-select: @value;
	-moz-user-select: @value;
	-ms-user-select: @value;
	user-select: @value;
}

.box-shadow(@values: 0 0 10px 0 rgba(0,0,0,0.1)){
	-webkit-box-shadow: @values;
	box-shadow: @values;
}

less 测试

测试

app-header.less
body {
  padding-top:@gutter-width;
  min-height:100vh;
  background-color: lighten(rgb(242, 247, 253), 2%);
  margin:0;
}
3d-pixels.markdown

less 懒惰2019年

lazyload.js
//lazyloading
function lazyloading() {
	$('img').each(function () {
		var vT = $(this);
        if (vT.data('src') !== undefined) {
            //console.log(vT.data('src') + '/' + vT.prop('width'));
            if ((vT.css('float') == 'left') || vT.css('float') == 'right') {
                vT.css({ 'min-width': '0' });
            }else if (vT.css('width') !== 0) {
                vT.css({ 'min-width': vT.css('width') });
            } else if (vT.css('height') !== 0) {
                vT.css({ 'height': vT.css('height') });
            }


            vT.addClass('lazyload').attr('src', '');
			var newsize = getClosestBigger(vT, is_high_resolution_screen());
			vT.attr('data-closestbigger', newsize);
			vT.attr('data-highres', is_high_resolution_screen());
            var vImgSrc = vT.data('src').replace(/preset=(\w+)/g, 'size=' + newsize + '&quality=85');
            vT.attr('src', vT.data('src').replace(/preset=(\w+)/g, 'preset=micro'));
			vT.attr('data-src', vImgSrc);
			vT.on('inview', function (event, isInView, visiblePartX, visiblePartY) {
                if (isInView) {
                    vT.attr('src', vImgSrc);
                    vT.parent().imagesLoaded().done(function (instance) {
                        vT.addClass('lazyloaded');
                    });
				}
			});
		}

	});
}

var responsiveSteps = "50=micro,100=mini,480=small,768=medium,960=large,1600=jumbo";
var rPreset = '50';
var rSize = 'micro';
var memWidth = $(document).width();

function getClosestBigger(el, highres) {
	//console.log(el.attr('class') + ' / ' + el.parent().width());
	var vW = ''
	if (el.closest('div').length) {
		vW = el.closest('div').width();
	} else {
		vW = el.parent().width();
	}
	if ($(document).width() < 769) { vW = $(document).width() }
	var vArr = responsiveSteps.split(',');
	var tmpSize = rSize;
	var vArr2 = '';
	var maxWidth = vArr[vArr.length - 1].split('=');
	var maxPreset = maxWidth[1];
	var nextbreak = false;
	if (highres) {
		vW = vW * 2;
	}
	
	maxWidth = maxWidth[0];
	if (vW > maxWidth) {
		rSize = maxWidth;
		rPreset = maxPreset;
	} else {
		for (var i = 0; i < vArr.length; i++) {
			vArr2 = vArr[i].split('=');
			//console.log(vArr2[0]);
			if (vW < (vArr2[0])) {
				rSize = vArr2[0];
				//console.log(rSize);
				rPreset = vArr2[1];
				break;
				//if ((nextbreak === false) && (vW >= 399)) {
				//	nextbreak = true;
				//} else {
				//	break;
				//}
			}
		}
	}
	return rSize;
}

//detect high resolution / retina screen
function is_high_resolution_screen() {
	return window.devicePixelRatio > 1;
}
imagesloaded.js
/*!
 * imagesLoaded PACKAGED v4.1.4
 * JavaScript is all like "You images are done yet or what?"
 * MIT License
 */

!function (e, t) { "function" == typeof define && define.amd ? define("ev-emitter/ev-emitter", t) : "object" == typeof module && module.exports ? module.exports = t() : e.EvEmitter = t() }("undefined" != typeof window ? window : this, function () { function e() { } var t = e.prototype; return t.on = function (e, t) { if (e && t) { var i = this._events = this._events || {}, n = i[e] = i[e] || []; return n.indexOf(t) == -1 && n.push(t), this } }, t.once = function (e, t) { if (e && t) { this.on(e, t); var i = this._onceEvents = this._onceEvents || {}, n = i[e] = i[e] || {}; return n[t] = !0, this } }, t.off = function (e, t) { var i = this._events && this._events[e]; if (i && i.length) { var n = i.indexOf(t); return n != -1 && i.splice(n, 1), this } }, t.emitEvent = function (e, t) { var i = this._events && this._events[e]; if (i && i.length) { i = i.slice(0), t = t || []; for (var n = this._onceEvents && this._onceEvents[e], o = 0; o < i.length; o++) { var r = i[o], s = n && n[r]; s && (this.off(e, r), delete n[r]), r.apply(this, t) } return this } }, t.allOff = function () { delete this._events, delete this._onceEvents }, e }), function (e, t) { "use strict"; "function" == typeof define && define.amd ? define(["ev-emitter/ev-emitter"], function (i) { return t(e, i) }) : "object" == typeof module && module.exports ? module.exports = t(e, require("ev-emitter")) : e.imagesLoaded = t(e, e.EvEmitter) }("undefined" != typeof window ? window : this, function (e, t) { function i(e, t) { for (var i in t) e[i] = t[i]; return e } function n(e) { if (Array.isArray(e)) return e; var t = "object" == typeof e && "number" == typeof e.length; return t ? d.call(e) : [e] } function o(e, t, r) { if (!(this instanceof o)) return new o(e, t, r); var s = e; return "string" == typeof e && (s = document.querySelectorAll(e)), s ? (this.elements = n(s), this.options = i({}, this.options), "function" == typeof t ? r = t : i(this.options, t), r && this.on("always", r), this.getImages(), h && (this.jqDeferred = new h.Deferred), void setTimeout(this.check.bind(this))) : void a.error("Bad element for imagesLoaded " + (s || e)) } function r(e) { this.img = e } function s(e, t) { this.url = e, this.element = t, this.img = new Image } var h = e.jQuery, a = e.console, d = Array.prototype.slice; o.prototype = Object.create(t.prototype), o.prototype.options = {}, o.prototype.getImages = function () { this.images = [], this.elements.forEach(this.addElementImages, this) }, o.prototype.addElementImages = function (e) { "IMG" == e.nodeName && this.addImage(e), this.options.background === !0 && this.addElementBackgroundImages(e); var t = e.nodeType; if (t && u[t]) { for (var i = e.querySelectorAll("img"), n = 0; n < i.length; n++) { var o = i[n]; this.addImage(o) } if ("string" == typeof this.options.background) { var r = e.querySelectorAll(this.options.background); for (n = 0; n < r.length; n++) { var s = r[n]; this.addElementBackgroundImages(s) } } } }; var u = { 1: !0, 9: !0, 11: !0 }; return o.prototype.addElementBackgroundImages = function (e) { var t = getComputedStyle(e); if (t) for (var i = /url\((['"])?(.*?)\1\)/gi, n = i.exec(t.backgroundImage); null !== n;) { var o = n && n[2]; o && this.addBackground(o, e), n = i.exec(t.backgroundImage) } }, o.prototype.addImage = function (e) { var t = new r(e); this.images.push(t) }, o.prototype.addBackground = function (e, t) { var i = new s(e, t); this.images.push(i) }, o.prototype.check = function () { function e(e, i, n) { setTimeout(function () { t.progress(e, i, n) }) } var t = this; return this.progressedCount = 0, this.hasAnyBroken = !1, this.images.length ? void this.images.forEach(function (t) { t.once("progress", e), t.check() }) : void this.complete() }, o.prototype.progress = function (e, t, i) { this.progressedCount++ , this.hasAnyBroken = this.hasAnyBroken || !e.isLoaded, this.emitEvent("progress", [this, e, t]), this.jqDeferred && this.jqDeferred.notify && this.jqDeferred.notify(this, e), this.progressedCount == this.images.length && this.complete(), this.options.debug && a && a.log("progress: " + i, e, t) }, o.prototype.complete = function () { var e = this.hasAnyBroken ? "fail" : "done"; if (this.isComplete = !0, this.emitEvent(e, [this]), this.emitEvent("always", [this]), this.jqDeferred) { var t = this.hasAnyBroken ? "reject" : "resolve"; this.jqDeferred[t](this) } }, r.prototype = Object.create(t.prototype), r.prototype.check = function () { var e = this.getIsImageComplete(); return e ? void this.confirm(0 !== this.img.naturalWidth, "naturalWidth") : (this.proxyImage = new Image, this.proxyImage.addEventListener("load", this), this.proxyImage.addEventListener("error", this), this.img.addEventListener("load", this), this.img.addEventListener("error", this), void (this.proxyImage.src = this.img.src)) }, r.prototype.getIsImageComplete = function () { return this.img.complete && this.img.naturalWidth }, r.prototype.confirm = function (e, t) { this.isLoaded = e, this.emitEvent("progress", [this, this.img, t]) }, r.prototype.handleEvent = function (e) { var t = "on" + e.type; this[t] && this[t](e) }, r.prototype.onload = function () { this.confirm(!0, "onload"), this.unbindEvents() }, r.prototype.onerror = function () { this.confirm(!1, "onerror"), this.unbindEvents() }, r.prototype.unbindEvents = function () { this.proxyImage.removeEventListener("load", this), this.proxyImage.removeEventListener("error", this), this.img.removeEventListener("load", this), this.img.removeEventListener("error", this) }, s.prototype = Object.create(r.prototype), s.prototype.check = function () { this.img.addEventListener("load", this), this.img.addEventListener("error", this), this.img.src = this.url; var e = this.getIsImageComplete(); e && (this.confirm(0 !== this.img.naturalWidth, "naturalWidth"), this.unbindEvents()) }, s.prototype.unbindEvents = function () { this.img.removeEventListener("load", this), this.img.removeEventListener("error", this) }, s.prototype.confirm = function (e, t) { this.isLoaded = e, this.emitEvent("progress", [this, this.element, t]) }, o.makeJQueryPlugin = function (t) { t = t || e.jQuery, t && (h = t, h.fn.imagesLoaded = function (e, t) { var i = new o(this, e, t); return i.jqDeferred.promise(h(this)) }) }, o.makeJQueryPlugin(), o });
onscreen.js
// jquery.onscreen 2018-01-22 https://github.com/adaptlearning/jquery.onscreen
"use strict"; !function () { function e(e) { for (var t = 0, n = e.length; t < n; t++) { var i = e[t].toLowerCase(); this[i] = new Number(t), this[i].string = i } } var t = { index: 0, check: function (e) { e[$.expando] || (e[$.expando] = ++t.index) }, make: function (e, n) { return t.check(e), n.guid + "-" + e[$.expando] } }, n = { TYPE: new e(["onscreen", "inview"]), INVIEW_STATES: new e(["none", "top", "bottom", "left", "right", "both"]), registered: [], shouldReProcess: !0, register: function (e, i, o) { var s = r.isLocked(), c = $(e); n.registered.push({ id: t.make(e, i), data: i, $element: c, type: o, _onscreen: s ? null : a.get(c).uniqueMeasurementId, _hasTriggered: !1 }), n.shouldReProcess = !0 }, unregister: function (e, i, r) { for (var o = n.registered, s = t.make(e, i), a = o.length - 1; a > -1; a--) { var c = o[a]; c.id == s && c.type == r && (o.splice(a, 1), n.shouldReProcess = !0) } }, process: function () { var e, t = n.registered; for (n.shouldReProcess = !0; n.shouldReProcess;) { if (n.shouldReProcess = !1, 0 == (e = t.length)) return; for (var i = 0; i < e; i++) { var r = t[i], o = a.get(r.$element); if (void 0 !== r._onscreen && r._hasTriggered) if (!(r._onscreen != o.uniqueMeasurementId)) continue; switch (r._onscreen = o.uniqueMeasurementId, r._hasTriggered = !0, r.type) { case n.TYPE.onscreen: n.processOnScreen(r, o); break; case n.TYPE.inview: n.processInView(r, o) }if (n.shouldReProcess) break } } }, processOnScreen: function (e, t) { e.$element.trigger("onscreen", t) }, processInView: function (e, t) { var i, r, o = t.percentFromTop >= 0 && t.percentFromTop <= 100, s = t.percentFromBottom >= 0 && t.percentFromBottom <= 100, a = t.percentFromLeft >= 0 && t.percentFromLeft <= 100, c = t.percentFromRight >= 0 && t.percentFromRight <= 100; i = o && s ? n.INVIEW_STATES.both.string : o ? n.INVIEW_STATES.top.string : s ? n.INVIEW_STATES.bottom.string : n.INVIEW_STATES.none.string, r = a && c ? n.INVIEW_STATES.both.string : a ? n.INVIEW_STATES.left.string : c ? n.INVIEW_STATES.right.string : n.INVIEW_STATES.none.string; var u = [t.onscreen, r, i]; e._inviewPreviousState = u, e._measurePreviousState = t, e.$element.trigger("inview", u) } }, i = { lastStartEvent: 0, timeoutHandle: null, intervalDuration: 100, hasRaf: !1, start: function () { i.lastStartEvent = (new Date).getTime(), i.repeat() }, repeat: function () { i.stop(), i.hasRaf ? i.timeoutHandle = requestAnimationFrame(i.main) : i.timeoutHandle = setTimeout(i.main, i.intervalDuration) }, hasExpired: function () { if (!((new Date).getTime() - i.lastStartEvent < 1500)) return i.stop(), !0 }, isThrottled: function () { return !((new Date).getTime() - i.lastMain > i.intervalDuration) }, lastMain: (new Date).getTime(), main: function () { i.isThrottled() ? i.repeat() : (i.lastMain = (new Date).getTime(), i.hasExpired() || (0 == n.registered.length ? (i.stop(), i.intervalDuration = 200, i.repeat()) : (i.stop(), i.intervalDuration = 100, i.repeat()), r.isLocked() || n.process())) }, stop: function () { null !== i.timeoutHandle && (i.hasRaf ? (cancelAnimationFrame(i.timeoutHandle), i.timeoutHandle = null) : (clearTimeout(i.timeoutHandle), i.timeoutHandle = null)) } }; $.extend($.event.special, { onscreen: { noBubble: !0, add: function (e) { n.register(this, e, n.TYPE.onscreen) }, remove: function (e) { n.unregister(this, e, n.TYPE.onscreen) } }, inview: { noBubble: !0, add: function (e) { n.register(this, e, n.TYPE.inview) }, remove: function (e) { n.unregister(this, e, n.TYPE.inview) } } }), $.extend($.fn, { onscreen: function (e) { return e ? (this.on("onscreen", e), this) : a.get(this) }, inview: function (e) { return e ? (this.on("inview", e), this) : a.get(this) } }); var r = { locks: [], lock: function (e) { r.isLocked(e) || r.locks.push(e) }, unlock: function (e) { if (r.isLocked(e)) { for (var t = 0, n = r.locks.length; t < n; t++) { if (r.locks[t] == e) { r.locks.splice(t, 1); break } } i.start() } }, isLocked: function (e) { if (!e) return r.locks.length > 0; for (var t = 0, n = r.locks.length; t < n; t++) { if (r.locks[t] == e) return !0 } return !1 } }, o = { options: {}, config: function (e) { "object" == typeof e && $.extend(o.options, e) } }; $.inview = $.onscreen = function () { i.start() }, $.extend($.inview, r, o); var s = { $el: $(window), height: null, width: null, heightRatio: null, widthRatio: null, resize: function () { s.height = window.innerHeight || s.$el.height(), s.width = window.innerWidth || s.$el.width(), s.heightRatio = 100 / s.height, s.widthRatio = 100 / s.width, i.start() } }, a = { featureDetect: function () { i.hasRaf = window.requestAnimationFrame && window.cancelAnimationFrame }, get: function (e) { if (0 != e.length) { var t, n = e[0]; try { t = n.getBoundingClientRect() } catch (e) { t = { top: 0, right: 0, bottom: 0, left: 0, width: 0, height: 0 } } var i = t.height, r = t.width, o = t.top, c = t.left, u = s.height - (o + i), l = s.width - (c + r), h = Math.round(s.heightRatio * o), d = Math.round(s.widthRatio * c), g = Math.round(s.heightRatio * u), f = Math.round(s.widthRatio * l), m = null; m = c + r > 0 && l < 0 && c < 0 ? r : c < 0 ? r + c : c + r > s.width ? s.width - c : r; var p = null; (p = o + i > 0 && u < 0 && o < 0 ? i : o < 0 ? i + o : o + i > s.height ? s.height - o : i) < 0 && (p = 0), m < 0 && (m = 0); var v = Math.round(100 / i * p), w = Math.round(100 / r * m), T = i * r, E = p * m, I = Math.round(100 / T * E), k = !0; (f > 100 || d > 100 || g > 100 || h > 100) && (k = !1), i <= 0 && r <= 0 && (k = !1); var S = a.isElementHidden(n); if (S && (k = !1), k) for (var $ = a.getParents(n), R = 0, b = $.length - 1; R < b; R++) { var P = $[R]; if (S = a.isElementHidden(P)) { k = !1; break } if (a.isOutOfBounds(n, P)) { k = !1; break } } return { top: o, left: c, bottom: u, right: l, percentFromTop: h, percentFromLeft: d, percentFromBottom: g, percentFromRight: f, percentInview: I, percentInviewHorizontal: w, percentInviewVertical: v, onscreen: k, uniqueMeasurementId: "" + o + c + u + l + i + r + s.height + s.width + k, timestamp: (new Date).getTime() } } }, getParents: function (e) { for (var t, n = []; t = e.parentElement;)n.push(t), e = t; return n }, isElementHidden: function (e) { var t = "none" == e.style.display || "hidden" == e.style.visibility; if (t) return !0; var n = window.getComputedStyle(e, null); return t = "none" == n.display || "hidden" == n.visibility }, isOutOfBounds: function (e, t) { var n = t.clientWidth < t.scrollWidth, i = t.clientHeight < t.scrollHeight, r = n || i, o = $(t); if (!r || "visible" === o.css("overflow")) return !1; var s = $(e).offset(), a = o.offset(), c = s.top - a.top, u = s.left - a.left, l = c + e.clientHeight, h = u + e.clientWidth; return c >= t.clientHeight || u >= t.clientWidth || l <= 0 || h <= 0 } }; $(window).on({ "touchmove scroll mousedown keydown": i.start, resize: s.resize }), $(a.featureDetect), s.resize() }();
lazyload.less
.lazyload {
  opacity: 0.1;
  .transition(all 0.5s ease-in-out);
  min-width:100%;
  &.lazyloaded {
    opacity: 1;
    min-width:0;
  }
}

less 由http://atom.io/packages/sync-settings自动更新

由http://atom.io/packages/sync-settings自动更新

config.conf
.
init.coffee
# Your init script
#
# Atom will evaluate this file each time a new window is opened. It is run
# after packages are loaded/activated and after the previous editor state
# has been restored.
#
# An example hack to log to the console when each text editor is saved.
#
# atom.workspace.observeTextEditors (editor) ->
#   editor.onDidSave ->
#     console.log "Saved! #{editor.getPath()}"
keymap.cson
# Your keymap
#
# Atom keymaps work similarly to style sheets. Just as style sheets use
# selectors to apply styles to elements, Atom keymaps use selectors to associate
# keystrokes with events in specific contexts. Unlike style sheets however,
# each selector can only be declared once.
#
# You can create a new keybinding in this file by typing "key" and then hitting
# tab.
#
# Here's an example taken from Atom's built-in keymap:
#
# 'atom-text-editor':
#   'enter': 'editor:newline'
#
# 'atom-workspace':
#   'ctrl-shift-p': 'core:move-up'
#   'ctrl-p': 'core:move-down'
#
# You can find more information about keymaps in these guides:
# * http://flight-manual.atom.io/using-atom/sections/basic-customization/#customizing-keybindings
# * http://flight-manual.atom.io/behind-atom/sections/keymaps-in-depth/
#
# If you're having trouble with your keybindings not working, try the
# Keybinding Resolver: `Cmd+.` on macOS and `Ctrl+.` on other platforms. See the
# Debugging Guide for more information:
# * http://flight-manual.atom.io/hacking-atom/sections/debugging/#check-the-keybindings
#
# This file uses CoffeeScript Object Notation (CSON).
# If you are unfamiliar with CSON, you can read more about it in the
# Atom Flight Manual:
# http://flight-manual.atom.io/using-atom/sections/basic-customization/#configuring-with-cson
packages.json
[
	{
		"name": "Hydrogen",
		"version": "2.9.0"
	},
	{
		"name": "about",
		"version": "1.9.1"
	},
	{
		"name": "archive-view",
		"version": "0.65.1"
	},
	{
		"name": "atom-clock",
		"version": "0.1.16"
	},
	{
		"name": "atom-cursor-indent",
		"version": "0.3.3"
	},
	{
		"name": "atom-dark-syntax",
		"version": "0.29.1",
		"theme": "syntax"
	},
	{
		"name": "atom-dark-ui",
		"version": "0.53.3",
		"theme": "ui"
	},
	{
		"name": "atom-light-syntax",
		"version": "0.29.1",
		"theme": "syntax"
	},
	{
		"name": "atom-light-ui",
		"version": "0.46.3",
		"theme": "ui"
	},
	{
		"name": "atom-material-syntax",
		"version": "1.0.8",
		"theme": "syntax"
	},
	{
		"name": "atom-material-ui",
		"version": "2.1.3",
		"theme": "ui"
	},
	{
		"name": "atom-sync",
		"version": "0.7.3"
	},
	{
		"name": "atom-sync-packages",
		"version": "1.1.0"
	},
	{
		"name": "autocomplete-atom-api",
		"version": "0.10.7"
	},
	{
		"name": "autocomplete-css",
		"version": "0.17.5"
	},
	{
		"name": "autocomplete-html",
		"version": "0.8.8"
	},
	{
		"name": "autocomplete-plus",
		"version": "2.42.0"
	},
	{
		"name": "autocomplete-snippets",
		"version": "1.12.1"
	},
	{
		"name": "autoflow",
		"version": "0.29.4"
	},
	{
		"name": "autosave",
		"version": "0.24.6"
	},
	{
		"name": "background-tips",
		"version": "0.28.0"
	},
	{
		"name": "base16-tomorrow-dark-theme",
		"version": "1.6.0",
		"theme": "syntax"
	},
	{
		"name": "base16-tomorrow-light-theme",
		"version": "1.6.0",
		"theme": "syntax"
	},
	{
		"name": "block-select",
		"version": "1.0.0"
	},
	{
		"name": "bookmarks",
		"version": "0.46.0"
	},
	{
		"name": "bracket-matcher",
		"version": "0.91.0"
	},
	{
		"name": "command-palette",
		"version": "0.43.5"
	},
	{
		"name": "dalek",
		"version": "0.2.2"
	},
	{
		"name": "data-explorer",
		"version": "0.6.0"
	},
	{
		"name": "deprecation-cop",
		"version": "0.56.9"
	},
	{
		"name": "dev-live-reload",
		"version": "0.48.1"
	},
	{
		"name": "encoding-selector",
		"version": "0.23.9"
	},
	{
		"name": "exception-reporting",
		"version": "0.43.1"
	},
	{
		"name": "expand-selection-to-indentation",
		"version": "0.4.0"
	},
	{
		"name": "find-and-replace",
		"version": "0.218.10"
	},
	{
		"name": "fuzzy-finder",
		"version": "1.13.5"
	},
	{
		"name": "git-diff",
		"version": "1.3.9"
	},
	{
		"name": "github",
		"version": "0.29.0"
	},
	{
		"name": "go-to-line",
		"version": "0.33.0"
	},
	{
		"name": "grammar-selector",
		"version": "0.50.1"
	},
	{
		"name": "hey-pane",
		"version": "1.1.2"
	},
	{
		"name": "hydrogen-launcher",
		"version": "1.2.2"
	},
	{
		"name": "image-view",
		"version": "0.64.0"
	},
	{
		"name": "incompatible-packages",
		"version": "0.27.3"
	},
	{
		"name": "indentation-indicator",
		"version": "1.1.0"
	},
	{
		"name": "indentation-jumper",
		"version": "0.1.2"
	},
	{
		"name": "keybinding-resolver",
		"version": "0.39.0"
	},
	{
		"name": "language-c",
		"version": "0.60.16"
	},
	{
		"name": "language-clojure",
		"version": "0.22.8"
	},
	{
		"name": "language-coffee-script",
		"version": "0.50.0"
	},
	{
		"name": "language-csharp",
		"version": "1.1.0"
	},
	{
		"name": "language-css",
		"version": "0.44.0"
	},
	{
		"name": "language-gfm",
		"version": "0.90.6"
	},
	{
		"name": "language-git",
		"version": "0.19.1"
	},
	{
		"name": "language-go",
		"version": "0.47.0"
	},
	{
		"name": "language-html",
		"version": "0.52.1"
	},
	{
		"name": "language-hyperlink",
		"version": "0.17.1"
	},
	{
		"name": "language-java",
		"version": "0.31.3"
	},
	{
		"name": "language-javascript",
		"version": "0.130.0"
	},
	{
		"name": "language-json",
		"version": "1.0.4"
	},
	{
		"name": "language-less",
		"version": "0.34.3"
	},
	{
		"name": "language-make",
		"version": "0.23.0"
	},
	{
		"name": "language-mustache",
		"version": "0.14.5"
	},
	{
		"name": "language-objective-c",
		"version": "0.15.1"
	},
	{
		"name": "language-perl",
		"version": "0.38.1"
	},
	{
		"name": "language-php",
		"version": "0.44.1"
	},
	{
		"name": "language-property-list",
		"version": "0.9.1"
	},
	{
		"name": "language-python",
		"version": "0.53.1"
	},
	{
		"name": "language-ruby",
		"version": "0.72.16"
	},
	{
		"name": "language-ruby-on-rails",
		"version": "0.25.3"
	},
	{
		"name": "language-rust-bundled",
		"version": "0.1.0"
	},
	{
		"name": "language-sass",
		"version": "0.62.0"
	},
	{
		"name": "language-shellscript",
		"version": "0.27.11"
	},
	{
		"name": "language-source",
		"version": "0.9.0"
	},
	{
		"name": "language-sql",
		"version": "0.25.10"
	},
	{
		"name": "language-text",
		"version": "0.7.4"
	},
	{
		"name": "language-todo",
		"version": "0.29.4"
	},
	{
		"name": "language-toml",
		"version": "0.20.0"
	},
	{
		"name": "language-typescript",
		"version": "0.4.11"
	},
	{
		"name": "language-xml",
		"version": "0.35.3"
	},
	{
		"name": "language-yaml",
		"version": "0.32.0"
	},
	{
		"name": "line-ending-selector",
		"version": "0.7.7"
	},
	{
		"name": "link",
		"version": "0.31.6"
	},
	{
		"name": "markdown-preview",
		"version": "0.160.0"
	},
	{
		"name": "metrics",
		"version": "1.8.1"
	},
	{
		"name": "notifications",
		"version": "0.70.6"
	},
	{
		"name": "one-dark-syntax",
		"version": "1.8.4",
		"theme": "syntax"
	},
	{
		"name": "one-dark-ui",
		"version": "1.12.5",
		"theme": "ui"
	},
	{
		"name": "one-light-syntax",
		"version": "1.8.4",
		"theme": "syntax"
	},
	{
		"name": "one-light-ui",
		"version": "1.12.5",
		"theme": "ui"
	},
	{
		"name": "open-on-github",
		"version": "1.3.1"
	},
	{
		"name": "package-generator",
		"version": "1.3.0"
	},
	{
		"name": "package-sync",
		"version": "1.1.0"
	},
	{
		"name": "python-indent",
		"version": "1.2.3"
	},
	{
		"name": "scroll-through-time",
		"version": "0.3.1"
	},
	{
		"name": "settings-view",
		"version": "0.261.3"
	},
	{
		"name": "snippets",
		"version": "1.5.0"
	},
	{
		"name": "solarized-dark-syntax",
		"version": "1.3.0",
		"theme": "syntax"
	},
	{
		"name": "solarized-light-syntax",
		"version": "1.3.0",
		"theme": "syntax"
	},
	{
		"name": "spell-check",
		"version": "0.74.5"
	},
	{
		"name": "status-bar",
		"version": "1.8.17"
	},
	{
		"name": "structure-view",
		"version": "0.2.1"
	},
	{
		"name": "styleguide",
		"version": "0.49.12"
	},
	{
		"name": "symbols-view",
		"version": "0.118.2"
	},
	{
		"name": "sync-settings",
		"version": "0.8.6"
	},
	{
		"name": "tabs",
		"version": "0.110.0"
	},
	{
		"name": "timecop",
		"version": "0.36.2"
	},
	{
		"name": "tree-view",
		"version": "0.227.0"
	},
	{
		"name": "tree-view-extended",
		"version": "2.1.0"
	},
	{
		"name": "update-package-dependencies",
		"version": "0.13.1"
	},
	{
		"name": "welcome",
		"version": "0.36.9"
	},
	{
		"name": "whitespace",
		"version": "0.37.7"
	},
	{
		"name": "wrap-guide",
		"version": "0.41.0"
	},
	{
		"name": "zentabs",
		"version": "0.8.9"
	}
]
settings.json
{
	"atom-clock": {},
	"core": {
		"autoHideMenuBar": true,
		"telemetryConsent": "no",
		"themes": [
			"atom-material-ui",
			"atom-material-syntax"
		],
		"uriHandlerRegistration": "always"
	},
	"editor": {
		"tabType": "soft"
	},
	"exception-reporting": {
		"userId": "69342be8-c3be-4774-9842-0c9fd5b8c73f"
	},
	"fuzzy-finder": {
		"scoringSystem": "fast",
		"useRipGrep": true
	},
	"package-sync": {
		"createOnChange": true,
		"forceOverwrite": true
	},
	"structure-view": {
		"AutoscrollFromSource": true
	},
	"sync-settings": {},
	"welcome": {
		"showOnStartup": false
	}
}
snippets.cson
# Your snippets
#
# Atom snippets allow you to enter a simple prefix in the editor and hit tab to
# expand the prefix into a larger code block with templated values.
#
# You can create a new snippet in this file by typing "snip" and then hitting
# tab.
#
# An example CoffeeScript snippet to expand log to console.log:
#
# '.source.coffee':
#   'Console log':
#     'prefix': 'log'
#     'body': 'console.log $1'
#
# Each scope (e.g. '.source.coffee' above) can only be declared once.
#
# This file uses CoffeeScript Object Notation (CSON).
# If you are unfamiliar with CSON, you can read more about it in the
# Atom Flight Manual:
# http://flight-manual.atom.io/using-atom/sections/basic-customization/#_cson
styles.less
/*
 * Your Stylesheet
 *
 * This stylesheet is loaded when Atom starts up and is reloaded automatically
 * when it is changed and saved.
 *
 * Add your own CSS or Less to fully customize Atom.
 * If you are unfamiliar with Less, you can read more about it here:
 * http://lesscss.org
 */


/*
 * Examples
 * (To see them, uncomment and save)
 */

// style the background color of the tree view
.tree-view {
  // background-color: whitesmoke;
}

// style the background and foreground colors on the atom-text-editor-element itself
atom-text-editor {
  // color: white;
  // background-color: hsl(180, 24%, 12%);
}

// style UI elements inside atom-text-editor
atom-text-editor .cursor {
  // border-color: red;
}

less 由http://atom.io/packages/sync-settings自动更新

由http://atom.io/packages/sync-settings自动更新

init.coffee
# initialization file (not found)
keymap.cson
'atom-text-editor':
  'ctrl-shift-delete': 'hydrogen:clear-results'
  'ctrl-shift-X': 'markdown-preview-plus:toggle-render-latex'

packages.json
[
	{
		"name": "Hydrogen",
		"version": "2.9.0"
	},
	{
		"name": "about",
		"version": "1.9.1"
	},
	{
		"name": "activate-power-mode",
		"version": "2.7.0"
	},
	{
		"name": "archive-view",
		"version": "0.65.1"
	},
	{
		"name": "atom-beautify",
		"version": "0.33.4"
	},
	{
		"name": "atom-dark-syntax",
		"version": "0.29.1",
		"theme": "syntax"
	},
	{
		"name": "atom-dark-ui",
		"version": "0.53.3",
		"theme": "ui"
	},
	{
		"name": "atom-file-icons",
		"version": "0.7.1"
	},
	{
		"name": "atom-ide-debugger-python",
		"version": "0.7.3"
	},
	{
		"name": "atom-ide-ui",
		"version": "0.13.0"
	},
	{
		"name": "atom-light-syntax",
		"version": "0.29.1",
		"theme": "syntax"
	},
	{
		"name": "atom-light-ui",
		"version": "0.46.3",
		"theme": "ui"
	},
	{
		"name": "autocomplete-atom-api",
		"version": "0.10.7"
	},
	{
		"name": "autocomplete-css",
		"version": "0.17.5"
	},
	{
		"name": "autocomplete-html",
		"version": "0.8.8"
	},
	{
		"name": "autocomplete-html-entities",
		"version": "0.2.0"
	},
	{
		"name": "autocomplete-paths",
		"version": "2.12.2"
	},
	{
		"name": "autocomplete-plus",
		"version": "2.42.0"
	},
	{
		"name": "autocomplete-python",
		"version": "1.14.0"
	},
	{
		"name": "autocomplete-snippets",
		"version": "1.12.0"
	},
	{
		"name": "autoflow",
		"version": "0.29.4"
	},
	{
		"name": "autosave",
		"version": "0.24.6"
	},
	{
		"name": "background-tips",
		"version": "0.28.0"
	},
	{
		"name": "base16-tomorrow-dark-theme",
		"version": "1.6.0",
		"theme": "syntax"
	},
	{
		"name": "base16-tomorrow-light-theme",
		"version": "1.6.0",
		"theme": "syntax"
	},
	{
		"name": "bookmarks",
		"version": "0.46.0"
	},
	{
		"name": "bracket-matcher",
		"version": "0.90.4"
	},
	{
		"name": "command-palette",
		"version": "0.43.5"
	},
	{
		"name": "dalek",
		"version": "0.2.2"
	},
	{
		"name": "deprecation-cop",
		"version": "0.56.9"
	},
	{
		"name": "dev-live-reload",
		"version": "0.48.1"
	},
	{
		"name": "encoding-selector",
		"version": "0.23.9"
	},
	{
		"name": "exception-reporting",
		"version": "0.43.1"
	},
	{
		"name": "find-and-replace",
		"version": "0.218.9"
	},
	{
		"name": "fuzzy-finder",
		"version": "1.13.1"
	},
	{
		"name": "git-blame",
		"version": "1.8.0"
	},
	{
		"name": "git-diff",
		"version": "1.3.9"
	},
	{
		"name": "git-plus",
		"version": "8.6.3"
	},
	{
		"name": "github",
		"version": "0.28.1"
	},
	{
		"name": "go-to-line",
		"version": "0.33.0"
	},
	{
		"name": "goto-definition",
		"version": "1.3.4"
	},
	{
		"name": "grammar-selector",
		"version": "0.50.1"
	},
	{
		"name": "highlight-line",
		"version": "0.12.0"
	},
	{
		"name": "highlight-selected",
		"version": "0.16.0"
	},
	{
		"name": "image-view",
		"version": "0.64.0"
	},
	{
		"name": "incompatible-packages",
		"version": "0.27.3"
	},
	{
		"name": "keybinding-resolver",
		"version": "0.39.0"
	},
	{
		"name": "language-c",
		"version": "0.60.14"
	},
	{
		"name": "language-clojure",
		"version": "0.22.8"
	},
	{
		"name": "language-coffee-script",
		"version": "0.50.0"
	},
	{
		"name": "language-csharp",
		"version": "1.1.0"
	},
	{
		"name": "language-css",
		"version": "0.44.0"
	},
	{
		"name": "language-cython",
		"version": "0.3.0"
	},
	{
		"name": "language-docker",
		"version": "1.1.8"
	},
	{
		"name": "language-gfm",
		"version": "0.90.6"
	},
	{
		"name": "language-git",
		"version": "0.19.1"
	},
	{
		"name": "language-go",
		"version": "0.46.6"
	},
	{
		"name": "language-html",
		"version": "0.52.0"
	},
	{
		"name": "language-hyperlink",
		"version": "0.17.0"
	},
	{
		"name": "language-java",
		"version": "0.31.1"
	},
	{
		"name": "language-javascript",
		"version": "0.129.21"
	},
	{
		"name": "language-json",
		"version": "0.19.2"
	},
	{
		"name": "language-latex",
		"version": "1.2.0"
	},
	{
		"name": "language-less",
		"version": "0.34.3"
	},
	{
		"name": "language-make",
		"version": "0.23.0"
	},
	{
		"name": "language-markdown",
		"version": "0.37.0"
	},
	{
		"name": "language-mustache",
		"version": "0.14.5"
	},
	{
		"name": "language-objective-c",
		"version": "0.15.1"
	},
	{
		"name": "language-perl",
		"version": "0.38.1"
	},
	{
		"name": "language-php",
		"version": "0.44.1"
	},
	{
		"name": "language-property-list",
		"version": "0.9.1"
	},
	{
		"name": "language-python",
		"version": "0.51.10"
	},
	{
		"name": "language-ruby",
		"version": "0.72.16"
	},
	{
		"name": "language-ruby-on-rails",
		"version": "0.25.3"
	},
	{
		"name": "language-rust-bundled",
		"version": "0.1.0"
	},
	{
		"name": "language-sass",
		"version": "0.62.0"
	},
	{
		"name": "language-shellscript",
		"version": "0.27.9"
	},
	{
		"name": "language-source",
		"version": "0.9.0"
	},
	{
		"name": "language-sql",
		"version": "0.25.10"
	},
	{
		"name": "language-text",
		"version": "0.7.4"
	},
	{
		"name": "language-todo",
		"version": "0.29.4"
	},
	{
		"name": "language-toml",
		"version": "0.20.0"
	},
	{
		"name": "language-typescript",
		"version": "0.4.11"
	},
	{
		"name": "language-xml",
		"version": "0.35.3"
	},
	{
		"name": "language-yaml",
		"version": "0.32.0"
	},
	{
		"name": "latex",
		"version": "0.50.2"
	},
	{
		"name": "line-ending-selector",
		"version": "0.7.7"
	},
	{
		"name": "link",
		"version": "0.31.6"
	},
	{
		"name": "linter",
		"version": "2.3.0"
	},
	{
		"name": "linter-docker",
		"version": "0.3.2"
	},
	{
		"name": "markdown-preview",
		"version": "0.159.25"
	},
	{
		"name": "markdown-preview-enhanced",
		"version": "0.16.1"
	},
	{
		"name": "markdown-preview-plus",
		"version": "3.8.1"
	},
	{
		"name": "markdown-writer",
		"version": "2.11.5"
	},
	{
		"name": "merge-conflicts",
		"version": "1.4.5"
	},
	{
		"name": "metrics",
		"version": "1.7.2"
	},
	{
		"name": "minimap",
		"version": "4.29.9"
	},
	{
		"name": "minimap-cursorline",
		"version": "0.2.0"
	},
	{
		"name": "minimap-find-and-replace",
		"version": "4.5.2"
	},
	{
		"name": "minimap-git-diff",
		"version": "4.3.1"
	},
	{
		"name": "minimap-highlight-selected",
		"version": "4.6.1"
	},
	{
		"name": "minimap-linter",
		"version": "2.2.1"
	},
	{
		"name": "notifications",
		"version": "0.70.6"
	},
	{
		"name": "one-dark-syntax",
		"version": "1.8.4",
		"theme": "syntax"
	},
	{
		"name": "one-dark-ui",
		"version": "1.12.5",
		"theme": "ui"
	},
	{
		"name": "one-light-syntax",
		"version": "1.8.4",
		"theme": "syntax"
	},
	{
		"name": "one-light-ui",
		"version": "1.12.5",
		"theme": "ui"
	},
	{
		"name": "open-on-github",
		"version": "1.3.1"
	},
	{
		"name": "package-generator",
		"version": "1.3.0"
	},
	{
		"name": "pdf-view",
		"version": "0.71.0"
	},
	{
		"name": "platformio-ide-terminal",
		"version": "2.9.1"
	},
	{
		"name": "python-black",
		"version": "0.7.0"
	},
	{
		"name": "python-debugger",
		"version": "0.2.0"
	},
	{
		"name": "python-indent",
		"version": "1.2.3"
	},
	{
		"name": "python-tools",
		"version": "0.6.9"
	},
	{
		"name": "regex-railroad-diagram",
		"version": "0.19.4"
	},
	{
		"name": "script",
		"version": "3.18.1"
	},
	{
		"name": "settings-view",
		"version": "0.261.1"
	},
	{
		"name": "snippets",
		"version": "1.4.1"
	},
	{
		"name": "solarized-dark-syntax",
		"version": "1.3.0",
		"theme": "syntax"
	},
	{
		"name": "solarized-light-syntax",
		"version": "1.3.0",
		"theme": "syntax"
	},
	{
		"name": "sort-lines",
		"version": "0.19.0"
	},
	{
		"name": "spell-check",
		"version": "0.74.4"
	},
	{
		"name": "split-diff",
		"version": "1.6.0"
	},
	{
		"name": "status-bar",
		"version": "1.8.17"
	},
	{
		"name": "styleguide",
		"version": "0.49.12"
	},
	{
		"name": "symbol-gen",
		"version": "1.3.1"
	},
	{
		"name": "symbols-tree-view",
		"version": "0.14.0"
	},
	{
		"name": "symbols-view",
		"version": "0.118.2"
	},
	{
		"name": "sync-settings",
		"version": "0.8.6"
	},
	{
		"name": "tabs",
		"version": "0.110.0"
	},
	{
		"name": "timecop",
		"version": "0.36.2"
	},
	{
		"name": "tree-view",
		"version": "0.225.0"
	},
	{
		"name": "update-package-dependencies",
		"version": "0.13.1"
	},
	{
		"name": "welcome",
		"version": "0.36.9"
	},
	{
		"name": "whitespace",
		"version": "0.37.7"
	},
	{
		"name": "wrap-guide",
		"version": "0.41.0"
	}
]
settings.json
{
	"activate-power-mode": {
		"plugins": {
			"playAudio": true,
			"screenShake": true
		}
	},
	"core": {
		"disabledPackages": [
			"language-gfm",
			"linter",
			"markdown-preview"
		],
		"telemetryConsent": "no"
	},
	"editor": {
		"fontSize": 22,
		"preferredLineLength": 88,
		"tabLength": 4
	},
	"exception-reporting": {
		"userId": "4c37a8c8-2389-496b-9342-e3cd5fa3adb4"
	},
	"git-blame": {
		"columnWidth": 400
	},
	"minimap": {
		"plugins": {
			"cursorline": true,
			"cursorlineDecorationsZIndex": 0,
			"find-and-replace": true,
			"find-and-replaceDecorationsZIndex": 0,
			"git-diff": true,
			"git-diffDecorationsZIndex": 0,
			"highlight-selected": true,
			"highlight-selectedDecorationsZIndex": 0,
			"linter": true,
			"linterDecorationsZIndex": 0
		}
	},
	"sync-settings": {},
	"welcome": {
		"showOnStartup": false
	},
	"latex": {
		"opener": "pdf-view"
	},
	"platformio-ide-terminal": {
		"core": {
			"scrollback": 10000,
			"workingDirectory": "Active File"
		}
	}
}
snippets.cson
# snippets file (not found)
styles.less
.script-view .line {
      font-size: 20px;
}