Рекомендуемый способ включения бутстрап-библиотеки в приложение Ember.JS ember-cli

Я пытаюсь правильно установить Twitter Bootstrap в моем текущем проекте ember-cli. Я установил бутстрап с беседкой:

bower install --save bootstrap

Теперь библиотека сглажена в /vendor/bootstrap/dist/ (css | js | fonts) Я попробовал то, что упоминается здесь: http://ember-cli.com/#managing-dependencies заменяя пути и имена файлов css, но я получаю ошибки в файле Brocfile.js. Я думаю, что формат brocfile слишком сильно изменился по сравнению с примером.

Я также попытался @import с файлом /app/styles/app.css после перемещения таблиц стилей в каталоге /app/styles/:

@import url('/assets/bootstrap.css');
@import url('/assets/bootstrap-theme.css');

Но это не сработало. Файлы видны истинным сервером dev: http://localhost:4200/assets/bootstrap.css

Может кто-то бросить мне кость здесь?

спасибо

Изменить:

ember -v
ember-cli 0.0.23

brocfile.js

    /* global require, module */

var uglifyJavaScript = require('broccoli-uglify-js');
var replace = require('broccoli-replace');
var compileES6 = require('broccoli-es6-concatenator');
var validateES6 = require('broccoli-es6-import-validate');
var pickFiles = require('broccoli-static-compiler');
var mergeTrees = require('broccoli-merge-trees');

var env = require('broccoli-env').getEnv();
var getEnvJSON = require('./config/environment');

var p = require('ember-cli/lib/preprocessors');
var preprocessCss = p.preprocessCss;
var preprocessTemplates = p.preprocessTemplates;
var preprocessJs = p.preprocessJs;

module.exports = function (broccoli) {

  var prefix = 'caisse';
  var rootURL = '/';

  // index.html

  var indexHTML = pickFiles('app', {
    srcDir: '/',
    files: ['index.html'],
    destDir: '/'
  });

  indexHTML = replace(indexHTML, {
    files: ['index.html'],
    patterns: [{ match: /\{\{ENV\}\}/g, replacement: getEnvJSON.bind(null, env)}]
  });

  // sourceTrees, appAndDependencies for CSS and JavaScript

  var app = pickFiles('app', {
    srcDir: '/',
    destDir: prefix
  });

  app = preprocessTemplates(app);

  var config = pickFiles('config', { // Don't pick anything, just watch config folder
    srcDir: '/',
    files: [],
    destDir: '/'
  });

  var sourceTrees = [app, config, 'vendor'].concat(broccoli.bowerTrees());
  var appAndDependencies = mergeTrees(sourceTrees, { overwrite: true });

  // JavaScript

  var legacyFilesToAppend = [
    'jquery.js',
    'handlebars.js',
    'ember.js',
    'ic-ajax/dist/named-amd/main.js',
    'ember-data.js',
    'ember-resolver.js',
    'ember-shim.js',
    'bootstrap/dist/js/bootstrap.js'
  ];

  var applicationJs = preprocessJs(appAndDependencies, '/', prefix);

  applicationJs = compileES6(applicationJs, {
    loaderFile: 'loader/loader.js',
    ignoredModules: [
      'ember/resolver',
      'ic-ajax'
    ],
    inputFiles: [
      prefix + '/**/*.js'
    ],
    legacyFilesToAppend: legacyFilesToAppend,
    wrapInEval: env !== 'production',
    outputFile: '/assets/app.js'
  });

  if (env === 'production') {
    applicationJs = uglifyJavaScript(applicationJs, {
      mangle: false,
      compress: false
    });
  }

  // Styles

  var styles = preprocessCss(appAndDependencies, prefix + '/styles', '/assets');

  // Bootstrap Style integration
  var bootstrap = pickFiles('vendor', {
    srcDir: '/bootstrap/dist/css',
    files: [
      'bootstrap.css',
      'bootstrap-theme.css'
    ],
    destDir: '/assets/'
  });

//var bootstrap = preprocessCss(appAndDependencies, '/vendor/bootstrap/dist/css', '/assets');

  // Ouput

  var outputTrees = [
    indexHTML,
    applicationJs,
    'public',
    styles,
    bootstrap
  ];

  // Testing

  if (env !== 'production') {

    var tests = pickFiles('tests', {
      srcDir: '/',
      destDir: prefix + '/tests'
    });

    var testsIndexHTML = pickFiles('tests', {
      srcDir: '/',
      files: ['index.html'],
      destDir: '/tests'
    });

    var qunitStyles = pickFiles('vendor', {
      srcDir: '/qunit/qunit',
      files: ['qunit.css'],
      destDir: '/assets/'
    });

    testsIndexHTML = replace(testsIndexHTML, {
      files: ['tests/index.html'],
      patterns: [{ match: /\{\{ENV\}\}/g, replacement: getEnvJSON.bind(null, env)}]
    });

    tests = preprocessTemplates(tests);

    sourceTrees = [tests, 'vendor'].concat(broccoli.bowerTrees());
    appAndDependencies = mergeTrees(sourceTrees, { overwrite: true });

    var testsJs = preprocessJs(appAndDependencies, '/', prefix);

    var validatedJs = validateES6(mergeTrees([app, tests]), {
      whitelist: {
        'ember/resolver': ['default'],
        'ember-qunit': [
          'globalize',
          'moduleFor',
          'moduleForComponent',
          'moduleForModel',
          'test',
          'setResolver'
        ]
      }
    });

    var legacyTestFiles = [
      'qunit/qunit/qunit.js',
      'qunit-shim.js',
      'ember-qunit/dist/named-amd/main.js'
    ];

    legacyFilesToAppend = legacyFilesToAppend.concat(legacyTestFiles);

    testsJs = compileES6(testsJs, {
      // Temporary workaround for
      // https://github.com/joliss/broccoli-es6-concatenator/issues/9
      loaderFile: '_loader.js',
      ignoredModules: [
        'ember/resolver',
        'ember-qunit'
      ],
      inputFiles: [
        prefix + '/**/*.js'
      ],
      legacyFilesToAppend: legacyFilesToAppend,

      wrapInEval: true,
      outputFile: '/assets/tests.js'
    });

    var testsTrees = [qunitStyles, testsIndexHTML, validatedJs, testsJs];
    outputTrees = outputTrees.concat(testsTrees);
  }

  return mergeTrees(outputTrees, { overwrite: true });
};

