• اطلاعیه ها

    • Saeed Fard

      برگزاری میتاپ وردپرسی   14/08/96

      بعد از اولین دوره همایش وردپرس در ایران اگر پیگیر اخبار وردپرس بوده باشید، حتما خبر برگزاری چندین میتاپ و جلسه متعدد وردپرسی را شنیده‌اید، یکی از بحث‌های اصلی که محور اصلی این میتاپ‌ها بوده است برگزاری وردکمپ بود که به طور جدی دنبال می‌شود. این میتاپ‌ها و جلسات توسط جمعی از فعلان حوزه وردپرس در کنار وردپرس‌پارسی برگزار می‌شد و مسائل مربوط به این حیطه و از جمله وردکمپ مورد بحث قرار می‌گرفت. این بار با رایزنی‌هایی که با تیم اصلی وردپرس داشتیم در بخش دوم این رویدادها قصد داریم که میتاپ‌ها و جلسات وردپرسی را به صورت آزاد برگزار کنیم تا تمامی علاقه‌مندان و دوست‌داران وردپرس فرصت حضور داشته باشند و با گردهمایی، جامعه کاملتری از دوست داران وردپرس بسازیم و از تجربیات یکدیگر استفاده کنیم.   بدیهی است که این رویدادها با رویکرد مثبت در جهت سود رسانی به جامعه وردپرس و افراد حاضر در آن برگزار می‌شود و برای تمامی علاقه‌مندان به وردپرس است. پس اگر یک کاربر معمولی وردپرس یا یک توسعه دهنده هستید می‌توانید در این رویدادها شرکت کنید. ما در ملاقات‌هایمان از موارد مختلف و کاربردی وردپرس صحبت می‌کنیم و علاقمند به توسعه هر چه بیشتر وردپرس در ایران هستیم. ما وردپرس را دوست داریم. عضویت در این گروه برای همه افرادی که مایل به پیوستن هستند بدون در نظرگرفتن توانایی‌ها، مهارت‌ها، وضعیت مالی و یا معیارهای دیگر باز و رایگان است. فضای میتاپ‌ها و جلسات ما دوستانه و آزادنه و دور از هرگونه تبعیض و رفتارهای زننده است. بر این اساس از تمامی دوستانی که علاقه‌مند به شرکت در میتاپ‌های وردپرس هستند دعوت می‌شود تا از طریق لینک زیر در سایت میتاپ اقدام به ثبت‌نام کنند و منتظر خبرهای برگزاری جلسات در آینده باشند . لینک ثبت نام و عضویت : https://www.meetup.com/Iran-WordPress-Meetup    
reza_yki

مشکل در ساخت آپلودر

8 پست در این موضوع قرار دارد

سلام من پنل برای قالب بزدم و نخواستم از پنل های آماده استفاده کنم پس خودم دست به کار شدم

من اپلودری برای آپلود تصویر درست کردم ولی یک مشکل داره که امیدوارم دوستان کمکم کنن

 

من از اپلودر در 2 جا استفاده کردم یکی برای آپلود لوگو و دیگری برای آپلود فاویکون مشکل این هست که وقتی لوگو رو آپلود می کنی درست عمل می کنه بعد از اون وقتی مخوای فاویکون رو اپلود کنی به جای آپلود در فاویکون تصویر در لوگو قرار می گیره این در حالی هست که وقتی لوگو رو آپلود می کنی و بعد ذخیره می کنی بعدش میری فاویکون رو آپلود میکنی درست عمل می کنه نمی دونم تونستم منظورم رو برسونم یا خیر

 

احساس می کنم مشکل در قسما جی کوئری هست چون اگر هر دو رو باهم وقتی آپلود می کنه به مشکل بر می خوره در صورتی که جدا آپلود و ذخیره می کنی درست عمل میشه فک می کنم تونستم برسونم مطلب رو

این هم از کد جی کوئری:

