134 lines
12 KiB
PHP
134 lines
12 KiB
PHP
@extends('skinlib.master')
|
|
|
|
@section('title', trans('skinlib.upload.title'))
|
|
|
|
@section('style')
|
|
<style>
|
|
label[for="type-skin"],
|
|
label[for="type-cape"] {
|
|
margin-top: 5px;
|
|
}
|
|
</style>
|
|
@endsection
|
|
|
|
@section('content')
|
|
<!-- Full Width Column -->
|
|
<div class="content-wrapper">
|
|
<div class="container">
|
|
<!-- Content Header (Page header) -->
|
|
<section class="content-header">
|
|
<h1>
|
|
{{ trans('skinlib.upload.title') }}
|
|
<small>Upload Texture</small>
|
|
</h1>
|
|
</section>
|
|
|
|
<!-- Main content -->
|
|
<section class="content">
|
|
<div class="row">
|
|
<div class="col-md-6">
|
|
<div class="box box-primary">
|
|
<div class="box-header with-border">
|
|
<h3 class="box-title">{{ trans('skinlib.upload.upload') }}</h3>
|
|
</div><!-- /.box-header -->
|
|
<div class="box-body">
|
|
<div class="form-group">
|
|
<label for="name">{{ trans('skinlib.upload.texture-name') }}</label>
|
|
<input id="name" class="form-control" type="text" placeholder="{{ trans('skinlib.upload.name-message') }}" />
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label>{{ trans('skinlib.upload.texture-type') }}</label>
|
|
<div class="row">
|
|
<div class="col-md-6">
|
|
<div class="row">
|
|
<div class="col-xs-4">
|
|
<label for="type-skin">
|
|
<input type="radio" name="type" id="type-skin"> {{ trans('general.skin') }}
|
|
</label>
|
|
</div>
|
|
<div class="col-xs-8">
|
|
<select class="form-control" id="skin-type" style="display: none;">
|
|
<option value="steve">{{ trans('skinlib.index.steve-model') }}</option>
|
|
<option value="alex">{{ trans('skinlib.index.alex-model') }}</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="col-md-6">
|
|
<label for="type-cape">
|
|
<input type="radio" name="type" id="type-cape"> {{ trans('general.cape') }}
|
|
</label>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="file">{{ trans('skinlib.upload.choose-file') }}</label>
|
|
<input id="file" type="file" data-show-upload="false" data-language="zh" class="file" accept="image/png" />
|
|
</div>
|
|
|
|
<div class="callout callout-info" id="msg" style="display: none;">
|
|
<p>{{ trans('skinlib.upload.storage-message', ['score' => option('private_score_per_storage')]) }}</p>
|
|
</div>
|
|
</div><!-- /.box-body -->
|
|
|
|
<div class="box-footer">
|
|
<label for="private" class="pull-right" title="{{ trans('skinlib.upload.privacy-message') }}" data-placement="top" data-toggle="tooltip">
|
|
<input id="private" type="checkbox"> {{ trans('skinlib.upload.set-private') }}
|
|
</label>
|
|
<button id="upload-button" onclick="upload()" class="btn btn-primary">{{ trans('skinlib.upload.button') }}</button>
|
|
</div>
|
|
</div><!-- /.box -->
|
|
</div>
|
|
<div class="col-md-6">
|
|
<div class="box box-default">
|
|
<div class="box-header with-border">
|
|
<h3 class="box-title" style="width: 100%;">{{ trans('general.texture-preview') }}
|
|
<div class="operations">
|
|
<i data-toggle="tooltip" data-placement="bottom" title="{{ trans('general.walk') }}" class="fa fa-pause"></i>
|
|
<i data-toggle="tooltip" data-placement="bottom" title="{{ trans('general.run') }}" class="fa fa-forward"></i>
|
|
<i data-toggle="tooltip" data-placement="bottom" title="{{ trans('general.rotation') }}" class="fa fa-repeat"></i>
|
|
</div>
|
|
</h3>
|
|
</div><!-- /.box-header -->
|
|
<div class="box-body">
|
|
<div id="skinpreview"></div>
|
|
</div><!-- /.box-body -->
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</section><!-- /.content -->
|
|
</div><!-- /.container -->
|
|
</div><!-- /.content-wrapper -->
|
|
|
|
<script type="text/javascript" src="{{ assets('vendor/skin-preview/three.min.js') }}"></script>
|
|
<script type="text/javascript" src="{{ assets('vendor/skin-preview/three.msp.js') }}"></script>
|
|
@endsection
|
|
|
|
@section('script')
|
|
<script>
|
|
// Default Steve Skin: https://minecraft.net/images/steve.png
|
|
var dskin = "";
|
|
MSP.changeSkin(dskin);
|
|
|
|
$(document).ready(function() {
|
|
init3dCanvas();
|
|
$('input[type=radio]').iCheck({
|
|
radioClass: 'iradio_square-blue'
|
|
});
|
|
$('input[type=checkbox]').iCheck({
|
|
checkboxClass: 'icheckbox_square-blue'
|
|
});
|
|
$('[for="private"]').tooltip();
|
|
});
|
|
|
|
// Auto resize canvas to fit responsive design
|
|
$(window).resize(init3dCanvas);
|
|
</script>
|
|
@endsection
|