Ответ 1

Возможно, вы захотите проверить ember-bootstrap, который автоматически импортирует загрузочные ресурсы.

ember install ember-bootstrap

Кроме того, он добавляет в приложение набор собственных компонентов ember, которые значительно упрощают работу с функциями бутстрапа в ember. Проверьте это, хотя я немного предвзятый, так как я автор этого!;)

Ответ 2

BASH:

bower install --save bootstrap

Brocfile.js:

app.import('vendor/bootstrap/dist/js/bootstrap.js');
app.import('vendor/bootstrap/dist/css/bootstrap.css');

JS будет добавлен в app.js, связанный по умолчанию, и CSS будет добавлен в assets/vendor.css, который с 14 мая также добавляется по умолчанию.

Для справки: http://www.ember-cli.com/#managing-dependencies

В ответ на вопрос @Joe, окружающий шрифты и другие активы, мне не удалось заставить рекомендуемый метод app.import() работать с шрифтами. Вместо этого я выбрал метод слияния и статический компилятор:

var mergeTrees = require('broccoli-merge-trees');
var pickFiles = require('broccoli-static-compiler');
var extraAssets = pickFiles('vendor/bootstrap/dist/fonts',{
    srcDir: '/', 
    files: ['**/*'],
    destDir: '/fonts'
});

module.exports = mergeTrees([app.toTree(), extraAssets]);

Ответ 3

BASH:

bower install --save bootstrap

Brocfile.js:

/* global require, module */

...


app.import('bower_components/bootstrap/dist/css/bootstrap.css');
app.import('bower_components/bootstrap/dist/css/bootstrap.css.map', {
    destDir: 'assets'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.eot', {
    destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.ttf', {
    destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.svg', {
    destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.woff', {
    destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.woff2', {
    destDir: 'fonts'
});