//uploader
jQuery(document).ready(function ($) {
    var custom_uploader;
    $(document).on('click', '.select-uploader', function (e) {
        e.preventDefault();
        var $this = $(this);
        var $target = $this.data('target');
        var $target_type = $this.data('target-type');

        //If the uploader object has already been created, reopen the dialog
        if (custom_uploader) {
            custom_uploader.open();
            return;
        }
        //Extend the wp.media object
        custom_uploader = wp.media.frames.file_frame = wp.media({
            title: 'انتخاب تصویر',
            button: {
                text: 'انتخاب تصویر'
            },
            multiple: false
        });
        //When a file is selected, grab the URL and set it as the text field's value
        custom_uploader.on('select', function () {
            attachment = custom_uploader.state().get('selection').first().toJSON();

            switch(true){

                case $target_type === 'image' :
                    $('#' + $target).attr('src',attachment.url);
                    $('#' + $target+'_input').val(attachment.url);
                break;
            }
        });
        //Open the uploader dialog
        custom_uploader.open();
    });

});

لطفا راهنمایی کنید ضروری هست

این هم قسمت اینپوت:
 

//logo
<input type="text" class="img-path" id="yp_logo_input" name="yp_logo" 
       value="<?php echo isset($yp_options ['yp_logo'])? $yp_options ['yp_logo']:
              get_template_directory_uri() . '/functions/admin/option-panel/img/default-logo.png'; ?>">
<button data-target-type="image" data-target="yp_logo" class="yp-btn select-uploader">بارگذاری</button>




//favicon
<input type="text" class="img-path" id="yp_icon_input" name="yp_icon" 
       value="<?php echo isset($yp_options ['yp_icon'])? $yp_options ['yp_icon'] :
              get_template_directory_uri() . '/functions/admin/option-panel/img/default-favicon.png'; ?>">
<button data-target-type="image" data-target="yp_icon" class="yp-btn select-uploader">بارگذاری</button>

 

0

به اشتراک گذاری این پست


لینک به پست

من الان سریع و چشمی چک کردم بنظر مشکلی تو این کدها نیست.

چون آی دی و دیتاها رو درست جاگذاشتین.

تا اینجا بنظر مشکلی نداره.

1

به اشتراک گذاری این پست


لینک به پست
در هم اکنون، Morteza گفته است :

من الان سریع و چشمی چک کردم بنظر مشکلی تو این کدها نیست.

چون آی دی و دیتاها رو درست جاگذاشتین.

تا اینجا بنظر مشکلی نداره.

بله @Morteza جان وقتی جدا جدا عمل می کنم درست عمل می کنه ولی وقتی اول می رم لوگو رو آپلود می کنم بعد می رم دنبال فاویکون این مشکل به وجود میاد

0

به اشتراک گذاری این پست


لینک به پست

آیا باید ارایه ای درست کرد تا این مشکل به وجود نیاد و چطور؟

0

به اشتراک گذاری این پست


لینک به پست

ارسال شده در (ویرایش شده)

من فکر می کنم مشکل اینه که دکمه ها هردوشون با یک کلاس مشترک استفاده شده یعنی هر دو از کلاس
select-uploader

استفاده کرده اند و در جی کوئری اشکال هست یعنی این قسمت:

 $(document).on('click', '.select-uploader', function (e) {

ایا میشه کلاس + یه چیزه خاص کرد؟

این کد زیر برای یه قالب خارجی هست فک می کنم باید این شکلی باشه ولی نمی تونم:

jQuery(document).on("click", "#upload_"+field+"_button" , function( event ){

میشه کمکم کنید

ویرایش شده در توسط reza_yki
0

به اشتراک گذاری این پست


لینک به پست

اگر بتونید فقط بخش آپلود رو بصورت کامل برای این دو فیلد اینجا قرار بدید من تست میکنم و بهتون مشکلش رو میگم.

0

به اشتراک گذاری این پست


لینک به پست

من کل قسمت هایی که مربوط به آپلودر بوده رو براتون جدا و  در فایل zip ارسال کردم

 

نکته: وقتی کلاس button رو تغییر می دم (برای فاویکون رو ازselect_uploader به select_uploader_icon تغییر میدم ) و قسمت جی کوئری رو هم کلا دوباره با اون کلاس جدید درست می کنم همه چی درست میشه ولی این طوری باید برای هر آپلودر یک بار دیگه کل قسمت جی کوئری رو بنویسم

<input type="text" class="img-path" id="yp_icon_input" name="yp_icon" 
value="<?php echo isset($yp_options ['yp_icon'])? $yp_options ['yp_icon'] :
get_template_directory_uri() . '/functions/admin/option-panel/img/default-favicon.png'; ?>">
<button data-target-type="image" data-target="yp_icon" class="yp-btn select_uploader_icon">بارگذاری</button>

 

یعنی این شکلی باید بنویسم ولی نه استاندارد هست این روش نه بهینه:

//uploader
jQuery(document).ready(function ($) {
    var custom_uploader;
    $(document).on('click', '.select-uploader', function (e) {
        e.preventDefault();
        var $this = $(this);
        var $target = $this.data('target');
        var $target_type = $this.data('target-type');

        //If the uploader object has already been created, reopen the dialog
        if (custom_uploader) {
            custom_uploader.open();
            return;
        }
        //Extend the wp.media object
        custom_uploader = wp.media.frames.file_frame = wp.media({
            title: 'انتخاب تصویر',
            button: {
                text: 'انتخاب تصویر'
            },
            multiple: false
        });
        //When a file is selected, grab the URL and set it as the text field's value
        custom_uploader.on('select', function () {
            var attachment = custom_uploader.state().get('selection').first().toJSON();

            switch(true){

                case $target_type === 'image' :
                    $('#' + $target).attr('src',attachment.url);
                    $('#' + $target+'_input').val(attachment.url);
                break;


                // case $target_type === 'textbox':
                //     $('#' + $target).val(attachment.url);
                // break;


            }
        });
        //Open the uploader dialog
        custom_uploader.open();
    });
    
    ////

});




//آپلودر برای فاویکون
///////
jQuery(document).ready(function ($) {
    var custom_uploader;

    $(document).on('click', '.select_uploader_icon', function (e) { // فقط به خاطر این قسمت دوباره کل کد ها رو تکرار میکنم
        e.preventDefault();
        var $this = $(this);
        var $target = $this.data('target');
        var $target_type = $this.data('target-type');

        //If the uploader object has already been created, reopen the dialog
        if (custom_uploader) {
            custom_uploader.open();
            return;
        }
        //Extend the wp.media object
        custom_uploader = wp.media.frames.file_frame = wp.media({
            title: 'انتخاب تصویر',
            button: {
                text: 'انتخاب تصویر'
            },
            multiple: false
        });
        //When a file is selected, grab the URL and set it as the text field's value
        custom_uploader.on('select', function () {
            var attachment = custom_uploader.state().get('selection').first().toJSON();

            switch(true){

                case $target_type === 'image' :
                    $('#' + $target).attr('src',attachment.url);
                    $('#' + $target+'_input').val(attachment.url);
                    break;


                // case $target_type === 'textbox':
                //     $('#' + $target).val(attachment.url);
                // break;


            }
        });
        //Open the uploader dialog
        custom_uploader.open();
    });

});

منتظر پاسختون هستم ممنون

uploader.zip

0

به اشتراک گذاری این پست


لینک به پست

اساتید پیشنهادی نداشتن؟

0

به اشتراک گذاری این پست


لینک به پست

برای ارسال نظر یک حساب کاربری ایجاد کنید یا وارد حساب خود شوید

برای اینکه بتوانید نظر ارسال کنید نیاز دارید که کاربر سایت شوید

ایجاد یک حساب کاربری

برای حساب کاربری جدید در انجمن ما ثبت نام کنید. عضویت خیلی ساده است !


ثبت نام یک حساب کاربری جدید

ورود به حساب کاربری

دارای حساب کاربری هستید؟ از اینجا وارد شوید


ورود به حساب کاربری