app.import('bower_components/bootstrap/dist/js/bootstrap.js');

module.exports = app.toTree();

Ответ 4

Обновление 3/30/15

plus ça change... Теперь я использую ember-cli-bootstrap-sassy, он, как представляется, приносит минимум минимума, хотя и позволяет мне настраивать переменные Bootstrap.


Обновление 1/22/15

Вероятно, вы должны использовать решение Johnny выше, а не lib, о котором я упоминал ранее. Мне также нравится ember-cli-bootstrap-sass, потому что я могу настраивать переменные Bootstrap непосредственно в моем проекте.

Оригинал 7/11/14

Если вы используете версию ember-cli, поддерживающую аддоны (на мой взгляд, 0.35+), теперь вы можете использовать ember-cli-bootstrap. Из корня вашего приложения,

npm install --save-dev ember-cli-bootstrap

Что это!

Примечание: как указывает @poweratom, ember-cli-bootstrap - это некоторая библиотека, в которую также входит bootstrap-for-ember. Таким образом, эта библиотека может выйти из синхронизации с официальной версией бутстрапа. Тем не менее, я по-прежнему считаю это отличным способом быстрого прототипирования нового проекта!

Ответ 5

$> bower install --save bootstrap

Затем добавьте следующие две строки в ember-cli-builds.js (или Brocfile.js, если вы используете более старую версию Ember.js):

app.import(app.bowerDirectory + '/bootstrap/dist/js/bootstrap.js');
app.import(app.bowerDirectory + '/bootstrap/dist/css/bootstrap.css');

И вуаля, готов к работе!

обновлено 08/18/2015: адаптировано к новой схеме, введенной в Ember.js 1.13

Ответ 6

Вот как я упаковываю файлы CSS поставщика с помощью Broccoli (который лежит в основе Ember-cli).

 var vendorCss = concat('vendor', {
   inputFiles: [
     'pikaday/css/pikaday.css'
   , 'nvd3/nv.d3.css'
   , 'semantic-ui/build/packaged/css/semantic.css'
   ]
  , outputFile: '/assets/css/vendor.css'
  });

Где находится папка vendor, где хранятся мои пакеты Bower. И assets - это то место, где я ожидаю, что мой CSS будет жить. Я предполагаю, что вы установили Bootstrap, используя Bower, который является способом Ember-cli.

Затем в моем index.html я просто ссылаюсь на файл vendor.css:

  <link href="/assets/css/vendor.css" rel="stylesheet" type="text/css" media="all">

Приветствия.

Ответ 7

Если вы используете SASS (возможно, через ember-cli-sass), bower_components автоматически добавляется к пути поиска. Это означает, что вы можете просто использовать Bower и вообще избегать файла Brocfile/ember-cli-build.

Установите официальную версию Bootstrap SASS с Bower

bower install --save bootstrap-sass

затем импортируйте lib в app.scss. Самое приятное в этом - вы можете настроить переменные перед импортом bootstrap:

$brand-primary: 'purple';

@import 'bower_components/bootstrap-sass/assets/stylesheets/bootstrap';

Ответ 8

bower install --save bootstrap

в brocfile.js:

app.import('bower_components/bootstrap/dist/js/bootstrap.js');
app.import('bower_components/bootstrap/dist/css/bootstrap.css');

Ответ 9

На терминале (для тех, кто использует Node Package Manager)

npm install bootstrap --save

Использование ember-cli для импорта установленного загрузчика

Откройте файл ember-cli-build.js

module.exports = function(defaults) {
  let app = new EmberApp(defaults, {
    // Add options here
  });
app.import('node_modules/bootstrap/dist/css/bootstrap.min.css');
app.import('node_modules/bootstrap/dist/js/bootstrap.min.js');

Это будет сделано, если загрузчик установлен через установщик NPM.

Не делайте этого:

app.import('./node_modules/bootstrap/dist/css/bootstrap.min.css');
app.import('./node_modules/bootstrap/dist/js/bootstrap.min.js');